shiplightai 0.1.45 → 0.1.47

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,31 +1,29 @@
1
- "use strict";var Tu=Object.create;var Hi=Object.defineProperty;var Au=Object.getOwnPropertyDescriptor;var Mu=Object.getOwnPropertyNames;var Iu=Object.getPrototypeOf,Cu=Object.prototype.hasOwnProperty;var b=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ue=(e,t)=>{for(var i in t)Hi(e,i,{get:t[i],enumerable:!0})},Ar=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Mu(t))!Cu.call(e,a)&&a!==i&&Hi(e,a,{get:()=>t[a],enumerable:!(n=Au(t,a))||n.enumerable});return e};var W=(e,t,i)=>(i=e!=null?Tu(Iu(e)):{},Ar(t||!e||!e.__esModule?Hi(i,"default",{value:e,enumerable:!0}):i,e)),$u=e=>Ar(Hi({},"__esModule",{value:!0}),e);function $r(e){Ia.updateConfig(e)}function G(){return Ia.getConfig()}function Pr(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var Pu,Ia,Wi,ie=b(()=>{"use strict";Pu=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}},Ia=new Pu,Wi=Ia});var Du,Lu,h,R=b(()=>{"use strict";ie();Du=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)}},Lu=new Du,h=Lu});async function Ou(e,t){let i=await import(e),n=Object.keys(i),a=new it.SyntheticModule(n,function(){for(let o of n)this.setExport(o,i[o])},{context:t});return await a.link(()=>{throw new Error("Nested imports not supported in VM context")}),await a.evaluate(),a}function Ca(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let a;if(it.isContext(e)?a=new it.Script(i,{importModuleDynamically:async o=>Ou(o,e)}).runInContext(e):a=(0,eval)(i),typeof a!="function")throw new Error("The injected code must be a function");e[t]=a}catch(a){h.error(`Error injecting user function ${t}: ${a.message}`)}}async function Lr(e,t,i=!1){try{let n=await Dr.readFile(t,"utf8"),a=JSON.parse(n);h.info(`Loading ${Object.keys(a).length} user functions...`);for(let[o,r]of Object.entries(a))Ca(e,o,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var Dr,it,Or=b(()=>{"use strict";R();Dr=W(require("fs/promises"),1),it=W(require("vm"),1)});async function Nr(e){try{let t=await $a.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function Rr(e){try{let t=await $a.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var $a,Fr=b(()=>{"use strict";R();$a=W(require("fs/promises"),1)});async function Hr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,a="";try{for(;;){let{done:o,value:r}=await i.read();if(o)break;a+=n.decode(r,{stream:!0});let s=a.split(`
2
- `);a=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var Wr=b(()=>{"use strict"});var Pa,Nu,f,ne=b(()=>{"use strict";ie();Pa=require("fs"),Nu=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=G().agentLogPath;if(e)try{(0,Pa.appendFileSync)(e,`
1
+ "use strict";var Nu=Object.create;var Ui=Object.defineProperty;var Ru=Object.getOwnPropertyDescriptor;var Fu=Object.getOwnPropertyNames;var Hu=Object.getPrototypeOf,Wu=Object.prototype.hasOwnProperty;var y=(e,t)=>()=>(e&&(t=e(e=0)),t);var Ge=(e,t)=>{for(var i in t)Ui(e,i,{get:t[i],enumerable:!0})},Dr=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Fu(t))!Wu.call(e,o)&&o!==i&&Ui(e,o,{get:()=>t[o],enumerable:!(n=Ru(t,o))||n.enumerable});return e};var W=(e,t,i)=>(i=e!=null?Nu(Hu(e)):{},Dr(t||!e||!e.__esModule?Ui(i,"default",{value:e,enumerable:!0}):i,e)),Bu=e=>Dr(Ui({},"__esModule",{value:!0}),e);function Rr(e){Lo.updateConfig(e)}function U(){return Lo.getConfig()}function Fr(){switch(process.env.SDK_LOG_LEVEL?.toLowerCase()){case"debug":return 0;case"info":return 1;case"warn":return 2;case"error":return 3;case"silent":return 4;default:return}}var Uu,Lo,Gi,te=y(()=>{"use strict";Uu=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}},Lo=new Uu,Gi=Lo});var Gu,Ku,h,R=y(()=>{"use strict";te();Gu=class{getLevel(){return Gi.get("logLevel")}isStderrOnly(){return Gi.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){Gi.set("logLevel",e)}},Ku=new Gu,h=Ku});async function ju(e,t){let i=await import(e),n=Object.keys(i),o=new it.SyntheticModule(n,function(){for(let a of n)this.setExport(a,i[a])},{context:t});return await o.link(()=>{throw new Error("Nested imports not supported in VM context")}),await o.evaluate(),o}function Oo(e,t,i,n=!1){if(e[t])if(n)h.info(`Overriding existing function: ${t}`),delete e[t];else{h.error(`The name ${t} is already defined in the global scope`);return}try{let o;if(it.isContext(e)?o=new it.Script(i,{importModuleDynamically:async a=>ju(a,e)}).runInContext(e):o=(0,eval)(i),typeof o!="function")throw new Error("The injected code must be a function");e[t]=o}catch(o){h.error(`Error injecting user function ${t}: ${o.message}`)}}async function Wr(e,t,i=!1){try{let n=await Hr.readFile(t,"utf8"),o=JSON.parse(n);h.info(`Loading ${Object.keys(o).length} user functions...`);for(let[a,r]of Object.entries(o))Oo(e,a,r,i)}catch(n){throw h.error("Failed to load user functions:",n),n}}var Hr,it,Br=y(()=>{"use strict";R();Hr=W(require("fs/promises"),1),it=W(require("vm"),1)});async function Ur(e){try{let t=await No.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledges from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledges file found"),[];throw h.error("Failed to load knowledges:",t),t}}async function Gr(e){try{let t=await No.readFile(e,"utf8"),i=JSON.parse(t);return h.info(`Loaded ${i.length} knowledge mappings from file`),i}catch(t){if(t.code==="ENOENT")return h.debug("No knowledge mappings file found"),[];throw h.error("Failed to load knowledge mappings:",t),t}}var No,Kr=y(()=>{"use strict";R();No=W(require("fs/promises"),1)});async function jr(e,t){if(!e.body)throw new Error("Response body is null");let i=e.body.getReader(),n=new TextDecoder,o="";try{for(;;){let{done:a,value:r}=await i.read();if(a)break;o+=n.decode(r,{stream:!0});let s=o.split(`
2
+ `);o=s.pop()||"";for(let l of s){let d=null;if(l.startsWith("data: "))try{let c=l.slice(6);c.trim()&&(d=JSON.parse(c))}catch(c){console.error(`Failed to parse SSE event: ${l}`,c);continue}d&&t(d)}}}finally{i.releaseLock()}}var zr=y(()=>{"use strict"});var Ro,zu,w,ie=y(()=>{"use strict";te();Ro=require("fs"),zu=class{constructor(){this.initialized=!1}init(){if(this.initialized)return;let e=U().agentLogPath;if(e)try{(0,Ro.appendFileSync)(e,`
3
3
  === Agent Execution Log ===
4
4
  Started: ${new Date().toISOString()}
5
5
 
6
- `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=G().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,Pa.appendFileSync)(t,`[${i}] ${e}
6
+ `),this.initialized=!0}catch(t){console.error(`[AgentLogger] Failed to initialize log file: ${t.message}`)}}log(e){let t=U().agentLogPath;if(t){this.initialized||this.init();try{let i=new Date().toISOString();(0,Ro.appendFileSync)(t,`[${i}] ${e}
7
7
  `)}catch{}}}section(e){this.log(`
8
8
  ${"=".repeat(60)}
9
9
  ${e}
10
- ${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,a=i.completionTokens||i.outputTokens||0,o=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${a} completion = ${o} total`)}}thinking(e){this.log(`Native Thinking:
10
+ ${"=".repeat(60)}`)}step(e,t,i){this.section(`Step ${e}/${t}`),i.task&&this.log(`Task: ${i.task}`),i.url&&this.log(`URL: ${i.url}`),i.thinking&&this.log(`Thinking: ${i.thinking}`),i.evaluation&&this.log(`Evaluation: ${i.evaluation}`),i.memory&&this.log(`Memory: ${i.memory}`),i.goal&&this.log(`Goal: ${i.goal}`),i.actions&&this.log(`Actions: ${i.actions}`)}llmCall(e,t,i){if(this.log(`LLM Call: ${e}`),this.log(`Duration: ${(t/1e3).toFixed(2)}s`),i){let n=i.promptTokens||i.inputTokens||0,o=i.completionTokens||i.outputTokens||0,a=i.totalTokens||0;this.log(`Tokens: ${n} prompt + ${o} completion = ${a} total`)}}thinking(e){this.log(`Native Thinking:
11
11
  ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
12
12
  ${e}`),this.log(`
13
13
  User Prompt:
14
14
  ${t}`)}response(e){this.log(`LLM Response:
15
- ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!G().agentLogPath}},f=new Nu});var Bi,Ru,Fu,Hu,Wu,Br,Gi,Da,Gr,La,Oa,fe=b(()=>{"use strict";Bi=Object.defineProperty,Ru=Object.getOwnPropertyDescriptor,Fu=Object.getOwnPropertyNames,Hu=Object.prototype.hasOwnProperty,Wu=(e,t,i)=>t in e?Bi(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Br=(e,t)=>()=>(e&&(t=e(e=0)),t),Gi=(e,t)=>{for(var i in t)Bi(e,i,{get:t[i],enumerable:!0})},Da=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Fu(t))!Hu.call(e,a)&&a!==i&&Bi(e,a,{get:()=>t[a],enumerable:!(n=Ru(t,a))||n.enumerable});return e},Gr=(e,t,i)=>(Da(e,t,"default"),i&&Da(i,t,"default")),La=e=>Da(Bi({},"__esModule",{value:!0}),e),Oa=(e,t,i)=>Wu(e,typeof t!="symbol"?t+"":t,i)});function D(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Ra}function Bu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function Na(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 Gu(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 Uu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Ku(e){let t=e.xpath;return typeof t=="string"&&t.trim()?!t.startsWith("xpath=")&&!t.startsWith("/")&&!t.startsWith("//")?`xpath=//${t}`:t.startsWith("xpath=")?t:`xpath=${t}`:null}function Le(e){let t=Uu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Ku(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var Ui,Mt,Ra,we,$,F=b(()=>{"use strict";fe();Ui={};Gi(Ui,{ACTION_TIMEOUT:()=>Ra,GOTO_TIMEOUT:()=>we,LOCATOR_TIMEOUT:()=>Mt,getActionTimeoutMs:()=>D,getFrameContext:()=>Na,getLocator:()=>O,getMinimalActionEntity:()=>Gu,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>Bu});$=Br(()=>{Mt=5e3,Ra=1e4,we=2e4})});async function It(e,t,i=[],n=[]){try{let a=await Na(e,i);if(!a)return h.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=a.locator(`xpath=${Ur(s)}`),d=ju(t);if(o=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Ur(t)}`)).elementHandle({timeout:Mt}),!o)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:Mt}),!o)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,o);return await o.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return h.error(`Error in pickBestLocator: ${a}`),null}}async function Ki(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Kr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let a=await It(e,n);i.set(n,a)})),i}function Ur(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function ju(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),s=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ke=b(()=>{"use strict";R();F();$()});async function jr(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),{width:r=0,height:s=0}=await o.metadata();return f.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function oe(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 ji(e,t){return t?{xpath:void 0,locator:await Ki(e,t)??void 0,frame_path:[]}:{xpath:void 0,locator:void 0,frame_path:[]}}function zi(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 nt=b(()=>{"use strict";ne();Ke()});function Vi(){let e=(G().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Yr(e){let t=G().env||{};if(Vi()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let a=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${a}`),(0,Xr.createVertex)({project:n,location:a})(e)}let i=t.GOOGLE_API_KEY;if(!i)throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.");return h.debug(`Using Google AI provider (API key): model=${e}`),(0,Vr.createGoogleGenerativeAI)({apiKey:i})(e)}function Jr(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:zr.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=zr.MEDIA_RESOLUTION_HIGH)}return Vi()?{vertex:a}:{google:a}}var Vr,Xr,zr,at=b(()=>{"use strict";R();ie();Vr=require("@ai-sdk/google"),Xr=require("@ai-sdk/google-vertex"),zr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function Z(e,t){return Math.round(e/1e3*t)}async function Vu(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let s=Z(i.x,n),l=Z(i.y,a),d=await oe(e,s,l);o={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=Z(i.x,n),l=Z(i.y,a),d=await oe(e,s,l);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=Z(i.x,n),l=Z(i.y,a),d=await oe(e,s,l);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"hover_at":{let s=Z(i.x,n),l=Z(i.y,a),d=await oe(e,s,l);o={action_name:"hover",kwargs:{}},r=d.element;break}case"scroll_at":{let s=Z(i.x,n),l=Z(i.y,a),d=await oe(e,s,l),c=i.direction??"down",u=Z(i.magnitude??800,c==="left"||c==="right"?n:a),p=c==="right"?u:c==="left"?-u:0,g=c==="down"?u:c==="up"?-u:0;o={action_name:"scroll_on_element",kwargs:{delta_x:p,delta_y:g}},r=d.element;break}case"drag_and_drop":{let s=Z(i.x,n),l=Z(i.y,a),d=Z(i.destination_x,n),c=Z(i.destination_y,a),u=await oe(e,s,l);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:f.log(`Unsupported Gemini function: ${t}`)}}catch(s){f.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:o,locatorInfo:await ji(e,r)}}async function Zr(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,s=G(),l;if(Vi()){let m=s.env?.GOOGLE_CLOUD_PROJECT;if(!m)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let x=s.env?.GOOGLE_CLOUD_LOCATION??"global";l={vertexai:!0,project:m,location:x}}else{let m=s.env?.GOOGLE_API_KEY;if(!m)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};l={apiKey:m}}let d=new Xi.GoogleGenAI(l);f.log("Sending request to Gemini CUA...");let c=await d.models.generateContent({model:r,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Xi.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination"]}},{functionDeclarations:zu}],temperature:.1}});f.log("Received response from Gemini CUA");let u=c.candidates?.[0];if(!u)return{status:"error",error:"No candidates in Gemini response"};let p=u.content?.parts?.find(m=>m.functionCall);if(!p)return{status:"error",reasoning:u.content?.parts?.filter(m=>m.text).map(m=>m.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:g,args:w}=p.functionCall;f.log(`Generated function call: ${g} with args ${JSON.stringify(w)}`),h.debug(`Generated function call: ${g} with args ${JSON.stringify(w)}`);let{action_data:k,locatorInfo:y}=await Vu(i,g,w,a,o);return k?{status:"success",actionEntity:zi(t,k,y),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${g}`}}var Xi,qr,zu,Yi=b(()=>{"use strict";nt();ne();at();R();ie();Xi=require("@google/genai");qr={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"]},zu=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:qr},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:qr}]});async function Xu(e,t){let i=null,n=null;switch(t.type){case"click":{if(t.x===void 0||t.y===void 0)break;let a=t.button==="right"?"right_click_by_coordinates":"click_by_coordinates",o=await oe(e,t.x,t.y);i={action_name:a,kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},n=o.element;break}case"double_click":{if(t.x===void 0||t.y===void 0)break;let a=await oe(e,t.x,t.y);i={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},n=a.element;break}case"drag":{if(!t.path||t.path.length<2)break;let[a,o]=[t.path[0],t.path[1]],r=await oe(e,a.x,a.y);i={action_name:"drag_drop",kwargs:{relative_x:r.relative_x,relative_y:r.relative_y,delta_x:o.x-a.x,delta_y:o.y-a.y}},n=r.element;break}case"move":{if(t.x===void 0||t.y===void 0)break;let a=await oe(e,t.x,t.y);i={action_name:"hover",kwargs:{}},n=a.element;break}case"scroll":{if(t.x===void 0||t.y===void 0)break;let a=await oe(e,t.x,t.y);i={action_name:"scroll_on_element",kwargs:{delta_x:t.scroll_x,delta_y:t.scroll_y}},n=a.element;break}}return{action_data:i,locatorInfo:await ji(e,n)}}async function es(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o}=e,r=G().env?.OPENAI_API_KEY;if(!r)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let s=new Qr.default({apiKey:r});f.log("Sending request to OpenAI CUA...");let l=`You will be given an action to execute and screenshot of the current screen.
16
- Output one computer_call object that will accomplish this action.
17
- Action: ${t}`,d=await s.responses.create({model:"computer-use-preview",tools:[{type:"computer_use_preview",display_width:a,display_height:o,environment:"browser"}],input:[{role:"user",content:[{type:"input_text",text:l},{type:"input_image",detail:"auto",image_url:`data:image/png;base64,${n}`}]}],truncation:"auto",temperature:.1});f.log("Received response from OpenAI CUA");let c=d.output.find(g=>g.type==="computer_call")??null;if(!c)return{status:"error",reasoning:d.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};f.log(`Generated action: ${JSON.stringify(c.action)}`);let{action_data:u,locatorInfo:p}=await Xu(i,c.action);return u?{status:"success",actionEntity:zi(t,u,p),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:"Failed to map OpenAI action"}}var Qr,Ji=b(()=>{"use strict";nt();ne();ie();Qr=W(require("openai"),1)});function is(e){let t=G(),i=t.env?.OPENAI_API_KEY;if(!i)throw new Error("OPENAI_API_KEY not configured in SDK config");let n=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),(0,ts.createOpenAI)({apiKey:i,baseURL:n})(e)}function ns(e){return{}}var ts,Ct=b(()=>{"use strict";R();ie();ts=require("@ai-sdk/openai")});function Yu(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Fa(e){return G().env?.[e]??process.env[e]}function Ju(){return Yu(Fa("ANTHROPIC_MODELS_USE_VERTEXAI"))}function rs(e){if(Ju()){let i=Fa("GOOGLE_CLOUD_PROJECT"),n=Fa("GOOGLE_CLOUD_LOCATION");if(!i)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!n)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${i}, location=${n}`),(0,os.createVertexAnthropic)({project:i,location:n})(e)}let t=G().env?.ANTHROPIC_API_KEY;if(!t)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return h.debug(`Using Anthropic provider: model=${e}`),(0,as.createAnthropic)({apiKey:t})(e)}function Ha(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var as,os,$t=b(()=>{"use strict";R();ie();as=require("@ai-sdk/anthropic"),os=require("@ai-sdk/google-vertex/anthropic")});function ls(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(qu.test(e))return"openai"}function qi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(Zu.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function be(e){let{provider:t,modelId:i}=qi(e),n=t??ls(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=ss[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(ss).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function ye(e,t){let{provider:i,modelId:n}=qi(e),a=i??ls(n);return a==="anthropic"||a==="vertex"?Ha(n):a==="openai"||a==="azure"?ns(n):a==="bedrock"?n.startsWith("anthropic.")?Ha(n):{}:Jr(t,n)}var qu,Zu,ss,Ee=b(()=>{"use strict";Ct();$t();at();qu=/^(gpt-|o\d|chatgpt-)/;Zu=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);ss={anthropic:rs,google:Yr,openai:is}});function eh(e){return e.startsWith("gemini-")?"google":"openai"}async function ot(e,t,i={}){let{page:n}=t,a=n.viewportSize();if(!a)return{status:"error",error:"Viewport size not available"};let{width:o,height:r}=a;f.log(`Viewport: ${o}x${r}`);let s=await jr(n,o,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=qi(l),c=eh(d),u=Qu[c];f.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:o,viewportHeight:r,modelId:d};try{return await u(p)}catch(g){return f.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var Qu,rt=b(()=>{"use strict";Yi();Ji();nt();ne();Ee();Qu={google:Zr,openai:es}});function Zi(e){let t=(0,Wa.zodToJsonSchema)(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return Pt(t),t}function Qi(e){return(0,Wa.zodToJsonSchema)(e,{$refStrategy:"none"})}function Pt(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))Pt(i)}e.type==="array"&&e.items&&Pt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Pt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Pt(i)}}var Wa,Dt=b(()=>{"use strict";Wa=require("zod-to-json-schema")});var en,tn=b(()=>{"use strict";Dt();en=class{constructor(e){this.registry=e}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.openai).map(e=>({type:"function",function:{name:e.name,description:e.description,parameters:Zi(e.schema),strict:!0}}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.openai).map(i=>({type:"function",function:{name:i.name,description:i.description,parameters:Zi(i.schema),strict:!0}}))}toJSON(){return this.getToolDefinitions()}getToolDefinition(e){let t=this.registry.get(e);if(t)return{type:"function",function:{name:t.name,description:t.description,parameters:Zi(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function th(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(o,r.index);l&&a.push({type:"text",text:l});let d=r[2];i.has(d)?a.push({type:"image",image:new URL(i.get(d))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let s=e.slice(o);return s&&a.push({type:"text",text:s}),a.length===0&&a.push({type:"text",text:e}),a}function ih(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=th(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
15
+ ${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!U().agentLogPath}},w=new zu});var Ki,Vu,Xu,Yu,Ju,Vr,ji,Fo,Xr,Ho,Wo,pe=y(()=>{"use strict";Ki=Object.defineProperty,Vu=Object.getOwnPropertyDescriptor,Xu=Object.getOwnPropertyNames,Yu=Object.prototype.hasOwnProperty,Ju=(e,t,i)=>t in e?Ki(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,Vr=(e,t)=>()=>(e&&(t=e(e=0)),t),ji=(e,t)=>{for(var i in t)Ki(e,i,{get:t[i],enumerable:!0})},Fo=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let o of Xu(t))!Yu.call(e,o)&&o!==i&&Ki(e,o,{get:()=>t[o],enumerable:!(n=Vu(t,o))||n.enumerable});return e},Xr=(e,t,i)=>(Fo(e,t,"default"),i&&Fo(i,t,"default")),Ho=e=>Fo(Ki({},"__esModule",{value:!0}),e),Wo=(e,t,i)=>Ju(e,typeof t!="symbol"?t+"":t,i)});function L(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Uo}function qu(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Le(t);return i?new Function("page",`return ${i}`)(e):null}async function Bo(e,t=[]){let i=e;for(let n of t){let o=await i.locator(n).elementHandle();if(!o)return null;let a=await o.contentFrame();if(await o.dispose(),!a)return null;i=a}return i}function Zu(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 Qu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function eh(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 Le(e){let t=Qu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=eh(e);if(n){let o=JSON.stringify(n);return`${t}.locator(${o}).first()`}return null}var zi,Ct,Uo,ge,P,F=y(()=>{"use strict";pe();zi={};ji(zi,{ACTION_TIMEOUT:()=>Uo,GOTO_TIMEOUT:()=>ge,LOCATOR_TIMEOUT:()=>Ct,getActionTimeoutMs:()=>L,getFrameContext:()=>Bo,getLocator:()=>O,getMinimalActionEntity:()=>Zu,getPageLocatorExpression:()=>Le,sanitizeForComment:()=>qu});P=Vr(()=>{Ct=5e3,Uo=1e4,ge=2e4})});async function It(e,t,i=[],n=[]){try{let o=await Bo(e,i);if(!o)return h.warn(`Could not find frame context for xpath: ${t}`),null;let a=null;if(n.length>0){let s=n[0];if(!s)return h.warn(`Missing shadow host xpath for element: ${t}`),null;let l=o.locator(`xpath=${Yr(s)}`),d=th(t);if(a=await(d?l.locator(`css=${d}`):l.locator(`xpath=${Yr(t)}`)).elementHandle({timeout:Ct}),!a)return h.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(a=await o.locator(`xpath=${t}`).elementHandle({timeout:Ct}),!a)return h.warn(`Could not find element with xpath: ${t}`),null;let r=await o.evaluate(s=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(s):null,a);return await a.dispose(),r?(h.debug(`Generated locator for ${t}: ${r}`),r):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(o){return h.error(`Error in pickBestLocator: ${o}`),null}}async function Vi(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(h.debug(`Generated locator: ${i}`),i):(h.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return h.error(`Error in pickBestLocator: ${i}`),null}}async function Jr(e,t){let i=new Map;return await Promise.all(t.map(async n=>{let o=await It(e,n);i.set(n,o)})),i}function Yr(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function th(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let o of i){let a=o.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!a)return null;let r=a[1].toLowerCase(),s=a[2]?`:nth-of-type(${a[2]})`:"";n.push(`${r}${s}`)}return n.join(" > ")}var Ke=y(()=>{"use strict";R();F();P()});async function Pt(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(l=>l()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:o}=await import("sharp"),a=o(n),{width:r=0,height:s=0}=await a.metadata();return w.log(`Screenshot actual: ${r}x${s}, viewport: ${t}x${i}`),(r!==t||s!==i?await a.resize(t,i).png().toBuffer():n).toString("base64")}async function Se(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),o=n.asElement();if(!o)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let a=await o.boundingBox();if(!a)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(a.x+a.width/2),relative_y:i-(a.y+a.height/2),element:o}}async function Xi(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(o=>{let a=[],r=o;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let s=1,l=r.previousElementSibling;for(;l;)l.tagName===r.tagName&&s++,l=l.previousElementSibling;a.unshift(`${r.tagName.toLowerCase()}[${s}]`),r=r.parentElement}return a.length?`/${a.join("/")}`:null}).catch(()=>null),n=await Vi(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function Yi(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 nt=y(()=>{"use strict";ie();Ke()});function Ji(){let e=(U().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function es(e){let t=U().env||{};if(Ji()){let n=t.GOOGLE_CLOUD_PROJECT;if(!n)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e==="gemini-3-flash-preview"?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return h.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,Qr.createVertex)({project:n,location:o})(e)}let i=t.GOOGLE_API_KEY;if(!i)throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.");return h.debug(`Using Google AI provider (API key): model=${e}`),(0,Zr.createGoogleGenerativeAI)({apiKey:i})(e)}function ts(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:qr.MEDIA_RESOLUTION_HIGH},o;switch(t){case"gemini-3-flash-preview":o={...n};break;default:o={...i},e===1&&(o.mediaResolution=qr.MEDIA_RESOLUTION_HIGH)}return Ji()?{vertex:o}:{google:o}}var Zr,Qr,qr,ot=y(()=>{"use strict";R();te();Zr=require("@ai-sdk/google"),Qr=require("@ai-sdk/google-vertex"),qr={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function fe(e,t){return Math.round(e/1e3*t)}async function nh(e,t,i,n,o){let a=null,r=null;try{switch(t){case"click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"right_click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"right_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"double_click_at":{let s=fe(i.x,n),l=fe(i.y,o),d=await Se(e,s,l);a={action_name:"double_click_by_coordinates",kwargs:{relative_x:d.relative_x,relative_y:d.relative_y}},r=d.element;break}case"drag_and_drop":{let s=fe(i.x,n),l=fe(i.y,o),d=fe(i.destination_x,n),c=fe(i.destination_y,o),u=await Se(e,s,l);a={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:d-s,delta_y:c-l}},r=u.element;break}default:w.log(`Unsupported Gemini function: ${t}`)}}catch(s){w.error(`Error mapping Gemini action "${t}"`,s)}return{action_data:a,locatorInfo:await Xi(e,r)}}async function ns(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:o,viewportHeight:a,modelId:r}=e,s=r||oh,l=U(),d;if(Ji()){let b=l.env?.GOOGLE_CLOUD_PROJECT;if(!b)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let _=l.env?.GOOGLE_CLOUD_LOCATION??"global";d={vertexai:!0,project:b,location:_}}else{let b=l.env?.GOOGLE_API_KEY;if(!b)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};d={apiKey:b}}let c=new qi.GoogleGenAI(d);w.log(`Sending request to Gemini CUA (model=${s})...`);let u=await c.models.generateContent({model:s,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:qi.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:ih}],temperature:.1}});w.log("Received response from Gemini CUA");let p=u.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let g=p.content?.parts?.find(b=>b.functionCall);if(!g)return{status:"error",reasoning:p.content?.parts?.filter(b=>b.text).map(b=>b.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:f,args:k}=g.functionCall;w.log(`Generated function call: ${f} with args ${JSON.stringify(k)}`),h.debug(`Generated function call: ${f} with args ${JSON.stringify(k)}`);let{action_data:x,locatorInfo:m}=await nh(i,f,k,o,a);return x?{status:"success",actionEntity:Yi(t,x,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${f}`}}var qi,is,ih,oh,Zi=y(()=>{"use strict";nt();ie();ot();R();te();qi=require("@google/genai");is={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"]},ih=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:is},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:is}];oh="gemini-3-flash-preview"});function as(e){return e!=null&&typeof e=="object"}function at(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function os(e){return typeof e=="string"?e:void 0}function ah(e){let t,i;return Array.isArray(e)?(t=at(e[0]),i=at(e[1])):as(e)&&(t=at(e.x),i=at(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function rs(e){if(!as(e))return{};let t=Array.isArray(e.path)?e.path.map(ah).filter(i=>i!==null):void 0;return{type:os(e.type),x:at(e.x),y:at(e.y),button:os(e.button),path:t}}var Qi=y(()=>{"use strict"});async function rh(e,t){let i=rs(t),n=null,o=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let a=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await Se(e,i.x,i.y);n={action_name:a,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},o=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let a=await Se(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:a.relative_x,relative_y:a.relative_y}},o=a.element;break}case"drag":{if(!i.path||i.path.length<2)break;let a=i.path[0],r=i.path[i.path.length-1],s=await Se(e,a.x,a.y);n={action_name:"drag_drop",kwargs:{relative_x:s.relative_x,relative_y:s.relative_y,delta_x:r.x-a.x,delta_y:r.y-a.y}},o=s.element;break}}return{action_data:n,locatorInfo:await Xi(e,o)}}async function cs(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:o,modelId:a}=e,r=a||sh,s=await Pt(i,n,o),l=U().env?.OPENAI_API_KEY;if(!l)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=new ls.default({apiKey:l}),c=d.responses.create.bind(d.responses);w.log(`Sending request to OpenAI CUA (model=${r})...`);let u=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${s}`}]}];async function p(m,b){let _={model:r,tools:[lh],input:m,temperature:.1};return b&&(_.previous_response_id=b),c(_)}let g=await p(u,void 0),f;for(let m=0;m<ss;m++){w.log(`Received response from OpenAI CUA (turn ${m+1})`);let b=g.output.find(S=>S.type==="computer_call");if(!b)return{status:"error",reasoning:g.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let _=b.actions??[];if(_.length>1&&w.log(`[openai CUA] dropping ${_.length-1} batched action(s); only the first is executed`),f=_[0],!f)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(f.type!=="screenshot")break;s=await Pt(i,n,o);let v=[{type:"computer_call_output",call_id:b.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${s}`}}];g=await p(v,g.id)}if(!f)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(f.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${ss} turns`};w.log(`Generated action: ${JSON.stringify(f)}`);let{action_data:k,locatorInfo:x}=await rh(i,f);return k?{status:"success",actionEntity:Yi(t,k,x),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(f)}`}}var ls,sh,lh,ss,en=y(()=>{"use strict";Qi();nt();ie();te();ls=W(require("openai"),1);sh="gpt-5.4",lh={type:"computer"},ss=4});function us(e){let t=U(),i=t.env?.OPENAI_API_KEY;if(!i)throw new Error("OPENAI_API_KEY not configured in SDK config");let n=t.env?.OPENAI_BASE_URL;return h.debug(`Using OpenAI provider: model=${e}${n?`, baseURL=${n}`:""}`),(0,ds.createOpenAI)({apiKey:i,baseURL:n})(e)}function hs(e){return{}}var ds,$t=y(()=>{"use strict";R();te();ds=require("@ai-sdk/openai")});function ch(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function Go(e){return U().env?.[e]??process.env[e]}function dh(){return ch(Go("ANTHROPIC_MODELS_USE_VERTEXAI"))}function gs(e){if(dh()){let i=Go("GOOGLE_CLOUD_PROJECT"),n=Go("GOOGLE_CLOUD_LOCATION");if(!i)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!n)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return h.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${i}, location=${n}`),(0,ps.createVertexAnthropic)({project:i,location:n})(e)}let t=U().env?.ANTHROPIC_API_KEY;if(!t)throw new Error("ANTHROPIC_API_KEY not configured in SDK config");return h.debug(`Using Anthropic provider: model=${e}`),(0,ms.createAnthropic)({apiKey:t})(e)}function Ko(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var ms,ps,Dt=y(()=>{"use strict";R();te();ms=require("@ai-sdk/anthropic"),ps=require("@ai-sdk/google-vertex/anthropic")});function ws(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(uh.test(e))return"openai"}function tn(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(hh.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function we(e){let{provider:t,modelId:i}=tn(e),n=t??ws(i);if(!n)throw new Error(`Cannot determine provider for model: ${e}. Use a known model prefix (claude-*, gemini-*, gpt-*) or specify a provider (e.g., "openai:${i}", "azure:${i}", "bedrock:${i}").`);if(!i)throw new Error(`Empty model ID in model string: "${e}". Specify a model after the provider prefix (e.g., "${n}:gpt-5.4-mini").`);let o=fs[n];if(!o)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(fs).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return o(i)}function be(e,t){let{provider:i,modelId:n}=tn(e),o=i??ws(n);return o==="anthropic"||o==="vertex"?Ko(n):o==="openai"||o==="azure"?hs(n):o==="bedrock"?n.startsWith("anthropic.")?Ko(n):{}:ts(t,n)}var uh,hh,fs,Ee=y(()=>{"use strict";$t();Dt();ot();uh=/^(gpt-|o\d|chatgpt-)/;hh=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);fs={anthropic:gs,google:es,openai:us}});function ph(e){return e.startsWith("gemini-")?"google":"openai"}async function rt(e,t,i={}){let{page:n}=t,o=n.viewportSize();if(!o)return{status:"error",error:"Viewport size not available"};let{width:a,height:r}=o;w.log(`Viewport: ${a}x${r}`);let s=await Pt(n,a,r),l=t.agentServices.getComputerUseModel();if(!l)return{status:"error",error:"No computer use model configured"};let{modelId:d}=tn(l),c=ph(d),u=mh[c];w.log(`Using CUA provider: ${c} (model: ${d})`);let p={statement:e,page:n,screenshotB64:s,viewportWidth:a,viewportHeight:r,modelId:d};try{return await u(p)}catch(g){return w.error(`CUA provider "${c}" threw an error`,g),{status:"error",error:g.message??"CUA provider failed"}}}var mh,st=y(()=>{"use strict";Zi();en();nt();ie();Ee();mh={google:ns,openai:cs}});function nn(e){let t=(0,jo.zodToJsonSchema)(e,{$refStrategy:"none"});if(t.$schema&&delete t.$schema,t.type!=="object")throw new Error(`Schema must be a Zod object schema, got type: ${t.type}`);return Lt(t),t}function on(e){return(0,jo.zodToJsonSchema)(e,{$refStrategy:"none"})}function Lt(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))Lt(i)}e.type==="array"&&e.items&&Lt(e.items);for(let t of["anyOf","oneOf","allOf"])Array.isArray(e[t])&&e[t].forEach(Lt);for(let[t,i]of Object.entries(e))typeof i=="object"&&i!==null&&!["properties","items","anyOf","oneOf","allOf"].includes(t)&&Lt(i)}}var jo,Ot=y(()=>{"use strict";jo=require("zod-to-json-schema")});var an,rn=y(()=>{"use strict";Ot();an=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:nn(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:nn(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:nn(t.schema),strict:!0}}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});function gh(e,t){let i=new Map;for(let l of t)l.hash&&l.url?i.set(l.hash,l.url):l.uuid&&l.url&&i.set(l.uuid,l.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,o=[],a=0,r;for(;(r=n.exec(e))!==null;){let l=e.slice(a,r.index);l&&o.push({type:"text",text:l});let d=r[2];i.has(d)?o.push({type:"image",image:new URL(i.get(d))}):o.push({type:"text",text:r[0]}),a=r.index+r[0].length}let s=e.slice(a);return s&&o.push({type:"text",text:s}),o.length===0&&o.push({type:"text",text:e}),o}function fh(e){let t=[];for(let i of e){let n=i.content||"",o=i.images||[],a=gh(n,o);t.length>0&&a.length>0&&t.push({type:"text",text:`
18
16
 
19
- `}),t.push(...o)}return t}function nn(e,t=cs){if(t){let i=ih(e);if(i.length===0)return[];let n={type:"text",text:`
17
+ `}),t.push(...a)}return t}function sn(e,t=bs){if(t){let i=fh(e);if(i.length===0)return[];let n={type:"text",text:`
20
18
 
21
19
  <retrieved_knowledge>
22
20
 
23
21
  Below are expert curated knowledge that are retrieved from the knowledge base; APPLY THESE KNOWLEDGES IF THEY ARE RELEVANT TO THE TASK:
24
- `},a={type:"text",text:`
22
+ `},o={type:"text",text:`
25
23
 
26
24
  </retrieved_knowledge>
27
25
 
28
- `};return[n,...i,a]}else{let i=e.filter(n=>!n.images||n.images.length===0).map(n=>n.content||"").filter(n=>n.length>0).join(`
26
+ `};return[n,...i,o]}else{let i=e.filter(n=>!n.images||n.images.length===0).map(n=>n.content||"").filter(n=>n.length>0).join(`
29
27
 
30
28
  `);return i?[{type:"text",text:`
31
29
 
@@ -36,7 +34,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
36
34
 
37
35
  </retrieved_knowledge>
38
36
 
39
- `}]:[]}}function ds(e,t=cs){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var cs,Lt=b(()=>{"use strict";cs=!1});function nh(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,a=t.find(c=>c.type==="day").value,o=t.find(c=>c.type==="hour").value,r=t.find(c=>c.type==="minute").value,s=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${a} ${o}:${r}:${s}.${d} ${l}`}function us(e){return`# Your Role
37
+ `}]:[]}}function ys(e,t=bs){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var bs,Nt=y(()=>{"use strict";bs=!1});function wh(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(c=>c.type==="year").value,n=t.find(c=>c.type==="month").value,o=t.find(c=>c.type==="day").value,a=t.find(c=>c.type==="hour").value,r=t.find(c=>c.type==="minute").value,s=t.find(c=>c.type==="second").value,l=t.find(c=>c.type==="timeZoneName").value,d=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${o} ${a}:${r}:${s}.${d} ${l}`}function xs(e){return`# Your Role
40
38
  You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
41
39
 
42
40
  # Rules
@@ -96,11 +94,11 @@ Example of empty action when the target element is not on the page, or the instr
96
94
  "action": {}, // empty action object to indicate the instruction cannot be completed
97
95
  "completes_instruction": false
98
96
  }
99
- `}function ah(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
97
+ `}function bh(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],o)=>{t+=`(${o+1}) Description: ${i}
100
98
  Feedback: ${n}
101
99
  `}),`## Additional context
102
100
  You just executed following steps in order:
103
- ${t}`}function hs(e,t,i,n,a,o,r=!1,s=nh(),l=!1,d){let c=[],u=`
101
+ ${t}`}function vs(e,t,i,n,o,a,r=!1,s=wh(),l=!1,d){let c=[],u=`
104
102
  # Instruction
105
103
  "${t}"
106
104
 
@@ -120,9 +118,9 @@ ${e.tabsText}
120
118
 
121
119
  ## Interactive elements from current page:
122
120
  ${e.elementsText}
123
- `;if(c.push({type:"text",text:u}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else o&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:o}));if(a&&a.length>0){let g=nn(a,l);c.push(...g)}let p="";if(p+=`
121
+ `;if(c.push({type:"text",text:u}),r&&e.slicedScreenshotsBase64)for(let g of e.slicedScreenshotsBase64)c.push({type:"text",text:"The following images provided are sliced screenshots of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:g});else a&&(c.push({type:"text",text:"The following image provided is a screenshot of the current webpage, with interactive elements highlighted. The element index label locate at the top right corner of the bounding box."}),c.push({type:"image",image:a}));if(o&&o.length>0){let g=sn(o,l);c.push(...g)}let p="";if(p+=`
124
122
  Current local time is ${s}.
125
- `,i&&Object.keys(i).length>0){let g=[];for(let w of Object.keys(i))if(d?.has(w))g.push(` - ${w}: [SENSITIVE - value hidden]`);else{let k=i[w],y=typeof k=="string"?k:JSON.stringify(k);g.push(` - ${w}: "${y}"`)}p+=`
123
+ `,i&&Object.keys(i).length>0){let g=[];for(let f of Object.keys(i))if(d?.has(f))g.push(` - ${f}: [SENSITIVE - value hidden]`);else{let k=i[f],x=typeof k=="string"?k:JSON.stringify(k);g.push(` - ${f}: "${x}"`)}p+=`
126
124
  ## Available Data Placeholders
127
125
  The following placeholders are available for use in your actions:
128
126
  ${g.join(`
@@ -133,32 +131,32 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
133
131
  - Do NOT use the actual value directly
134
132
  - The values shown are for context only to help you understand what data is available
135
133
  - In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
136
- `}if(n&&n.length>0){let g=ah(n);p+=`
134
+ `}if(n&&n.length>0){let g=bh(n);p+=`
137
135
  `+g}return p+=`
138
136
  Based on the above information, please determine the right action to accomplish the task.
139
- `,c.push({type:"text",text:p}),c}var an=b(()=>{"use strict";Lt()});function on(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 Ot=b(()=>{"use strict"});async function oh(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${o}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let a=n.length>0?n.join(`
137
+ `,c.push({type:"text",text:p}),c}var ln=y(()=>{"use strict";Nt()});function cn(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 Rt=y(()=>{"use strict"});async function yh(e){let t=e.context().pages(),i=null,n=[];for(let a=0;a<t.length;a++){let r=t[a];r===e&&(i=a);let s="(title unavailable)";try{s=await Promise.race([r.title(),new Promise((d,c)=>setTimeout(()=>c(new Error("timeout")),1e3))])}catch{}let l=`Tab ${a}: ${r.url()}`;s&&(l+=` - ${s.slice(0,50)}`),n.push(l)}let o=n.length>0?n.join(`
140
138
  `):"";return{currentTabText:i!==null?`Current tab: ${i}
141
- `:"",tabsText:a}}async function rh(e,t){let{currentTabText:i,tabsText:n}=await oh(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function rn(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),s=a.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=l.elementTree.clickableElementsToString(),p=await rh(i,u);return c&&(p.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var Nt=b(()=>{"use strict"});var se,st,H,Te=b(()=>{"use strict";se=require("zod"),st=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let a=t?.description,o={...t};delete o.description;let r=n.schema.parse(o),s={...i,actionDescription:a};return await n.execute(r,s)}catch(a){if(a instanceof se.z.ZodError){let o=a.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw a}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(a=>i.has(a.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return se.z.object({done:se.z.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof se.z.ZodObject){let l=s._def.shape();s=se.z.object({...l,description:se.z.string().describe("Semantic, human-readable description of the action")})}if(s instanceof se.z.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=se.z.object({_empty:se.z.boolean().optional()}))}return se.z.object({[r.name]:s})});if(i.length===1)return i[0];let[n,a,...o]=i;return se.z.union([n,a,...o])}},H=new st});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 sh(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 lh(e,t=!0){try{let i=sh(e.xpath);if(e.attributes.class&&t){let a=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&a.test(r)&&(i+=`.${r}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(a=>n.add(a));for(let[a,o]of Object.entries(e.attributes)){if(a==="class"||!a.trim()||!n.has(a))continue;let r=a.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let s=o;o.includes(`
142
- `)&&(s=o.split(`
143
- `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function ch(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 lh(e,!1)}function Ba(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=ch(o);h.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function N(e,t){let i=null,n=Ba(t);return t.xpath&&(i=await It(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var K=b(()=>{"use strict";Ke();R()});function dh(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 uh(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 hh(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=uh(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 ms(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,s=a.retrieveKnowledges(e).catch(X=>(f.log(`Failed to retrieve knowledges: ${X.message}`),[])),l=a.isSlicedScreenshotsEnabled(),d=a.isResizeSlicedScreenshotsEnabled(),c=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),p=a.isActionIntentFilteringEnabled(),g=p?dh(e):"all";p&&g!=="all"&&f.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:w,domState:k,pageContext:y}=await rn(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:g});t.domState=k;let m=new en(H).getToolDefinitions().map(X=>{let et=X.function;return`${et.name}: ${et.description}
139
+ `:"",tabsText:o}}async function xh(e,t){let{currentTabText:i,tabsText:n}=await yh(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function dn(e,t){let{page:i,domService:n,agentServices:o}=e,a=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=o.getInteractiveClassNames(),s=o.getIframeFallbackDomains(),{domState:l,screenshotBase64:d,slicedScreenshotsBase64:c}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:s,useCleanScreenshot:a.useCleanScreenshot,useSlicedScreenshots:a.useSlicedScreenshots,resizeSlicedScreenshots:a.resizeSlicedScreenshots,useAccessibilityTree:a.useAccessibilityTree,actionIntent:a.actionIntent}),u=l.elementTree.clickableElementsToString(),p=await xh(i,u);return c&&(p.slicedScreenshotsBase64=c),{domTree:u,screenshotBase64:d,slicedScreenshotsBase64:c,domState:l,pageContext:p}}var Ft=y(()=>{"use strict"});var ae,lt,H,Te=y(()=>{"use strict";ae=require("zod"),lt=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let o=t?.description,a={...t};delete a.description;let r=n.schema.parse(a),s={...i,actionDescription:o};return await n.execute(r,s)}catch(o){if(o instanceof ae.z.ZodError){let a=o.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${a}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${a}`}}}throw o}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(o=>i.has(o.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return ae.z.object({done:ae.z.any()});let i=e.map(r=>{let s=r.schema;if(t&&s instanceof ae.z.ZodObject){let l=s._def.shape();s=ae.z.object({...l,description:ae.z.string().describe("Semantic, human-readable description of the action")})}if(s instanceof ae.z.ZodObject){let l=s._def.shape();Object.keys(l).length===0&&(s=ae.z.object({_empty:ae.z.boolean().optional()}))}return ae.z.object({[r.name]:s})});if(i.length===1)return i[0];let[n,o,...a]=i;return ae.z.union([n,o,...a])}},H=new lt});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 vh(e){let t=e.split("/").filter(o=>o);if(t.length===0)return"*";let i=t[t.length-1],n=i.match(/^(\w+)(?:\[(\d+)\])?$/);if(n){let[,o,a]=n;return a?`${o}:nth-of-type(${a})`:o}return i}function kh(e,t=!0){try{let i=vh(e.xpath);if(e.attributes.class&&t){let o=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,a=e.attributes.class.split(/\s+/);for(let r of a)r.trim()&&o.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(o=>n.add(o));for(let[o,a]of Object.entries(e.attributes)){if(o==="class"||!o.trim()||!n.has(o))continue;let r=o.replace(/:/g,"\\:");if(a==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(a)){let s=a;a.includes(`
140
+ `)&&(s=a.split(`
141
+ `)[0]),s=s.replace(/\s+/g," ").trim();let l=s.replace(/"/g,'\\"');i+=`[${r}*="${l}"]`}else i+=`[${r}="${a}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function _h(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 kh(e,!1)}function zo(e){let t=[],i=e;for(;i&&i.parent!==null;){let a=i.parent;t.push(a),i=a}t.reverse();let n=[],o=t.filter(a=>a.tagName==="iframe");for(let a of o){let r=_h(a);h.debug("[frame-path] iframe attrs:",JSON.stringify(a.attributes),"\u2192",r),n.push(r)}return n}async function N(e,t){let i=null,n=zo(t);return t.xpath&&(i=await It(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var j=y(()=>{"use strict";Ke();R()});function Sh(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 Eh(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 Th(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=Eh(n);if(o)return{type:"image",file:o};let a=typeof n=="string"?n:"";return{type:"image",file:a.startsWith("data:")?a:`data:image/png;base64,${a}`}}return{type:"text",text:i.text}}):t.content}))}async function ks(e,t,i={}){let{page:n,agentServices:o}=t,a=o.getModel(),r=i.temperature??0,s=o.retrieveKnowledges(e).catch(X=>(w.log(`Failed to retrieve knowledges: ${X.message}`),[])),l=o.isSlicedScreenshotsEnabled(),d=o.isResizeSlicedScreenshotsEnabled(),c=o.isKnowledgeImagesEnabled(),u=o.isAccessibilityTreeEnabled(),p=o.isActionIntentFilteringEnabled(),g=p?Sh(e):"all";p&&g!=="all"&&w.log(`Action intent filtering: detected '${g}' intent from statement`);let{screenshotBase64:f,domState:k,pageContext:x}=await dn(t,{useSlicedScreenshots:l,resizeSlicedScreenshots:d,useAccessibilityTree:u,actionIntent:g});t.domState=k;let m=new an(H).getToolDefinitions().map(X=>{let et=X.function;return`${et.name}: ${et.description}
144
142
  Parameters: ${JSON.stringify(et.parameters,null,2)}`}).join(`
145
143
 
146
- `),x=us(m),T=await s,v=hs(y,e,t.variables,t.executionHistory,T.length>0?T:void 0,w,l,void 0,c,t.sensitiveKeys),E=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?E.push({role:"user",content:X.content}):X.role==="assistant"&&E.push({role:"assistant",content:X.content})}),E.push({role:"user",content:v});let A=hh(E),C=H.buildActionUnionSchema(),I=Rt.z.object({thought:Rt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Rt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:C,completes_instruction:Rt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),L=Array.isArray(v)?v.filter(X=>X.type==="image").length:0,V=ye(o,L),ee=await(0,sn.generateText)({model:be(o),system:x,messages:E,temperature:r,output:sn.Output.object({schema:I}),providerOptions:V}),_e=ee.reasoningText;h.info(`Action Generation Reasoning: ${_e}`);let z=ee.output,Y=JSON.stringify(z,null,2);h.info(`Generate Action Raw Output: ${Y}`);let Se=[],Ge=on(ee.usage,o);Ge&&Se.push(Ge);let $e={systemPrompt:x,userPrompt:A,rawLlmResponse:Y,tokenUsages:Se},Pe=z.thought||"",De=z.description||"",U=z.action||{},J=z.completes_instruction||!1;if(!U||Object.keys(U).length===0)return{status:"error",reasoning:Pe||De||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:$e};let q=Object.keys(U)[0];if(q==="done")return{status:"error",reasoning:Pe||De||"Task marked as done",goalAccomplished:J,error:"Agent indicated task is done without generating an action",debugInfo:$e};if(q==="perform_accurate_operation")return await ot(e,t,i);if(!J){let X="Can't complete the instruction in one action";return{status:"error",reasoning:Pe||De||X,goalAccomplished:!1,error:X,debugInfo:$e}}let he=U[q]||{},Er={};if(typeof he.element_index=="number"){let X=he.element_index;if(X<0)return{status:"error",reasoning:Pe||De||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:$e};let et=k.selectorMap.get(X);et&&(Er=await N(n,et))}let Tr=De;return q==="verify"&&(Tr=e,he.statement=e),{status:"success",actionEntity:{...Er,action_description:Tr||Pe||`${q}(${JSON.stringify(he)})`,action_data:{action_name:q,kwargs:he}},reasoning:Pe||De,goalAccomplished:J,debugInfo:$e}}var sn,Rt,ln=b(()=>{"use strict";rt();tn();an();Ot();Nt();Te();ne();Ee();K();R();sn=require("ai"),Rt=require("zod")});function mh(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 Ga(e,t,i={}){return i.usePureVision?ot(e,t,i):ms(e,t,i)}function gh(){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 fh(){return`# Role
144
+ `),b=xs(m),_=await s,v=vs(x,e,t.variables,t.executionHistory,_.length>0?_:void 0,f,l,void 0,c,t.sensitiveKeys),S=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(X=>{X.role==="user"?S.push({role:"user",content:X.content}):X.role==="assistant"&&S.push({role:"assistant",content:X.content})}),S.push({role:"user",content:v});let A=Th(S),I=H.buildActionUnionSchema(),C=Ht.z.object({thought:Ht.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:Ht.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:I,completes_instruction:Ht.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),D=Array.isArray(v)?v.filter(X=>X.type==="image").length:0,K=be(a,D),Q=await(0,un.generateText)({model:we(a),system:b,messages:S,temperature:r,output:un.Output.object({schema:C}),providerOptions:K}),ke=Q.reasoningText;h.info(`Action Generation Reasoning: ${ke}`);let V=Q.output,Y=JSON.stringify(V,null,2);h.info(`Generate Action Raw Output: ${Y}`);let _e=[],Ue=cn(Q.usage,a);Ue&&_e.push(Ue);let Pe={systemPrompt:b,userPrompt:A,rawLlmResponse:Y,tokenUsages:_e},$e=V.thought||"",De=V.description||"",G=V.action||{},J=V.completes_instruction||!1;if(!G||Object.keys(G).length===0)return{status:"error",reasoning:$e||De||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Pe};let q=Object.keys(G)[0];if(q==="done")return{status:"error",reasoning:$e||De||"Task marked as done",goalAccomplished:J,error:"Agent indicated task is done without generating an action",debugInfo:Pe};if(q==="perform_accurate_operation")return await rt(e,t,i);if(!J){let X="Can't complete the instruction in one action";return{status:"error",reasoning:$e||De||X,goalAccomplished:!1,error:X,debugInfo:Pe}}let de=G[q]||{},Pr={};if(typeof de.element_index=="number"){let X=de.element_index;if(X<0)return{status:"error",reasoning:$e||De||"No action generated",goalAccomplished:J,error:"Agent did not generate any action",debugInfo:Pe};let et=k.selectorMap.get(X);et&&(Pr=await N(n,et))}let $r=De;return q==="verify"&&($r=e,de.statement=e),{status:"success",actionEntity:{...Pr,action_description:$r||$e||`${q}(${JSON.stringify(de)})`,action_data:{action_name:q,kwargs:de}},reasoning:$e||De,goalAccomplished:J,debugInfo:Pe}}var un,Ht,hn=y(()=>{"use strict";st();rn();ln();Rt();Ft();Te();ie();Ee();j();R();un=require("ai"),Ht=require("zod")});function Ah(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 Vo(e,t,i={}){return i.usePureVision?rt(e,t,i):ks(e,t,i)}function Ch(){let e=new Date,t=e.toLocaleDateString("en-US",{weekday:"long",year:"numeric",month:"long",day:"numeric",timeZone:"America/Los_Angeles"}),i=e.toLocaleTimeString("en-US",{hour:"2-digit",minute:"2-digit",second:"2-digit",fractionalSecondDigits:3,timeZoneName:"short",timeZone:"America/Los_Angeles"});return{dateString:t,timeString:i}}function Ih(){return`# Role
147
145
  You are an experienced QA person for web applications.
148
146
  You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
149
- `}async function ps(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:p,domState:g,pageContext:w}=await rn(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let k="";a&&a.length>0&&(k=`
147
+ `}async function _s(e,t,i={}){let{page:n,executionHistory:o}=t,a=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),s=t.agentServices.isResizeSlicedScreenshotsEnabled(),l=t.agentServices.isKnowledgeImagesEnabled(),d=t.agentServices.isAccessibilityTreeEnabled(),{domTree:c,screenshotBase64:u,slicedScreenshotsBase64:p,domState:g,pageContext:f}=await dn(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:s,useAccessibilityTree:d});t.domState=g;let k="";o&&o.length>0&&(k=`
150
148
  # Previous actions in this session:
151
- ${a.map(([U,J],q)=>`${q+1}. Action: ${U}
149
+ ${o.map(([G,J],q)=>`${q+1}. Action: ${G}
152
150
  Result: ${J}`).join(`
153
151
  `)}
154
- `);let{dateString:y,timeString:m}=gh(),x=`
152
+ `);let{dateString:x,timeString:m}=Ch(),b=`
155
153
  # User statement
156
154
  "${e}"
157
155
 
158
156
  # Current webpage state
159
157
  ## Tab information:
160
- ${w.currentTabText}Available tabs:
161
- ${w.tabsText}
158
+ ${f.currentTabText}Available tabs:
159
+ ${f.tabsText}
162
160
 
163
161
  ## Element interaction guidelines:
164
162
  - Each element has a unique index number (e.g., "[33]<button>")
@@ -170,22 +168,22 @@ ${c}
170
168
 
171
169
  ## Screenshot
172
170
  ${r&&p?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
173
- `,T="";if(t.variables&&Object.keys(t.variables).length>0){let U=[];for(let J of Object.keys(t.variables))if(!t.sensitiveKeys?.has(J)){let q=t.variables[J],he=typeof q=="string"?q:JSON.stringify(q);U.push(` - ${J}: "${he}"`)}U.length>0&&(T=`
171
+ `,_="";if(t.variables&&Object.keys(t.variables).length>0){let G=[];for(let J of Object.keys(t.variables))if(!t.sensitiveKeys?.has(J)){let q=t.variables[J],de=typeof q=="string"?q:JSON.stringify(q);G.push(` - ${J}: "${de}"`)}G.length>0&&(_=`
174
172
  ## Available Variables
175
173
  The following non-sensitive variables are available:
176
- ${U.join(`
174
+ ${G.join(`
177
175
  `)}`)}let v=`
178
- ${T}
176
+ ${_}
179
177
  ${k}
180
178
 
181
- Today is ${y}. Current local time is ${m}.
179
+ Today is ${x}. Current local time is ${m}.
182
180
  Based on the above information, please determine if the statement is true.
183
- `,E=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:x}],C=0;if(r&&p&&p.length>0)for(let U of p)A.push({type:"image",image:U}),C++;else A.push({type:"image",image:u}),C=1;if(E&&E.length>0){let U=nn(E,l);A.push(...U)}A.push({type:"text",text:v});let I=E?ds(E,l):0,L=C+I,V=ye(o,L),ee=fh(),_e=await(0,cn.generateText)({model:be(o),system:ee,messages:[{role:"user",content:A}],output:cn.Output.object({schema:ph}),temperature:0,providerOptions:V}),{conclusion:z,explanation:Y}=_e.output,Se=JSON.stringify(_e.output,null,2),Ge=[],$e=on(_e.usage,o);$e&&Ge.push($e);let Pe=[{role:"user",content:A.map(U=>{if(U.type==="text")return{type:"text",text:U.text};if(U.type==="image"){let J=U.image,q=mh(J);if(q)return{type:"image",file:q};let he=typeof J=="string"?J:"";return{type:"image",file:he.startsWith("data:")?he:`data:image/png;base64,${he}`}}return{type:"text",text:"[unknown content type]"}})}],De={systemPrompt:ee,userPrompt:Pe,rawLlmResponse:Se,screenshotWithSom:u,tokenUsages:Ge,retrievedKnowledges:E&&E.length>0?E:void 0,elementTree:c};return{success:z==="true",explanation:Y,debugInfo:De}}catch(r){return{success:!1,error:r.message}}}var cn,Ft,ph,dn=b(()=>{"use strict";ln();rt();Ot();Nt();Lt();Ee();cn=require("ai"),Ft=require("zod");ph=Ft.z.object({screenshotDescription:Ft.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
181
+ `,S=await t.agentServices.retrieveKnowledges(e),A=[{type:"text",text:b}],I=0;if(r&&p&&p.length>0)for(let G of p)A.push({type:"image",image:G}),I++;else A.push({type:"image",image:u}),I=1;if(S&&S.length>0){let G=sn(S,l);A.push(...G)}A.push({type:"text",text:v});let C=S?ys(S,l):0,D=I+C,K=be(a,D),Q=Ih(),ke=await(0,mn.generateText)({model:we(a),system:Q,messages:[{role:"user",content:A}],output:mn.Output.object({schema:Mh}),temperature:0,providerOptions:K}),{conclusion:V,explanation:Y}=ke.output,_e=JSON.stringify(ke.output,null,2),Ue=[],Pe=cn(ke.usage,a);Pe&&Ue.push(Pe);let $e=[{role:"user",content:A.map(G=>{if(G.type==="text")return{type:"text",text:G.text};if(G.type==="image"){let J=G.image,q=Ah(J);if(q)return{type:"image",file:q};let de=typeof J=="string"?J:"";return{type:"image",file:de.startsWith("data:")?de:`data:image/png;base64,${de}`}}return{type:"text",text:"[unknown content type]"}})}],De={systemPrompt:Q,userPrompt:$e,rawLlmResponse:_e,screenshotWithSom:u,tokenUsages:Ue,retrievedKnowledges:S&&S.length>0?S:void 0,elementTree:c};return{success:V==="true",explanation:Y,debugInfo:De}}catch(r){return{success:!1,error:r.message}}}var mn,Wt,Mh,pn=y(()=>{"use strict";hn();st();Rt();Ft();Nt();Ee();mn=require("ai"),Wt=require("zod");Mh=Wt.z.object({screenshotDescription:Wt.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
184
182
  and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
185
183
  [45] A modal dialog titled "Confirmation",
186
- in the center of the screen`),explanation:Ft.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Ft.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function fs(){let{default:e}=await import("sharp");return e}async function Ua(e,t){let i=await fs(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,s=0,l=Math.floor((a-r)/2),d=Math.max(0,a-r),c=(w,k)=>{let y=i(e).extract({left:w,top:0,width:k,height:r});return t?.resize&&(y=y.resize(gs,gs)),y.png().toBuffer()},[u,p,g]=await Promise.all([c(s,Math.min(r,a)),c(l,Math.min(r,a-l)),c(d,Math.min(r,a-d))]);return[u,p,g]}async function ws(e){let t=(await fs())(e),i=await t.metadata(),n=i.width||0,a=i.height||0;if(n===0||a===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<a;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=o[s*n+l]}return{pixels:r,width:n,height:a}}var gs,Ht=b(()=>{"use strict";gs=768});function bs(e){return e?Wt.has(e):!1}function ys(e){return lt.has(e)}function xs(e){return e.filter(t=>lt.has(t.type))}var Wt,lt,un,hn,Bt=b(()=>{"use strict";Wt=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),lt=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),un=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],hn=500});function vs(e,t){return e.length>t?e.slice(0,t)+"...":e}var Gt=b(()=>{"use strict"});var ks,_s,Ut=b(()=>{"use strict";ks=["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"],_s={"react-flow__(\\S+)":"$1"}});var Ss,Kt,xe,ct=b(()=>{"use strict";Gt();Ut();Ss=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},Kt=class extends Ss{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}},xe=class mn extends Ss{constructor(t,i,n,a,o,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,p=null,g=null,w=null,k=null,y=[],m=null){super(o,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=w,this.viewportInfo=k,this.isNew=null,this.shadowHostXPaths=y}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof mn&&a!==this&&a.highlightIndex!==null)){if(a instanceof Kt)i.push(a.text);else if(a instanceof mn)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
187
- `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??ks,n=t?.includeClassesWithRename??_s,a=[],o=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof mn){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let v of Object.keys(r.attributes))if(i.includes(v)){let E=r.attributes[v].trim();E!==""&&(m[v]=E)}let x=i.filter(v=>v in m);if(x.length>1){let v=new Set,E={};for(let A of x){let C=m[A];C.length>5&&(C in E?v.add(A):E[C]=A)}for(let A of v)delete m[A]}r.tagName===m.role&&delete m.role;let T=["aria-label","placeholder","title"];for(let v of T)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(u=Object.entries(m).map(([v,E])=>`${v}=${vs(E,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let x of m)for(let[T,v]of Object.entries(n))try{let E=new RegExp(`^${T}$`);if(x.match(E)){let A=x.replace(E,v);A&&g.push(A);break}}catch{continue}}let w=r.isScrollable?" (SCROLLABLE)":"",k=r.markAsClickable?" (CLICKABLE)":"",y=`${d}${p}${w}${k}<${r.tagName}`;if(g.length>0&&(y+=` ${g.join(" ")}`),u&&(y+=` ${u}`),c){let m=c.trim();u||(y+=" "),y+=`>${m}`}else u||(y+=" ");y+=" />",a.push(y)}else{let c=["data-testid","data-test-id"].filter(u=>r.attributes[u]);c.length>0&&(l+=1,a.push(`${d}<${r.tagName} ${c.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let c of r.children)o(c,l)}else if(r instanceof Kt){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${d}${r.text}`)}};return o(this,0),a.join(`
188
- `)}}});function yh(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var wh,bh,me,je=b(()=>{"use strict";Ht();Bt();ct();R();wh=`(
184
+ in the center of the screen`),explanation:Wt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:Wt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function Es(){let{default:e}=await import("sharp");return e}async function Xo(e,t){let i=await Es(),n=await i(e).metadata(),o=n.width||0,a=n.height||0;if(o===0||a===0)throw new Error("Invalid image dimensions");let r=a,s=0,l=Math.floor((o-r)/2),d=Math.max(0,o-r),c=(f,k)=>{let x=i(e).extract({left:f,top:0,width:k,height:r});return t?.resize&&(x=x.resize(Ss,Ss)),x.png().toBuffer()},[u,p,g]=await Promise.all([c(s,Math.min(r,o)),c(l,Math.min(r,o-l)),c(d,Math.min(r,o-d))]);return[u,p,g]}async function Ts(e){let t=(await Es())(e),i=await t.metadata(),n=i.width||0,o=i.height||0;if(n===0||o===0)throw new Error("Invalid image dimensions");let{data:a}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let s=0;s<o;s++){r[s]=[];for(let l=0;l<n;l++)r[s][l]=a[s*n+l]}return{pixels:r,width:n,height:o}}var Ss,Bt=y(()=>{"use strict";Ss=768});function As(e){return e?Ut.has(e):!1}function Ms(e){return ct.has(e)}function Cs(e){return e.filter(t=>ct.has(t.type))}var Ut,ct,gn,fn,Gt=y(()=>{"use strict";Ut=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),ct=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),gn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],fn=500});function Is(e,t){return e.length>t?e.slice(0,t)+"...":e}var Kt=y(()=>{"use strict"});var Ps,$s,jt=y(()=>{"use strict";Ps=["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"],$s={"react-flow__(\\S+)":"$1"}});var Ds,zt,ye,dt=y(()=>{"use strict";Kt();jt();Ds=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},zt=class extends Ds{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}},ye=class wn extends Ds{constructor(t,i,n,o,a,r=!1,s=!1,l=!1,d=!1,c=!1,u=!1,p=null,g=null,f=null,k=null,x=[],m=null){super(a,m),this.tagName=t,this.xpath=i,this.attributes=n,this.children=o,this.isInteractive=r,this.isScrollable=s,this.markAsClickable=l,this.isTopElement=d,this.isInViewport=c,this.shadowRoot=u,this.highlightIndex=p,this.viewportCoordinates=g,this.pageCoordinates=f,this.viewportInfo=k,this.isNew=null,this.shadowHostXPaths=x}getAllTextTillNextClickableElement(t=-1){let i=[],n=(o,a)=>{if(!(t!==-1&&a>t)&&!(o instanceof wn&&o!==this&&o.highlightIndex!==null)){if(o instanceof zt)i.push(o.text);else if(o instanceof wn)for(let r of o.children)n(r,a+1)}};return n(this,0),i.join(`
185
+ `).trim()}clickableElementsToString(t){let i=t?.includeAttributes??Ps,n=t?.includeClassesWithRename??$s,o=[],a=(r,s)=>{let l=s,d=" ".repeat(s);if(r instanceof wn){if(r.highlightIndex!==null){l+=1;let c=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let m={};for(let v of Object.keys(r.attributes))if(i.includes(v)){let S=r.attributes[v].trim();S!==""&&(m[v]=S)}let b=i.filter(v=>v in m);if(b.length>1){let v=new Set,S={};for(let A of b){let I=m[A];I.length>5&&(I in S?v.add(A):S[I]=A)}for(let A of v)delete m[A]}r.tagName===m.role&&delete m.role;let _=["aria-label","placeholder","title"];for(let v of _)m[v]&&m[v].trim().toLowerCase()===c.trim().toLowerCase()&&delete m[v];Object.keys(m).length>0&&(u=Object.entries(m).map(([v,S])=>`${v}=${Is(S,200)}`).join(" "))}let p=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,g=[];if(Object.keys(n).length>0&&r.attributes.class){let m=r.attributes.class.split(/\s+/);for(let b of m)for(let[_,v]of Object.entries(n))try{let S=new RegExp(`^${_}$`);if(b.match(S)){let A=b.replace(S,v);A&&g.push(A);break}}catch{continue}}let f=r.isScrollable?" (SCROLLABLE)":"",k=r.markAsClickable?" (CLICKABLE)":"",x=`${d}${p}${f}${k}<${r.tagName}`;if(g.length>0&&(x+=` ${g.join(" ")}`),u&&(x+=` ${u}`),c){let m=c.trim();u||(x+=" "),x+=`>${m}`}else u||(x+=" ");x+=" />",o.push(x)}else{let c=["data-testid","data-test-id"].filter(u=>r.attributes[u]);c.length>0&&(l+=1,o.push(`${d}<${r.tagName} ${c.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let c of r.children)a(c,l)}else if(r instanceof zt){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&o.push(`${d}${r.text}`)}};return a(this,0),o.join(`
186
+ `)}}});function Dh(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Ph,$h,ue,je=y(()=>{"use strict";Bt();Gt();dt();R();Ph=`(
189
187
  args = {
190
188
  doHighlightElements: true,
191
189
  focusHighlightIndex: -1,
@@ -1953,7 +1951,7 @@ Based on the above information, please determine if the statement is true.
1953
1951
 
1954
1952
  return { rootId, map: DOM_HASH_MAP };
1955
1953
  }
1956
- `,bh=`((args = {
1954
+ `,$h=`((args = {
1957
1955
  doHighlightElements: true,
1958
1956
  focusHighlightIndex: -1,
1959
1957
  viewportExpansion: 0,
@@ -4001,7 +3999,7 @@ Based on the above information, please determine if the statement is true.
4001
3999
  // Return element data from boxes phase for use in labels phase
4002
4000
  elementData: phase === 'boxes' ? collectedElementData : undefined,
4003
4001
  };
4004
- })`;me=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let a=this.normalizeDomain(n);if(a&&(i===a||i.endsWith(`.${a}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){h.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?bh:wh}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,u]=await this.buildDomTree(e,i,n,a,o,r,s,l,d);return{elementTree:c,selectorMap:u}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let a=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await Ua(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){h.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){h.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:a}=await n.send("Accessibility.getFullAXTree",{depth:-1});h.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(m=>{if(m.ignored)return!1;let x=m.role?.value;return!(!x||!Wt.has(x)||m.properties?.find(T=>T.name==="disabled")?.value?.value||!m.backendDOMNodeId)});h.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(m=>m.role?.value==="button");h.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let x=[];m.ignored&&x.push("ignored"),m.backendDOMNodeId||x.push("no-backendDOMNodeId"),m.properties?.find(T=>T.name==="disabled")?.value?.value&&x.push("disabled"),h.debug(` - "${m.name?.value||"(no name)"}" ${x.length>0?`[SKIPPED: ${x.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(o.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)s.has(m.backendNodeId)||(o.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),d++);h.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${o.length})`);let c=await this.resolveAXNodesToDOM(n,o),u=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){h.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let x=[];m.isVisible||x.push("not-visible"),m.isInViewport||x.push("not-in-viewport"),m.isTopElement||x.push("not-top-element"),m.boundingRect||x.push("no-bounding-rect"),h.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${x.join(", ")}]`)}}h.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:g,highlightIndex:w}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&w>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,w)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let k=i.toString("base64"),y;if(t.useSlicedScreenshots)try{y=(await Ua(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){h.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:k,screenshot:i,slicedScreenshotsBase64:y}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],s=a[o];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4002
+ })`;ue=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let o=this.normalizeDomain(n);if(o&&(i===o||i.endsWith(`.${o}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){h.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?$h:Ph}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:o=0,interactiveClassNames:a=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:s=!1,sameRectIoUThreshold:l,actionIntent:d="all"}=t,[c,u]=await this.buildDomTree(e,i,n,o,a,r,s,l,d);return{elementTree:c,selectorMap:u}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let o=i.toString("base64"),a;if(t.useSlicedScreenshots)try{a=(await Xo(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){h.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:o,screenshot:i,slicedScreenshotsBase64:a}}async getClickableElementsWithAXTree(e,t={}){h.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:o}=await n.send("Accessibility.getFullAXTree",{depth:-1});h.debug(`\u{1F4CA} Got ${o.length} AXNodes from accessibility tree`);let a=o.filter(m=>{if(m.ignored)return!1;let b=m.role?.value;return!(!b||!Ut.has(b)||m.properties?.find(_=>_.name==="disabled")?.value?.value||!m.backendDOMNodeId)});h.debug(`\u2705 Found ${a.length} interactive elements from AXTree`);let r=o.filter(m=>m.role?.value==="button");h.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let m of r){let b=[];m.ignored&&b.push("ignored"),m.backendDOMNodeId||b.push("no-backendDOMNodeId"),m.properties?.find(_=>_.name==="disabled")?.value?.value&&b.push("disabled"),h.debug(` - "${m.name?.value||"(no name)"}" ${b.length>0?`[SKIPPED: ${b.join(", ")}]`:"[INCLUDED]"}`)}let s=new Set(a.map(m=>m.backendDOMNodeId)),l=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),d=0;for(let m of l)s.has(m.backendNodeId)||(a.push({nodeId:`synthetic-${m.backendNodeId}`,ignored:!1,backendDOMNodeId:m.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:m.eventTypes.join(",")}}]}),s.add(m.backendNodeId),d++);h.debug(`\u{1F3AF} Added ${d} elements from event listeners (total: ${a.length})`);let c=await this.resolveAXNodesToDOM(n,a),u=c.filter(m=>m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect),p=c.filter(m=>!(m.isVisible&&m.isInViewport&&m.isTopElement&&m.boundingRect));if(p.length>0){h.debug(`\u{1F6AB} Filtered out ${p.length} elements:`);for(let m of p){let b=[];m.isVisible||b.push("not-visible"),m.isInViewport||b.push("not-in-viewport"),m.isTopElement||b.push("not-top-element"),m.boundingRect||b.push("no-bounding-rect"),h.debug(` - <${m.tagName}> "${m.axNode.name?.value||""}" [${b.join(", ")}]`)}}h.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:g,highlightIndex:f}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&f>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,f)),await e.waitForTimeout(100)),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]);try{await n.detach()}catch{}if(!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let k=i.toString("base64"),x;if(t.useSlicedScreenshots)try{x=(await Xo(i,{resize:t.resizeSlicedScreenshots})).map(m=>m.toString("base64"))}catch(m){h.warn("Failed to slice screenshot:",m)}return{domState:g,screenshotBase64:k,screenshot:i,slicedScreenshotsBase64:x}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(a=>a.backendDOMNodeId).filter(a=>a!==void 0);if(n.length===0)return i;let o=[];for(let a of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:a});o.push(r.objectId||null)}catch{o.push(null)}for(let a=0;a<t.length;a++){let r=t[a],s=o[a];if(s)try{let{result:l}=await e.send("Runtime.callFunctionOn",{objectId:s,functionDeclaration:`function() {
4005
4003
  const el = this;
4006
4004
  const rect = el.getBoundingClientRect();
4007
4005
  const rects = el.getClientRects();
@@ -4085,44 +4083,44 @@ Based on the above information, please determine if the statement is true.
4085
4083
  } : null,
4086
4084
  clientRects: clientRectsArray
4087
4085
  };
4088
- }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=hn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=un.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});h.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>lt.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new xe("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(o),l=new xe(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",s,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let d=new Kt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=a[l%a.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),w=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${w}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let s of o){let l=s.url();try{let d=new URL(l).hostname;d&&d!==a&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(yh(e.url()))return[new xe("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let y={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:y});h.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let x=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let T=performance.now(),v=await ws(x);u=v.pixels;let E=Math.round(performance.now()-T);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${E}ms`);let A={...d,phase:"labels",grayscaleImage:u,elementData:m.elementData};c=await e.evaluate(({code:C,argsObj:I})=>new Function("return "+C)()(I),{code:this.jsCode,argsObj:A}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(y){h.warn("Two-phase rendering failed, falling back to legacy mode:",y.message),u=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:x,argsObj:T})=>new Function("return "+x)()(T),{code:this.jsCode,argsObj:m}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:y,argsObj:m})=>new Function("return "+y)()(m),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(y){throw h.error("Error evaluating JavaScript:",y.message),y}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let y={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:x})=>new Function("return "+m)()(x),{code:this.jsCode,argsObj:y})}let p=Object.entries(c.map).filter(([,y])=>y.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[y,m]of p){let x=m;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${y} src=${x.attributes?.src} inaccessibleFrame=${x.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let y of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${y.url()}`);let w=[];for(let[y,m]of Object.entries(c.map)){let x=m;this.shouldProcessWithPlaywrightFrameFallback(x,o)&&w.push({nodeId:y,src:x.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${w.length}`),w.length>0){h.debug(`\u{1F50C} Found ${w.length} inaccessible iframe(s) for Playwright fallback, processing`);let y=-1;for(let m of Object.values(c.map)){let x=m;x.highlightIndex!=null&&(y=Math.max(y,x.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${y}`);for(let m=0;m<w.length;m++){let{nodeId:x,src:T}=w[m];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${T}`);let v=I=>{try{let L=new URL(I);if(L.protocol==="chrome-extension:"&&L.hostname)return`chrome-extension://${L.hostname}`;let V=L.origin;return V==="null"?null:V}catch{return null}},E=v(T);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${E??"null"}`);let A=null,C=e.frames().find(I=>{let L=I.url();if(L===T)return A="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${L}`),!0;let V=v(L);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${L} origin=${V??"null"} vs srcOrigin=${E??"null"}`),E&&V===E?(A="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${L}`),!0):!1});if(!C){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${T}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(I=>I.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${T} (frame url: ${C.url()})`);try{let I={...d,initialHighlightIndex:y+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${I.initialHighlightIndex}`);let L=await C.evaluate(({code:z,argsObj:Y})=>new Function("return "+z)()(Y),{code:this.jsCode,argsObj:I});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(L?.map??{}).length} rootId=${L?.rootId}`),!L?.map||!L.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let V=Object.values(L.map).filter(z=>z.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${V.length}`);for(let z of V){let Y=z;h.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let z of Object.values(L.map)){let Y=z;Y.highlightIndex!=null&&(y=Math.max(y,Y.highlightIndex))}let ee=`ext_${m}_`;for(let[z,Y]of Object.entries(L.map)){let Se={...Y};Se.children&&(Se.children=Se.children.map(Ge=>`${ee}${Ge}`)),c.map[`${ee}${z}`]=Se}let _e=c.map[x];_e?(_e.children=[..._e.children||[],`${ee}${L.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${x}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${x} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${T}`)}catch(I){h.warn(`Failed to process fallback iframe ${T}:`,I)}}}if(c&&c.perfMetrics){let y=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let T of Object.values(c.map))typeof T=="object"&&T!==null&&T.isInteractive&&m++;let x=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${x} interactive=${m}/${y}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(a.set(s,d),o.set(s,c),d instanceof xe&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of o){let d=a.get(s);if(d instanceof xe)for(let c of l){let u=a.get(c);u&&(u.parent=d,d.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof xe))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 Kt(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 xe(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),a=e.children||[];return[n,a]}}});var Es,pn=b(()=>{"use strict";F();$();Es=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.keys;if(!a||typeof a!="string")throw new Error("Missing or invalid keys for send keys on element action");let o=O(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=Le(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 Ts,As,Sf,gn=b(()=>{"use strict";Ts=require("zod"),As=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Sf=Ts.z.object({})});var Ms,fn=b(()=>{"use strict";F();$();Ms=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Is,wn=b(()=>{"use strict";Is=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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
+ }`,returnByValue:!0});l.value&&i.push({axNode:r,...l.value})}catch(l){h.debug(`Failed to resolve element: ${l}`)}}return i}async getElementsWithEventListeners(e,t=fn){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),o=gn.join(","),{nodeIds:a}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:o});h.debug(`\u{1F50D} Checking ${Math.min(a.length,t)} elements for event listeners`);for(let r of a.slice(0,t))try{let{object:s}=await e.send("DOM.resolveNode",{nodeId:r});if(!s.objectId)continue;let{listeners:l}=await e.send("DOMDebugger.getEventListeners",{objectId:s.objectId}),d=l.filter(c=>ct.has(c.type));if(d.length>0){let{node:c}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:c.backendNodeId,eventTypes:d.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:s.objectId})}catch{}h.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){h.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new ye("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let o of e){let a=o.axNode.role?.value||"",r=o.axNode.name?.value||"",s=["button","link","menuitem","tab","switch"].includes(a),l=new ye(o.tagName,o.xpath,o.attributes,[],o.isVisible,!0,a==="scrollbar",s,o.isTopElement,o.isInViewport,!1,n,o.boundingRect?{topLeft:{x:o.boundingRect.x,y:o.boundingRect.y},topRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y},bottomLeft:{x:o.boundingRect.x,y:o.boundingRect.y+o.boundingRect.height},bottomRight:{x:o.boundingRect.x+o.boundingRect.width,y:o.boundingRect.y+o.boundingRect.height},center:{x:o.boundingRect.x+o.boundingRect.width/2,y:o.boundingRect.y+o.boundingRect.height/2},width:o.boundingRect.width,height:o.boundingRect.height}:null,null,null,[],i);if(r){let d=new zt(r,!0,l);l.children.push(d)}i.children.push(l),t.set(n,l),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:o})=>{let a="playwright-highlight-container",r=document.getElementById(a);r||(r=document.createElement("div"),r.id=a,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((s,l)=>{if(!s.boundingRect)return;let d=o[l%o.length],c=s.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${d}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${c.y}px`,u.style.left=`${c.x}px`,u.style.width=`${c.width}px`,u.style.height=`${c.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=d,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=l>=100?"8px":"12px",p.textContent=String(l);let g=Math.max(0,c.y-16),f=Math.max(0,Math.min(c.x+c.width-20,window.innerWidth-25));p.style.top=`${g}px`,p.style.left=`${f}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(o=>o()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),h.debug("\u2705 Highlights removed from page")}catch(n){h.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let o=n.url();if(!(!o.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(o,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(s=>s.map(l=>l.src)),i=s=>{try{let l=new URL(s);return["doubleclick.net","adroll.com","googletagmanager.com"].some(d=>l.hostname.includes(d))}catch{return!1}},n=e.url(),o=new URL(n).hostname,a=e.frames(),r=[];for(let s of a){let l=s.url();try{let d=new URL(l).hostname;d&&d!==o&&!t.includes(l)&&!i(l)&&r.push(l)}catch{continue}}return r}async buildDomTree(e,t,i,n,o,a,r,s,l="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Dh(e.url()))return[new ye("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let d={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:o,alwaysHighlightFileInput:r,sameRectIoUThreshold:s,actionIntent:l,domTreeRoot:this.domTreeRoot};h.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let c,u=null;if(this.useDomTreeTs&&t)try{let x={...d,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:I,argsObj:C})=>new Function("return "+I)()(C),{code:this.jsCode,argsObj:x});h.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let b=await e.screenshot({type:"png",fullPage:!1});h.debug("\u{1F4F8} Captured screenshot with bounding boxes");let _=performance.now(),v=await Ts(b);u=v.pixels;let S=Math.round(performance.now()-_);h.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${v.width}x${v.height}) in ${S}ms`);let A={...d,phase:"labels",grayscaleImage:u,elementData:m.elementData};c=await e.evaluate(({code:I,argsObj:C})=>new Function("return "+I)()(C),{code:this.jsCode,argsObj:A}),c.map=m.map,c.rootId=m.rootId,c.highlightCount=m.highlightCount,c.perfMetrics=m.perfMetrics,h.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(x){h.warn("Two-phase rendering failed, falling back to legacy mode:",x.message),u=null;let m={...d,grayscaleImage:null};c=await e.evaluate(({code:b,argsObj:_})=>new Function("return "+b)()(_),{code:this.jsCode,argsObj:m}),h.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{c=await e.evaluate(({code:x,argsObj:m})=>new Function("return "+x)()(m),{code:this.jsCode,argsObj:d}),h.debug("\u2705 JavaScript DOM analysis completed")}catch(x){throw h.error("Error evaluating JavaScript:",x.message),x}if(!c||typeof c!="object")throw h.error("JavaScript returned invalid result:",c),new Error("JavaScript DOM analysis returned invalid result");if(!c.map||!c.rootId)throw h.error("JavaScript result missing map or rootId:",JSON.stringify(c,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(l!=="all"&&c.highlightCount===0){h.debug(`\u26A0\uFE0F No elements matched intent '${l}', falling back to 'all'`);let x={...d,actionIntent:"all"};c=await e.evaluate(({code:m,argsObj:b})=>new Function("return "+m)()(b),{code:this.jsCode,argsObj:x})}let p=Object.entries(c.map).filter(([,x])=>x.tagName==="iframe");h.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[x,m]of p){let b=m;h.debug(`\u{1F50D} [ext-iframe] iframe node id=${x} src=${b.attributes?.src} inaccessibleFrame=${b.inaccessibleFrame}`)}let g=e.frames();h.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${g.length}`);for(let x of g)h.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${x.url()}`);let f=[];for(let[x,m]of Object.entries(c.map)){let b=m;this.shouldProcessWithPlaywrightFrameFallback(b,a)&&f.push({nodeId:x,src:b.attributes.src})}if(h.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${f.length}`),f.length>0){h.debug(`\u{1F50C} Found ${f.length} inaccessible iframe(s) for Playwright fallback, processing`);let x=-1;for(let m of Object.values(c.map)){let b=m;b.highlightIndex!=null&&(x=Math.max(x,b.highlightIndex))}h.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${x}`);for(let m=0;m<f.length;m++){let{nodeId:b,src:_}=f[m];h.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${_}`);let v=C=>{try{let D=new URL(C);if(D.protocol==="chrome-extension:"&&D.hostname)return`chrome-extension://${D.hostname}`;let K=D.origin;return K==="null"?null:K}catch{return null}},S=v(_);h.debug(`\u{1F50D} [ext-iframe] iframe src origin=${S??"null"}`);let A=null,I=e.frames().find(C=>{let D=C.url();if(D===_)return A="exact",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${D}`),!0;let K=v(D);return h.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${D} origin=${K??"null"} vs srcOrigin=${S??"null"}`),S&&K===S?(A="origin",h.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${D}`),!0):!1});if(!I){h.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${_}`),h.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(C=>C.url()).join(", ")}`);continue}h.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${_} (frame url: ${I.url()})`);try{let C={...d,initialHighlightIndex:x+1,domTreeRoot:"body"};h.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${C.initialHighlightIndex}`);let D=await I.evaluate(({code:V,argsObj:Y})=>new Function("return "+V)()(Y),{code:this.jsCode,argsObj:C});if(h.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(D?.map??{}).length} rootId=${D?.rootId}`),!D?.map||!D.rootId){h.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let K=Object.values(D.map).filter(V=>V.highlightIndex!=null);h.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${K.length}`);for(let V of K){let Y=V;h.debug(`\u{1F50D} [ext-iframe] - <${Y.tagName}> highlightIndex=${Y.highlightIndex} text="${Y.children?.length?"...":""}"`)}for(let V of Object.values(D.map)){let Y=V;Y.highlightIndex!=null&&(x=Math.max(x,Y.highlightIndex))}let Q=`ext_${m}_`;for(let[V,Y]of Object.entries(D.map)){let _e={...Y};_e.children&&(_e.children=_e.children.map(Ue=>`${Q}${Ue}`)),c.map[`${Q}${V}`]=_e}let ke=c.map[b];ke?(ke.children=[...ke.children||[],`${Q}${D.rootId}`],h.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${b}`)):h.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${b} not found in map`),h.debug(`\u2705 Merged fallback iframe content from: ${_}`)}catch(C){h.warn(`Failed to process fallback iframe ${_}:`,C)}}}if(c&&c.perfMetrics){let x=c.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(c.map)for(let _ of Object.values(c.map))typeof _=="object"&&_!==null&&_.isInteractive&&m++;let b=e.url().length>50?e.url().slice(0,50)+"...":e.url();h.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${b} interactive=${m}/${x}`)}h.debug("\u{1F504} Starting TypeScript DOM tree construction...");let k=await this.constructDomTree(c);return h.debug("\u2705 TypeScript DOM tree construction completed"),k}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,o=new Map,a=new Map;for(let[s,l]of Object.entries(t)){let[d,c]=this.parseNode(l);d!==null&&(o.set(s,d),a.set(s,c),d instanceof ye&&d.highlightIndex!==null&&n.set(d.highlightIndex,d))}for(let[s,l]of a){let d=o.get(s);if(d instanceof ye)for(let c of l){let u=o.get(c);u&&(u.parent=d,d.children.push(u))}}let r=o.get(i);if(!r||!(r instanceof ye))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 zt(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 ye(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),o=e.children||[];return[n,o]}}});var Ls,bn=y(()=>{"use strict";F();P();Ls=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.keys;if(!o||typeof o!="string")throw new Error("Missing or invalid keys for send keys on element action");let a=O(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a)await a.press(o,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Le(e);if(!t){let o=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(o)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=L();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var Os,Ns,Wf,yn=y(()=>{"use strict";Os=require("zod"),Ns=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Wf=Os.z.object({})});var Rs,xn=y(()=>{"use strict";F();P();Rs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Fs,vn=y(()=>{"use strict";Fs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
4089
4087
  return (async () => {
4090
- ${a}
4088
+ ${o}
4091
4089
  })();
4092
- `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4093
- `):["// Skipping js_action: missing code"]}}});var Ka,Cs,Pf,bn=b(()=>{"use strict";Ka=require("zod"),Cs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.code;if(!a)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
4090
+ `)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
4091
+ `):["// Skipping js_action: missing code"]}}});var Yo,Hs,Xf,kn=y(()=>{"use strict";Yo=require("zod"),Hs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.code;if(!o)throw new Error("Missing code for js_code action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","agent",`
4094
4092
  return (async () => {
4095
- ${a}
4093
+ ${o}
4096
4094
  })();
4097
- `)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4098
- `);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Pf=Ka.z.object({code:Ka.z.string().describe("JavaScript code to execute in the browser context")})});var $s,yn=b(()=>{"use strict";F();$();$s=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=O(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Ps,xn=b(()=>{"use strict";F();$();Ps=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,s=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Ds,vn=b(()=>{"use strict";F();$();Ds=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],s=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:D(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+o.relative_x+d.width/2,u=d.y+o.relative_y+d.height/2,p=c+o.delta_x,g=u+o.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(p,g,{steps:n}):await e.mouse.move(p,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(a=>` ${a},`),"});"]}}});var Ls,kn=b(()=>{"use strict";Ls=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",`
4095
+ `)(e,a)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
4096
+ `);for(let o of n)i.push(` ${o}`);return i.push("}"),i}},Xf=Yo.z.object({code:Yo.z.string().describe("JavaScript code to execute in the browser context")})});var Ws,_n=y(()=>{"use strict";F();P();Ws=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.move(r,s),await e.waitForTimeout(200),await e.mouse.click(r,s),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Bs,Sn=y(()=>{"use strict";F();P();Bs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let o=O(e,t);if(o){await o.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let a=await o.boundingBox();if(a){let r=a.x+n.kwargs.relative_x+a.width/2,s=a.y+n.kwargs.relative_y+a.height/2;await e.mouse.dblclick(r,s,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Us,En=y(()=>{"use strict";F();P();Us=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,o=t.action_data;if(!o)throw new Error("Action data not found");let a=o.kwargs,r=[a.coord_source_x,a.coord_source_y],s=[a.coord_target_x,a.coord_target_y];if(typeof a.relative_x=="number"&&typeof a.relative_y=="number"&&typeof a.delta_x=="number"&&typeof a.delta_y=="number"){let l=O(e,t);if(!l)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await l.waitFor({state:"attached",timeout:L(i,t.action_data?.kwargs?.timeout_ms)});let d=await(await l).boundingBox();if(!d)throw new Error("Could not get bounding box for drag_drop element");let c=d.x+a.relative_x+d.width/2,u=d.y+a.relative_y+d.height/2,p=c+a.delta_x,g=u+a.delta_y;await e.mouse.move(c,u),await e.mouse.down(),n>0?await e.mouse.move(p,g,{steps:n}):await e.mouse.move(p,g),await e.mouse.up()}else if(r.every(l=>typeof l=="number")&&s.every(l=>typeof l=="number")){let[l,d]=r,[c,u]=s;await e.mouse.move(l,d),await e.mouse.down(),n>0?await e.mouse.move(c,u,{steps:n}):await e.mouse.move(c,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(o=>` ${o},`),"});"]}}});var Gs,Tn=y(()=>{"use strict";Gs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.generateFunctionCallCode(n.kwargs);if(!o)throw new Error("Missing function name for function action");let a=i.agent;if(!a)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
4099
4097
  return (async () => {
4100
- ${a}
4098
+ ${o}
4101
4099
  })();
4102
- `)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var _n,Os,Sn=b(()=>{"use strict";ct();_n=require("crypto"),Os=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=a=>{if(a.highlightIndex!==null){let o=this.hashDomElement(a);if(this.compareHashes(o,i))return a}for(let o of a.children)if(o instanceof xe){let r=n(o);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),a=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:a}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return(0,_n.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,_n.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,_n.createHash)("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(a=>a.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var ja,dt=b(()=>{"use strict";ja=(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))(ja||{})});var ut={};Ue(ut,{evaluateStatement:()=>Ve,executeAction:()=>jt,executeStep:()=>ze,generateActionStep:()=>mt,runTask:()=>Xe});var ht=b(()=>{"use strict";zt();dn();ln();rt();Yi();Ji();nt();tn();an();Ot();Nt();Te();Dt();Lt();Sn();je();Ht();Bt();ct();Gt();Ut();ne();Ee();Ct();$t();at();K();Ke();R();ie();dt();F();fe()});var za,Ns,Iw,En=b(()=>{"use strict";za=require("zod"),Ns=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(()=>(ht(),ut)),s=await r(a,e,i,{usePureVision:o});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},Iw=za.z.object({statement:za.z.string().describe('The action to perform (e.g., "click the submit button")')})});var Va,Rs,Pw,Tn=b(()=>{"use strict";Va=require("zod"),Rs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(ht(),ut)),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"]}},Pw=Va.z.object({statement:Va.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function Hs(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:xh,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:l.message}}}}})}var An,Fs,xh,Vt=b(()=>{"use strict";An=require("zod"),Fs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(ht(),ut));for(;Date.now()-s<o;){if((await l(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},xh=An.z.object({condition:An.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:An.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function vh(e,t,i,n){return{...await N(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Ws(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 Gs(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:kh,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Ws(l||`Select option in dropdown ${a}`,{index:a,option:o})};let c=await vh(d,r,o,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${o}" in dropdown ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ws(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Xt,Bs,kh,Yt=b(()=>{"use strict";K();F();Xt=require("zod");$();Bs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=O(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},`),"});"]}};kh=Xt.z.object({element_index:Xt.z.number().int().describe("Index of the dropdown/select element"),option:Xt.z.string().describe("Option value, label, or index to select"),timeout_ms:Xt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function _h(e,t,i,n){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Xa(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 Ks(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4100
+ `)(e,a)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((s,l)=>l<r.length?String(r[l]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],o=["undefined","null","true","false"],a=i.map(r=>n.includes(r)||o.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${a.join(", ")})`}}});var An,Ks,Mn=y(()=>{"use strict";dt();An=require("crypto"),Ks=class{static convertDomElementToHistoryElement(e){let t=this.getParentBranchPath(e),i=this.generateCssSelector(e);return{tagName:e.tagName,xpath:e.xpath,highlightIndex:e.highlightIndex,entireParentBranchPath:t,attributes:e.attributes,shadowRoot:e.shadowRoot,cssSelector:i,pageCoordinates:e.pageCoordinates,viewportCoordinates:e.viewportCoordinates,viewportInfo:e.viewportInfo}}static findHistoryElementInTree(e,t){let i=this.hashDomHistoryElement(e),n=o=>{if(o.highlightIndex!==null){let a=this.hashDomElement(o);if(this.compareHashes(a,i))return o}for(let a of o.children)if(a instanceof ye){let r=n(a);if(r!==null)return r}return null};return n(t)}static compareHistoryElementAndDomElement(e,t){let i=this.hashDomHistoryElement(e),n=this.hashDomElement(t);return this.compareHashes(i,n)}static hashDomHistoryElement(e){let t=this.parentBranchPathHash(e.entireParentBranchPath),i=this.attributesHash(e.attributes),n=this.xpathHash(e.xpath);return{branchPathHash:t,attributesHash:i,xpathHash:n}}static hashDomElement(e){let t=this.getParentBranchPath(e),i=this.parentBranchPathHash(t),n=this.attributesHash(e.attributes),o=this.xpathHash(e.xpath);return{branchPathHash:i,attributesHash:n,xpathHash:o}}static getParentBranchPath(e){let t=[],i=e;for(;i!==null&&i.parent!==null;)t.push(i),i=i.parent;return t.reverse(),t.map(n=>n.tagName)}static parentBranchPathHash(e){let t=e.join("/");return(0,An.createHash)("sha256").update(t).digest("hex")}static attributesHash(e){let t=Object.entries(e).map(([i,n])=>`${i}=${n}`).join("");return(0,An.createHash)("sha256").update(t).digest("hex")}static xpathHash(e){return(0,An.createHash)("sha256").update(e).digest("hex")}static compareHashes(e,t){return e.branchPathHash===t.branchPathHash&&e.attributesHash===t.attributesHash&&e.xpathHash===t.xpathHash}static generateCssSelector(e){let t=e.attributes.id;if(t)return`#${t}`;let i=e.attributes.class;if(i){let n=i.split(/\s+/).filter(o=>o.trim());if(n.length>0)return`${e.tagName}.${n.join(".")}`}return e.tagName}}});var Jo,ut=y(()=>{"use strict";Jo=(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))(Jo||{})});var ht={};Ge(ht,{evaluateStatement:()=>Ve,executeAction:()=>Vt,executeStep:()=>ze,generateActionStep:()=>pt,runTask:()=>Xe});var mt=y(()=>{"use strict";Xt();pn();hn();st();Zi();en();Qi();nt();rn();ln();Rt();Ft();Te();Ot();Nt();Mn();je();Bt();Gt();dt();Kt();jt();ie();Ee();$t();Dt();ot();j();Ke();R();te();ut();F();pe()});var qo,js,zw,Cn=y(()=>{"use strict";qo=require("zod"),js=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_action");let a=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(mt(),ht)),s=await r(o,e,i,{usePureVision:a});if(s.status!=="success")throw new Error(s.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),o=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${o});`]}},zw=qo.z.object({statement:qo.z.string().describe('The action to perform (e.g., "click the submit button")')})});var Zo,zs,Yw,In=y(()=>{"use strict";Zo=require("zod"),zs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.statement;if(!o)throw new Error("Missing statement for ai_step");let{runTask:a}=await Promise.resolve().then(()=>(mt(),ht)),r=await a(o,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"]}},Yw=Zo.z.object({statement:Zo.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function Xs(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:Lh,async execute(i,n){let{condition:o,timeout_seconds:a=60}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Wait until: ${o}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Condition met: ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Wait until: ${o} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:o,timeout_seconds:a}},feedback:l.message}}}}})}var Pn,Vs,Lh,Yt=y(()=>{"use strict";Pn=require("zod"),Vs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.condition;if(!o)throw new Error("Missing condition for ai_wait_until");let a=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,s=Date.now(),{evaluateStatement:l}=await Promise.resolve().then(()=>(mt(),ht));for(;Date.now()-s<a;){if((await l(o,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${o}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},Lh=Pn.z.object({condition:Pn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:Pn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function Oh(e,t,i,n){return{...await N(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Ys(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 qs(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Nh,usesElementIndex:!0,async execute(i,n){let{element_index:o,option:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Ys(l||`Select option in dropdown ${o}`,{index:o,option:a})};let c=await Oh(d,r,a,l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Selected option "${a}" in dropdown ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ys(`Select option in dropdown ${o}`,{index:o,option:a})}}}})}var Jt,Js,Nh,qt=y(()=>{"use strict";j();F();Jt=require("zod");P();Js=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text||n.kwargs.option,a=O(e,t),r=L(i,t.action_data?.kwargs?.timeout_ms);if(a&&o)await a.selectOption(o,{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},`),"});"]}};Nh=Jt.z.object({element_index:Jt.z.number().int().describe("Index of the dropdown/select element"),option:Jt.z.string().describe("Option value, label, or index to select"),timeout_ms:Jt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Rh(e,t,i,n){return{...await N(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function Qo(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 Qs(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
4103
4101
 
4104
4102
  IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
4105
4103
  Do NOT use it for custom/non-native date pickers
4106
4104
 
4107
- The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Sh,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:Xa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Xa(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=await _h(`Set date to ${o} on element ${a}`,l,r,o);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${o} on element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Xa(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Jt,Us,Sh,qt=b(()=>{"use strict";K();F();Jt=require("zod");$();Us=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:D(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Sh=Jt.z.object({element_index:Jt.z.number().int().describe("Index of the native date picker input element"),date:Jt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Jt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function zs(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Eh,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:l.message}}}}})}var Ya,js,Eh,Zt=b(()=>{"use strict";Ya=require("zod"),js=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},Eh=Ya.z.object({tab_index:Ya.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function Ys(e,t,i,n,a,o){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return Xs.default.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await Mn(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await Mn(e,u,s,d);return}if(a){let c=r.map(p=>`"${p}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await a(e,u,o)}else throw new Error("No selector provided and AI action execution is not available")}async function Mn(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(Vs.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:o});s.catch(()=>{}),await t.click({timeout:o}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var Vs,Xs,Qt=b(()=>{"use strict";R();Vs=W(require("fs"),1),Xs=W(require("path"),1)});async function Th(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Js(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 Zs(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:Ah,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:Js(l||`Upload file to element ${a}`,{index:a,paths:o})};let c=await Th(d,r,{paths:o},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:Js(l||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Ae,qs,Ah,Zw,ei=b(()=>{"use strict";Qt();K();F();Ae=require("zod");$();qs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(d=>i.getTestDataFilePath(d)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await Mn(e,r,o,{useFileInput:s,timeout:D(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]}};Ah=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ae.z.string().describe("Paths to the files to upload"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Zw=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the file input element"),paths:Ae.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function el(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Mh,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Waited ${a} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:l.message}}}}})}var Ja,Qs,Mh,ti=b(()=>{"use strict";Ja=require("zod"),Qs=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});`]}},Mh=Ja.z.object({seconds:Ja.z.number().positive().describe("Number of seconds to wait")})});function il(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Ih,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:s.message}}}}})}var qa,tl,Ih,ii=b(()=>{"use strict";qa=require("zod"),tl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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} } },`,"});"]}},Ih=qa.z.object({timeout_seconds:qa.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function nl(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:Ch,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:l.message}}}}})}var Za,Qa,Ch,ni=b(()=>{"use strict";Za=require("zod"),Qa=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)});`]}},Ch=Za.z.object({keys:Za.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function rl(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:$h,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 al,ol,$h,ai=b(()=>{"use strict";F();al=require("zod");$();ol=class{async execute(e,t){await e.reload({timeout:we}),await e.waitForLoadState("load",{timeout:we}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},$h=al.z.object({})});async function Ph(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function sl(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 ll(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Dh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:sl(`Right-click element ${a}`,"right_click",{index:a})};let d=s||`Right-click element ${a}`,c=await Ph("right_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:sl(`Right-click element ${a}`,"right_click",{index:a})}}}})}var In,eo,Dh,oi=b(()=>{"use strict";K();F();In=require("zod");$();eo=class{async execute(e,t,i){let n=O(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},`),"});"]}};Dh=In.z.object({element_index:In.z.number().int().describe("Index of the element to right-click"),timeout_ms:In.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function dl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Lh,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:l.message}}}}})}var Cn,cl,Lh,ri=b(()=>{"use strict";Cn=require("zod"),cl=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)} } },`,"});"]}},Lh=Cn.z.object({name:Cn.z.string().describe("Variable name to save"),value:Cn.z.string().describe("Value to save in the variable")})});async function Oh(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Nh(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function ul(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:Rh,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${a?"down":"up"} ${o} page(s)`,c=await Oh("scroll",d,{down:a,num_pages:o});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Nh(l||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var $n,si,Rh,li=b(()=>{"use strict";$n=require("zod"),si=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)})');`]}};Rh=$n.z.object({down:$n.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:$n.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Fh(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function hl(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function pl(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Hh,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Element with index ${a} not found`,actionEntity:hl(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let c=await Fh("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,d,s,{delta_x:o,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:hl(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var pt,ml,Hh,ci=b(()=>{"use strict";K();F();pt=require("zod");$();ml=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=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(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});`]}};Hh=pt.z.object({element_index:pt.z.number().int().describe("Index of the scrollable element"),delta_x:pt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:pt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:pt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function fl(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Wh,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${a}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:l.message}}}}})}var to,gl,Wh,di=b(()=>{"use strict";to=require("zod"),gl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.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();`]}},Wh=to.z.object({text:to.z.string().describe("Text to scroll to on the page")})});async function Bh(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function wl(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 yl(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Gh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:wl(s||`Get options from dropdown ${a}`,{index:a})};let d=await Bh(l,o,s);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:wl(s||`Get options from dropdown ${a}`,{index:a})}}}})}var io,bl,Gh,ui=b(()=>{"use strict";K();io=require("zod"),bl=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(o){let r=[];for(let s of o.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
4108
- `);a+=`
4109
- Use the exact text string in select_dropdown_option`,i.addNote(a)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};Gh=io.z.object({element_index:io.z.number().int().describe("Index of the dropdown/select element")})});function kl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Uh,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,s,o),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var xl,vl,Uh,hi=b(()=>{"use strict";F();xl=require("zod");$();vl=class{async execute(e,t){await e.goBack({timeout:we}),await e.waitForLoadState("load",{timeout:we}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Uh=xl.z.object({})});function _l(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:Kh,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:a,new_tab:o??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(p){let g=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var mi,no,Kh,pi=b(()=>{"use strict";F();mi=require("zod");$();no=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:we,l=e;o&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},Kh=mi.z.object({url:mi.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:mi.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:mi.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function jh(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Sl(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 El(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:zh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Sl(`Hover element ${a}`,"hover",{index:a})};let d=s||`Hover over element ${a}`,c=await jh("hover",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Sl(`Hover element ${a}`,"hover",{index:a})}}}})}var Pn,ao,zh,gi=b(()=>{"use strict";K();F();Pn=require("zod");$();ao=class{async execute(e,t,i){let n=O(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};zh=Pn.z.object({element_index:Pn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Pn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Vh(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Tl(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 Al(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Xh,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,a);if(!d)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Tl(l||`Input text to element ${a}`,"input_text",{index:a,text:o})};let c=l||`Input text to element ${a}`,u=await Vh("input_text",c,d,r,{text:o});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(d){return{success:!1,error:d.message,actionEntity:Tl(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var fi,oo,Xh,wi=b(()=>{"use strict";K();F();fi=require("zod");$();oo=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=O(e,t),s=D(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(o,{delay:l}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Xh=fi.z.object({element_index:fi.z.number().int().describe("Index of the input element"),text:fi.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:fi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Il(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Yh,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Closed tab ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var ro,Ml,Yh,bi=b(()=>{"use strict";ro=require("zod"),Ml=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} } },`,"});"]}},Yh=ro.z.object({index:ro.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function $l(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Jh,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 Dn,Cl,Jh,yi=b(()=>{"use strict";Dn=require("zod"),Cl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},Jh=Dn.z.object({success:Dn.z.boolean().describe("Whether the task was completed successfully"),summary:Dn.z.string().describe("Summary of what was accomplished or why it failed")})});async function qh(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Pl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Dl(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:Zh,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Pl(`Double-click element ${a}`,"double_click",{index:a})};let d=s||`Double-click element ${a}`,c=await qh("double_click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Pl(`Double-click element ${a}`,"double_click",{index:a})}}}})}var Ln,so,Zh,xi=b(()=>{"use strict";K();F();Ln=require("zod");$();so=class{async execute(e,t,i){let n=O(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},`),"});"]}};Zh=Ln.z.object({element_index:Ln.z.number().int().describe("Index of the element to double-click"),timeout_ms:Ln.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Ol(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:Qh,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:s.message}}}}})}var lo,Ll,Qh,vi=b(()=>{"use strict";lo=require("zod"),Ll=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.otp_secret_key;if(!a)throw new Error("Missing otp_secret_key for generate_2fa_code");let o=i.replaceVariables(String(a)),r=await i.generate2faCode(o);i.saveVariable("otp_code",r)}transpile(e){let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]}},Qh=lo.z.object({otp_secret_key:lo.z.string().describe("The OTP secret key to generate the 2FA code from")})});function Rl(e){if(!e.trim())return!1;try{return(0,Nl.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Nl,On=b(()=>{"use strict";Nl=require("@babel/parser")});function Hl(e,t){e.register({name:"verify",description:"Verify that a statement is true based on the current page state. Use this to check assertions about the page content, element visibility, or any condition.",schema:tm,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let s={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var co,em,Fl,uo,Nn,tm,ki=b(()=>{"use strict";On();R();fe();co=require("zod"),em=W(require("playwright/test"),1),Fl=W(require("playwright/test"),1),uo={};Gi(uo,{default:()=>Fl.default});Gr(uo,em);Nn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let p=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(ht(),ut)),l=await s(o,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4105
+ The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Fh,usesElementIndex:!0,async execute(i,n){let{element_index:o,date:a}=i,{page:r,agentServices:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Date picker element with index ${o} not found`,actionEntity:Qo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let d=l.attributes.type;if(d!=="date")return{success:!1,error:`Element ${o} is not a native date picker (type="${d}"). This action only works with <input type="date">.`,actionEntity:Qo(`Set date to ${a} on element ${o}`,{index:o,date:a})};let c=await Rh(`Set date to ${a} on element ${o}`,l,r,a);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Set date to ${a} on element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Qo(`Set date to ${a} on element ${o}`,{index:o,date:a})}}}})}var Zt,Zs,Fh,Qt=y(()=>{"use strict";j();F();Zt=require("zod");P();Zs=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.date;if(!o)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(o))throw new Error(`Invalid date format: ${o}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let a=i.replaceVariables(String(o)),r=O(e,t);if(r){let s=await r.getAttribute("type").catch(()=>null);if(s&&s!=="date")throw new Error(`Element is not a native date picker (type="${s}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(a,{timeout:L(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},`),"});"]}};Fh=Zt.z.object({element_index:Zt.z.number().int().describe("Index of the native date picker input element"),date:Zt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Zt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function tl(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Hh,async execute(i,n){let o=i.tab_index,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Switch to tab ${o}`,action_data:{action_name:"switch_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Switched to tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Switch to tab ${o}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:o}},feedback:l.message}}}}})}var ea,el,Hh,ei=y(()=>{"use strict";ea=require("zod"),el=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof o=="number"){let a=e.context().pages(),r=o===-1?a.length-1:o;if(i){let s=await i.switchTab(r);await s.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await s.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},Hh=ea.z.object({tab_index:ea.z.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")})});async function ol(e,t,i,n,o,a){let r=Array.isArray(t)?t:[t];if(r.length===0)throw new Error("No file paths provided for upload");let s=r.map(c=>{if(c.startsWith("/")||c.match(/^[A-Za-z]:\\/))return c;let u=n.testDataDir||process.cwd();return nl.default.join(u,c)});h.info(`Uploading files: ${s.join(", ")}`);let l=i.timeout||2e4,d={useFileInput:i.useFileInput||!1,timeout:l};if(i.selector&&typeof i.selector!="string"){let c=i.selector;await $n(e,c,s,d);return}if(i.selector&&typeof i.selector=="string"){let c=i.selector,u=(c.startsWith("xpath="),e.locator(c));await $n(e,u,s,d);return}if(o){let c=r.map(p=>`"${p}"`).join(", "),u="";i.targetDescription?u=`Upload ${c} to ${i.targetDescription}`:u=`Upload ${c}`,h.info(`Using AI to handle file upload: ${u}`),await o(e,u,a)}else throw new Error("No selector provided and AI action execution is not available")}async function $n(e,t,i,n){let{useFileInput:o,timeout:a,mockShowOpenFilePicker:r}=n;if(r){h.info("Using mockShowOpenFilePicker approach");let s=i.map(l=>({path:l,buffer:new Uint8Array(il.default.readFileSync(l))}));await e.evaluate(l=>{window.__pw_showOpenFilePicker_mock_files=l},s),await t.click({timeout:a}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(o)h.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:a}),await e.waitForTimeout(3e3);else{h.info("Using file chooser approach");let s=e.waitForEvent("filechooser",{timeout:a});s.catch(()=>{}),await t.click({timeout:a}),await(await s).setFiles(i),await e.waitForTimeout(3e3)}h.info(`Successfully uploaded ${i.length} file(s)`)}var il,nl,ti=y(()=>{"use strict";R();il=W(require("fs"),1),nl=W(require("path"),1)});async function Wh(e,t,i={},n){return{...await N(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function al(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 sl(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:Bh,usesElementIndex:!0,async execute(i,n){let{element_index:o,paths:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`File input element with index ${o} not found`,actionEntity:al(l||`Upload file to element ${o}`,{index:o,paths:a})};let c=await Wh(d,r,{paths:a},l);return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Uploaded file to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:al(l||`Upload file to element ${o}`,{index:o,paths:a})}}}})}var Ae,rl,Bh,gb,ii=y(()=>{"use strict";ti();j();F();Ae=require("zod");P();rl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=[];if(n.kwargs.paths?o=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(o=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),o.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(o);let a=o.map(d=>i.getTestDataFilePath(d)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let s=n.kwargs.use_file_input||!1,l=i.getActionSettings().mock_show_open_file_picker??!1;await $n(e,r,a,{useFileInput:s,timeout:L(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:l})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(o=>` ${o},`),"});"]}};Bh=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ae.z.string().describe("Paths to the files to upload"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});gb=Ae.z.object({element_index:Ae.z.number().int().describe("Index of the file input element"),paths:Ae.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ae.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function cl(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Uh,async execute(i,n){let{seconds:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Wait ${o} seconds`,action_data:{action_name:"wait",kwargs:{seconds:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Waited ${o} seconds`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Wait ${o} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:o}},feedback:l.message}}}}})}var ta,ll,Uh,ni=y(()=>{"use strict";ta=require("zod"),ll=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});`]}},Uh=ta.z.object({seconds:ta.z.number().positive().describe("Number of seconds to wait")})});function ul(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Gh,async execute(i,n){let{timeout_seconds:o=10}=i,{page:a,agentServices:r}=n;try{let s={action_description:`Wait for download to complete (timeout: ${o}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:"Download completed"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:o}},feedback:s.message}}}}})}var ia,dl,Gh,oi=y(()=>{"use strict";ia=require("zod"),dl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,o)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Gh=ia.z.object({timeout_seconds:ia.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function hl(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:Kh,async execute(i,n){let{keys:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Press keys "${o}"`,action_data:{action_name:"press",kwargs:{keys:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Pressed keys "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Press keys "${o}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:o}},feedback:l.message}}}}})}var na,oa,Kh,ai=y(()=>{"use strict";na=require("zod"),oa=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)});`]}},Kh=na.z.object({keys:na.z.string().describe("A single key or key combination to press (e.g. Escape, Backspace, Insert, PageDown, Delete, Tab, Enter). Key combinations like `Control+o`, `Control+Shift+T`, `ControlOrMeta+a` are supported. Note: This does NOT support sequences - to press multiple keys in sequence (e.g., Control+A then Backspace), call this action multiple times.")})});function gl(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:jh,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(o,r,a),{success:!0,actionEntity:r,message:`Reloaded ${o.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 ml,pl,jh,ri=y(()=>{"use strict";F();ml=require("zod");P();pl=class{async execute(e,t){await e.reload({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},jh=ml.z.object({})});async function zh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function fl(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 wl(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Vh,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:fl(`Right-click element ${o}`,"right_click",{index:o})};let d=s||`Right-click element ${o}`,c=await zh("right_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Right-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:fl(`Right-click element ${o}`,"right_click",{index:o})}}}})}var Dn,aa,Vh,si=y(()=>{"use strict";j();F();Dn=require("zod");P();aa=class{async execute(e,t,i){let n=O(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:o});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Vh=Dn.z.object({element_index:Dn.z.number().int().describe("Index of the element to right-click"),timeout_ms:Dn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function yl(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Xh,async execute(i,n){let{name:o,value:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Save variable "${o}" = "${a}"`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Saved variable "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Save variable "${o}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:o,value:a}},feedback:l.message}}}}})}var Ln,bl,Xh,li=y(()=>{"use strict";Ln=require("zod"),bl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.name,a=n.kwargs.value;if(!o||a===void 0)throw new Error("Missing variable name or value for save_variable");o.startsWith("$")&&(o=o.slice(1)),i.saveVariable(o,a)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Xh=Ln.z.object({name:Ln.z.string().describe("Variable name to save"),value:Ln.z.string().describe("Value to save in the variable")})});async function Yh(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Jh(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function xl(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:qh,async execute(i,n){let{down:o,num_pages:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=l||`Scroll ${o?"down":"up"} ${a} page(s)`,c=await Yh("scroll",d,{down:o,num_pages:a});return await t.execute(r,c,s),{success:!0,actionEntity:c,message:`Scrolled ${o?"down":"up"} ${a} page(s)`}}catch(d){return{success:!1,error:d.message,actionEntity:Jh(l||`Scroll ${o?"down":"up"} ${a} page(s)`,"scroll",{down:o,num_pages:a})}}}})}var On,ci,qh,di=y(()=>{"use strict";On=require("zod"),ci=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,o=i.kwargs.num_pages??1,a=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${o} * ${a})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};qh=On.z.object({down:On.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:On.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Zh(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function vl(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function _l(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Qh,usesElementIndex:!0,async execute(i,n){let{element_index:o,delta_x:a,delta_y:r}=i,{page:s,agentServices:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Element with index ${o} not found`,actionEntity:vl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})};let c=await Zh("scroll_on_element",`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,d,s,{delta_x:a,delta_y:r});return await t.execute(s,c,l),{success:!0,actionEntity:c,message:`Scrolled on element ${o} horizontally: ${a}px, vertically: ${r}px`}}catch(d){return{success:!1,error:d.message,actionEntity:vl(`Scroll on element ${o} horizontally: ${a}px, vertically: ${r}px`,"scroll_on_element",{index:o,delta_x:a,delta_y:r})}}}})}var gt,kl,Qh,ui=y(()=>{"use strict";j();F();gt=require("zod");P();kl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.delta_x||0,a=n.kwargs.delta_y||0,r=O(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:s}),await e.mouse.wheel(o,a);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Le(e);if(!t){let o=e.action_data?.kwargs?.delta_x||0,a=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${o}, delta_y: ${a} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${L()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Qh=gt.z.object({element_index:gt.z.number().int().describe("Index of the scrollable element"),delta_x:gt.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:gt.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:gt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function El(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:em,async execute(i,n){let{text:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Scroll to text "${o}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Scrolled to text "${o}"`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||`Scroll to text "${o}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:o}},feedback:l.message}}}}})}var ra,Sl,em,hi=y(()=>{"use strict";ra=require("zod"),Sl=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.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();`]}},em=ra.z.object({text:ra.z.string().describe("Text to scroll to on the page")})});async function tm(e,t,i){return{...await N(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Tl(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 Ml(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:im,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Dropdown element with index ${o} not found`,actionEntity:Tl(s||`Get options from dropdown ${o}`,{index:o})};let d=await tm(l,a,s);return await t.execute(a,d,r),{success:!0,actionEntity:d,message:d.feedback||"No options found"}}catch(l){return{success:!1,error:l.message,actionEntity:Tl(s||`Get options from dropdown ${o}`,{index:o})}}}})}var sa,Al,im,mi=y(()=>{"use strict";j();sa=require("zod"),Al=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let o of e.frames())try{let a=await o.evaluate(r=>{let s=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return s?{options:Array.from(s.options).map(l=>({text:l.text,value:l.value,index:l.index})),id:s.id,name:s.name}:null},t.xpath);if(a){let r=[];for(let s of a.options){let l=JSON.stringify(s.text);r.push(`${s.index}: text=${l}`)}n.push(...r)}}catch{}if(n.length>0){let o=n.join(`
4106
+ `);o+=`
4107
+ Use the exact text string in select_dropdown_option`,i.addNote(o)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};im=sa.z.object({element_index:sa.z.number().int().describe("Index of the dropdown/select element")})});function Pl(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:nm,async execute(i,n){let{page:o,agentServices:a,actionDescription:r}=n;try{let s={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(o,s,a),{success:!0,actionEntity:s,message:"Navigated back"}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:s.message}}}}})}var Cl,Il,nm,pi=y(()=>{"use strict";F();Cl=require("zod");P();Il=class{async execute(e,t){await e.goBack({timeout:ge}),await e.waitForLoadState("load",{timeout:ge}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},nm=Cl.z.object({})});function $l(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:om,async execute(i,n){let{url:o,new_tab:a,timeout_seconds:r}=i,{page:s,agentServices:l,actionDescription:d}=n,c={url:o,new_tab:a??!1};r!==void 0&&(c.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=a?`Open ${o} in new tab`:`Navigate to ${o}`,g={action_description:d||p,action_data:{action_name:"go_to_url",kwargs:c}};return await t.execute(s,g,l),{success:!0,actionEntity:g,message:(a?`Opened ${o} in new tab`:`Navigated to ${o}`)+u}}catch(p){let g=a?`Open ${o} in new tab`:`Navigate to ${o}`;return{success:!1,error:p.message,actionEntity:{action_description:(d||g)+" (failed)",action_data:{action_name:"go_to_url",kwargs:c},feedback:p.message}}}}})}var gi,la,om,fi=y(()=>{"use strict";F();gi=require("zod");P();la=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.url;if(!o)throw new Error("Missing URL for go_to_url action");let a=n.kwargs.new_tab===!0,r=i.replaceVariables(String(o));if(r.startsWith("/")){let d=e.url(),c=null;try{let u=new URL(d);u.origin&&u.origin!=="null"&&(c=u.origin)}catch{}c&&(r=c+r)}let s=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:ge,l=e;a&&(l=await e.context().newPage(),i.setPage(l)),await l.goto(r,{timeout:s})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,o=[`url: ${JSON.stringify(t)}`];return i&&o.push("new_tab: true"),n&&o.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${o.join(", ")} } },`,"});"]}},om=gi.z.object({url:gi.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:gi.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:gi.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function am(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Dl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ll(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:rm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Dl(`Hover element ${o}`,"hover",{index:o})};let d=s||`Hover over element ${o}`,c=await am("hover",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Hovered over element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Dl(`Hover element ${o}`,"hover",{index:o})}}}})}var Nn,ca,rm,wi=y(()=>{"use strict";j();F();Nn=require("zod");P();ca=class{async execute(e,t,i){let n=O(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:o});let a=await n.elementHandle();if(!a)throw new Error("Unable to obtain element handle for hover action");let r=await a.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let s=r.x+r.width/2,l=r.y+r.height/2;await e.mouse.move(s,l)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};rm=Nn.z.object({element_index:Nn.z.number().int().describe("Index of the element to hover over"),timeout_ms:Nn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function sm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Ol(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 Nl(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:lm,usesElementIndex:!0,async execute(i,n){let{element_index:o,text:a}=i,{page:r,agentServices:s,actionDescription:l}=n;try{let d=await B(n,o);if(!d)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:Ol(l||`Input text to element ${o}`,"input_text",{index:o,text:a})};let c=l||`Input text to element ${o}`,u=await sm("input_text",c,d,r,{text:a});return await t.execute(r,u,s),{success:!0,actionEntity:u,message:`Input text to element ${o}`}}catch(d){return{success:!1,error:d.message,actionEntity:Ol(`Input text to element ${o}`,"input_text",{index:o,text:a})}}}})}var bi,da,lm,yi=y(()=>{"use strict";j();F();bi=require("zod");P();da=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.text??n.kwargs.value??"",a=i.replaceVariables(String(o)),r=O(e,t),s=L(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(d=>{d.value&&(d.value="")},null,{timeout:s}),await r.click({timeout:s}),await e.waitForTimeout(200);let l=i.getActionSettings().type_delay;l!==void 0?await e.keyboard.type(a,{delay:l}):await e.keyboard.type(a)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};lm=bi.z.object({element_index:bi.z.number().int().describe("Index of the input element"),text:bi.z.string().describe("Text to type into the input. To use a placeholder, write {{ placeholder_name }} using exact placeholder name. Use clear_input first if you want to replace existing content."),timeout_ms:bi.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Fl(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:cm,async execute(i,n){let{index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l={action_description:s||`Close tab ${o}`,action_data:{action_name:"close_tab",kwargs:{page_id:o}}};return await t.execute(a,l,r),{success:!0,actionEntity:l,message:`Closed tab ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(s||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:l.message}}}}})}var ua,Rl,cm,xi=y(()=>{"use strict";ua=require("zod"),Rl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.page_id??n.kwargs.index;if(o===void 0&&(o=e.context().pages().indexOf(e)),typeof o=="number"){if(o===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(o)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},cm=ua.z.object({index:ua.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function Wl(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:dm,async execute(i,n){let{page:o,agentServices:a}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(o,r,a),{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 Rn,Hl,dm,vi=y(()=>{"use strict";Rn=require("zod"),Hl=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},dm=Rn.z.object({success:Rn.z.boolean().describe("Whether the task was completed successfully"),summary:Rn.z.string().describe("Summary of what was accomplished or why it failed")})});async function um(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function Bl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ul(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:hm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})};let d=s||`Double-click element ${o}`,c=await um("double_click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Double-clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:Bl(`Double-click element ${o}`,"double_click",{index:o})}}}})}var Fn,ha,hm,ki=y(()=>{"use strict";j();F();Fn=require("zod");P();ha=class{async execute(e,t,i){let n=O(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:o});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};hm=Fn.z.object({element_index:Fn.z.number().int().describe("Index of the element to double-click"),timeout_ms:Fn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Kl(e,t){e.register({name:"generate_2fa_code",description:'Generate a 2FA code from an OTP secret key. The code is saved to the "otp_code" variable. To use the otp_code, you must use `$otp_code` to access it.',schema:mm,async execute(i,n){let{otp_secret_key:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:o}},feedback:s.message}}}}})}var ma,Gl,mm,_i=y(()=>{"use strict";ma=require("zod"),Gl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.otp_secret_key;if(!o)throw new Error("Missing otp_secret_key for generate_2fa_code");let a=i.replaceVariables(String(o)),r=await i.generate2faCode(a);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)} } },`,"});"]}},mm=ma.z.object({otp_secret_key:ma.z.string().describe("The OTP secret key to generate the 2FA code from")})});function zl(e){if(!e.trim())return!1;try{return(0,jl.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var jl,Hn=y(()=>{"use strict";jl=require("@babel/parser")});function Xl(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:gm,async execute(i,n){let{statement:o}=i,{page:a,agentServices:r}=n;try{let s={action_description:`${o}`,action_data:{action_name:"verify",kwargs:{statement:o}}};return await t.execute(a,s,r),{success:!0,actionEntity:s,message:`Assertion verified: ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Verify: ${o} (failed)`,action_data:{action_name:"verify",kwargs:{statement:o}},feedback:s.message}}}},availability:{openai:!0,mcp:!0}})}var pa,pm,Vl,ga,Wn,gm,Si=y(()=>{"use strict";Hn();R();pe();pa=require("zod"),pm=W(require("playwright/test"),1),Vl=W(require("playwright/test"),1),ga={};ji(ga,{default:()=>Vl.default});Xr(ga,pm);Wn=class{async execute(e,t,i){let n=t.action_data?.kwargs,o=typeof n?.code=="string",a=o?n?.statement||t.action_description:t.action_description||n?.statement;if(o&&a){let c=Date.now();try{await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a}`),i.addNote(`Assertion passed: ${a}`);return}catch(u){let p=((Date.now()-c)/1e3).toFixed(1);h.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${a}`)}}else if(o){let c=Date.now();await this.executeJSAssertion(e,n.code,i),h.info(`[VERIFY:JS] \u2713 ${((Date.now()-c)/1e3).toFixed(1)}s: ${a||"js-only"}`),i.addNote(`Assertion passed: ${a||"js-only"}`);return}if(!a)throw new Error("Missing statement or code for verify action");let r=Date.now();h.info(`[VERIFY:AI] Evaluating: ${a}`);let{evaluateStatement:s}=await Promise.resolve().then(()=>(mt(),ht)),l=await s(a,e,i,{useCleanScreenshotForAssertion:!0}),d=l.explanation||l.error||(l.success?`Assertion passed: ${a}`:"Assertion failed");if(i.addNote(d),!l.success)throw h.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`),new Error(l.error||l.explanation||"Assertion failed");h.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${a}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
4110
4108
  return (async () => {
4111
4109
  ${t}
4112
4110
  })();
4113
- `)(e,uo.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(!Rl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let s=r.split(`
4114
- `),l=JSON.stringify(a);return["{ const _t = Date.now(); try {",...s.map(d=>` ${d}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${o});`,"} }"]}return r.split(`
4115
- `)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},tm=co.z.object({statement:co.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function Bl(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:im,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${a} to ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Rn,Wl,im,_i=b(()=>{"use strict";Rn=require("zod"),Wl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:s}=await Promise.resolve().then(()=>(ht(),ut)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},im=Rn.z.object({element_description:Rn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Rn.z.string().describe("Name of the variable to store the extracted value")})});async function nm(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Gl(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 Kl(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:am,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Gl(s||`Clear element ${a}`,"clear_input",{index:a})};let d=s||`Clear element ${a}`,c=await nm("clear_input",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Cleared element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:Gl(`Clear element ${a}`,"clear_input",{index:a})}}}})}var Fn,Ul,am,Si=b(()=>{"use strict";K();F();Fn=require("zod");$();Ul=class{async execute(e,t,i){let n=O(e,t),a=D(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};am=Fn.z.object({element_index:Fn.z.number().int().describe("Index of the input element to clear"),timeout_ms:Fn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function om(e,t,i,n,a={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function jl(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function zl(e,t){e.register({name:"click",description:"Click an interactive element.",schema:rm,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:s}=n;try{let l=await B(n,a);if(!l)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:jl(`Click element ${a}`,"click",{index:a})};let d=s||`Click element ${a}`,c=await om("click",d,l,o);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:`Clicked element ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:jl(`Click element ${a}`,"click",{index:a})}}}})}var Hn,Wn,rm,Ei=b(()=>{"use strict";K();F();Hn=require("zod");$();Wn=class{async execute(e,t,i){let n=O(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=Le(e);if(!t)return['await agent.execAction("click", page, {});'];let i=D();return[`await ${t}.click({ timeout: ${i} });`]}};rm=Hn.z.object({element_index:Hn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Hn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var sm,lm,Ti,Bn=b(()=>{"use strict";sm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],lm=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Ti=class{static isAiAction(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:sm.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let n=i.element_description,a=i.variable_name;return n&&a?`Extract ${n} and save to ${a}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!lm.includes(t)}}});var ho,mo,Gn,po=b(()=>{"use strict";pn();gn();fn();wn();bn();yn();xn();vn();kn();En();Tn();Vt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();li();ci();di();ui();hi();pi();gi();wi();bi();yi();xi();vi();ki();_i();Si();Ei();Bn();F();fe();ho=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new no),M.registerAction("go_back",new vl),M.registerAction("reload_page",new ol),M.registerAction("close_tab",new Ml),M.registerAction("switch_tab",new js),M.registerAction("click",new Wn),M.registerAction("hover",new ao),M.registerAction("right_click",new eo),M.registerAction("double_click",new so),M.registerAction("click_by_coordinates",new $s),M.registerAction("right_click_by_coordinates",new Ms),M.registerAction("double_click_by_coordinates",new Ps),M.registerAction("drag_drop",new Ds),M.registerAction("input_text",new oo),M.registerAction("clear_input",new Ul),M.registerAction("press",new Qa),M.registerAction("send_keys_on_element",new Es),M.registerAction("scroll_on_element",new ml),M.registerAction("scroll_to_text",new gl),M.registerAction("scroll",new si),M.registerAction("upload_file",new qs),M.registerAction("wait_for_download_complete",new tl),M.registerAction("get_dropdown_options",new bl),M.registerAction("select_dropdown_option",new Bs),M.registerAction("set_date_for_native_date_picker",new Us),M.registerAction("verify",new Nn),M.registerAction("ai_action",new Ns),M.registerAction("ai_extract",new Wl),M.registerAction("ai_step",new Rs),M.registerAction("ai_wait_until",new Fs),M.registerAction("generate_2fa_code",new Ll),M.registerAction("wait",new Qs),M.registerAction("wait_for_page_ready",new As),M.registerAction("save_variable",new cl),M.registerAction("js_code",new Cs),M.registerAction("js_action",new Is),M.registerAction("function",new Ls),M.registerAction("done",new Cl),M.registerAction("click_element",new Wn),M.registerAction("click_element_by_index",new Wn),M.registerAction("hover_element_by_index",new ao),M.registerAction("right_click_on_element",new eo),M.registerAction("double_click_on_element",new so),M.registerAction("scroll_down",new si),M.registerAction("scroll_up",new si),M.registerAction("scroll_element",new si),M.registerAction("send_keys",new Qa),M.registerAction("open_tab",new no),M.registerAction("fill",new oo),M.registerAction("ai_assert",new Nn),M.registerAction("assert",new Nn)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=($(),La(Ui)),o=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(Ti.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(o),c=l.map(g=>` ${g}`),u=Ti.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=($(),La(Ui));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(a){let l=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};ho.actions=new Map,ho.initialized=!1;mo=ho,Gn=mo});var gt={};Ue(gt,{ActionHandler:()=>mo,default:()=>Gn});var ft=b(()=>{"use strict";po();pn();gn();fn();wn();bn();yn();xn();vn();kn();En();Tn();Vt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();li();ci();di();ui();hi();pi();gi();wi();bi();yi();xi();vi();ki();_i();Si();Ei();On();Qt();K();Ke();R();ie();dt();Bn();F();fe()});function Un(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4111
+ `)(e,ga.expect,n)}catch(o){throw new Error(`Assertion failed: ${o instanceof Error?o.message:String(o)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",o=n?i?.statement||e.action_description:e.action_description||i?.statement,a=JSON.stringify(t||"");if(n){let r=i.code;if(!zl(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(o){let s=r.split(`
4112
+ `),l=JSON.stringify(o);return["{ const _t = Date.now(); try {",...s.map(d=>` ${d}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${a});`,"} }"]}return r.split(`
4113
+ `)}return o?[`await agent.assert(page, ${JSON.stringify(o)}, ${a});`]:["// Skipping verify: missing statement or code"]}},gm=pa.z.object({statement:pa.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function Jl(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:fm,async execute(i,n){let{element_description:o,variable_name:a}=i,{page:r,agentServices:s}=n;try{let l={action_description:`Extract ${o} to ${a}`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}}};return await t.execute(r,l,s),{success:!0,actionEntity:l,message:`Extracted ${o} to ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Extract ${o} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:o,variable_name:a}},feedback:l.message}}}},availability:{openai:!1,mcp:!0}})}var Bn,Yl,fm,Ei=y(()=>{"use strict";Bn=require("zod"),Yl=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=n.kwargs.element_description,a=n.kwargs.variable_name;if(!o||!a)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${o} and save to ${a}`,{executeStep:s}=await Promise.resolve().then(()=>(mt(),ht)),l=await s(r,e,i);if(l.status!=="success")throw new Error(l.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let o=JSON.stringify(i),a=JSON.stringify(n);return[`await agent.extract(page, ${o}, ${a}, '${t||""}');`]}},fm=Bn.z.object({element_description:Bn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:Bn.z.string().describe("Name of the variable to store the extracted value")})});async function wm(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ql(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Ql(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:bm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Input element with index ${o} not found`,actionEntity:ql(s||`Clear element ${o}`,"clear_input",{index:o})};let d=s||`Clear element ${o}`,c=await wm("clear_input",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Cleared element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ql(`Clear element ${o}`,"clear_input",{index:o})}}}})}var Un,Zl,bm,Ti=y(()=>{"use strict";j();F();Un=require("zod");P();Zl=class{async execute(e,t,i){let n=O(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};bm=Un.z.object({element_index:Un.z.number().int().describe("Index of the input element to clear"),timeout_ms:Un.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function ym(e,t,i,n,o={}){return{...await N(n,i),action_description:t,action_data:{action_name:e,kwargs:{...o}}}}function ec(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 tc(e,t){e.register({name:"click",description:"Click an interactive element.",schema:xm,usesElementIndex:!0,async execute(i,n){let{element_index:o}=i,{page:a,agentServices:r,actionDescription:s}=n;try{let l=await B(n,o);if(!l)return{success:!1,error:`Element with index ${o} not found.`,actionEntity:ec(`Click element ${o}`,"click",{index:o})};let d=s||`Click element ${o}`,c=await ym("click",d,l,a);return await t.execute(a,c,r),{success:!0,actionEntity:c,message:`Clicked element ${o}`}}catch(l){return{success:!1,error:l.message,actionEntity:ec(`Click element ${o}`,"click",{index:o})}}}})}var Gn,Kn,xm,Ai=y(()=>{"use strict";j();F();Gn=require("zod");P();Kn=class{async execute(e,t,i){let n=O(e,t),o=L(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:o});else throw new Error("No locator found for click action")}transpile(e){let t=Le(e);if(!t)return['await agent.execAction("click", page, {});'];let i=L();return[`await ${t}.click({ timeout: ${i} });`]}};xm=Gn.z.object({element_index:Gn.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:Gn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});var vm,km,Mi,jn=y(()=>{"use strict";vm=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],km=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],Mi=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:vm.includes(t)}static getAiStatement(e){let t=e.action_data?.action_name;if(!t)return null;let i=e.action_data?.kwargs||{};switch(t){case"ai_action":case"ai_step":return i.statement||null;case"verify":case"ai_assert":case"assert":return i.statement||e.action_description||null;case"ai_extract":let n=i.element_description,o=i.variable_name;return n&&o?`Extract ${n} and save to ${o}`:null;case"ai_wait_until":return i.condition||null;default:return null}}static canSelfHeal(e){let t=e.action_data?.action_name;return!t||(t==="verify"||t==="ai_assert"||t==="assert")&&e.action_data?.kwargs?.code?!1:!km.includes(t)}}});var fa,wa,zn,ba=y(()=>{"use strict";bn();yn();xn();vn();kn();_n();Sn();En();Tn();Cn();In();Yt();qt();Qt();ei();ii();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();fi();wi();yi();xi();vi();ki();_i();Si();Ei();Ti();Ai();jn();F();pe();fa=class M{static registerAction(t,i){M.actions.set(t,i)}constructor(){M.initialized||(this.registerBuiltinActions(),M.initialized=!0)}registerBuiltinActions(){M.registerAction("go_to_url",new la),M.registerAction("go_back",new Il),M.registerAction("reload_page",new pl),M.registerAction("close_tab",new Rl),M.registerAction("switch_tab",new el),M.registerAction("click",new Kn),M.registerAction("hover",new ca),M.registerAction("right_click",new aa),M.registerAction("double_click",new ha),M.registerAction("click_by_coordinates",new Ws),M.registerAction("right_click_by_coordinates",new Rs),M.registerAction("double_click_by_coordinates",new Bs),M.registerAction("drag_drop",new Us),M.registerAction("input_text",new da),M.registerAction("clear_input",new Zl),M.registerAction("press",new oa),M.registerAction("send_keys_on_element",new Ls),M.registerAction("scroll_on_element",new kl),M.registerAction("scroll_to_text",new Sl),M.registerAction("scroll",new ci),M.registerAction("upload_file",new rl),M.registerAction("wait_for_download_complete",new dl),M.registerAction("get_dropdown_options",new Al),M.registerAction("select_dropdown_option",new Js),M.registerAction("set_date_for_native_date_picker",new Zs),M.registerAction("verify",new Wn),M.registerAction("ai_action",new js),M.registerAction("ai_extract",new Yl),M.registerAction("ai_step",new zs),M.registerAction("ai_wait_until",new Vs),M.registerAction("generate_2fa_code",new Gl),M.registerAction("wait",new ll),M.registerAction("wait_for_page_ready",new Ns),M.registerAction("save_variable",new bl),M.registerAction("js_code",new Hs),M.registerAction("js_action",new Fs),M.registerAction("function",new Gs),M.registerAction("done",new Hl),M.registerAction("click_element",new Kn),M.registerAction("click_element_by_index",new Kn),M.registerAction("hover_element_by_index",new ca),M.registerAction("right_click_on_element",new aa),M.registerAction("double_click_on_element",new ha),M.registerAction("scroll_down",new ci),M.registerAction("scroll_up",new ci),M.registerAction("scroll_element",new ci),M.registerAction("send_keys",new oa),M.registerAction("open_tab",new la),M.registerAction("fill",new da),M.registerAction("ai_assert",new Wn),M.registerAction("assert",new Wn)}getAction(t){return M.actions.get(t)}hasAction(t){return M.actions.has(t)}getActionNames(){return Array.from(M.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let o=i.action_data?.action_name;if(!o)throw new Error("Action name not found in action_data");let a=this.getAction(o);if(!a)throw new Error(`Unknown action: ${o}`);await a.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:o}=(P(),Ho(zi)),a=t.action_description||"",r=t.action_data?.action_name||"",s=this.getAction(r);if(!s)return[`// ${i}: Unknown action: ${r}`];let l=s.transpile(t,i);if(Mi.isAiAction(t))return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);",...l];let d=JSON.stringify(a),c=l.map(g=>` ${g}`),u=Mi.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${o(a)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...c,`}, ${d}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,o=!1,a){let{sanitizeForComment:r}=(P(),Ho(zi));if(!t)return[`// ${i}: Skipping - no description`];let s=JSON.stringify(t);if(o){let l=a?`, { stmtUid: ${JSON.stringify(a)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${s}, '${i}'${l});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${s}, '${i}', ${n});`]}};fa.actions=new Map,fa.initialized=!1;wa=fa,zn=wa});var ft={};Ge(ft,{ActionHandler:()=>wa,default:()=>zn});var wt=y(()=>{"use strict";ba();bn();yn();xn();vn();kn();_n();Sn();En();Tn();Cn();In();Yt();qt();Qt();ei();ii();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();fi();wi();yi();xi();vi();ki();_i();Si();Ei();Ti();Ai();Hn();ti();j();Ke();R();te();ut();jn();F();pe()});function Vn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
4116
4114
  ${e.stepHistory.slice(-3).map(l=>{let d=`${l.outcome.success?"\u2713":"\u2717"} Step ${l.stepNumber}: ${l.goal}`;if(l.actions.length>1)l.actions.forEach((c,u)=>{let p=c.action_description||"Unknown action";d+=`
4117
4115
  \u2192 Action ${u+1}: ${p}`});else if(l.actions.length===1){let c=l.actions[0]?.action_description||"Unknown action";d+=`
4118
4116
  \u2192 ${c}`}if(!l.outcome.success&&l.outcome.error){let c=l.outcome.error.substring(0,100);d+=`
4119
4117
  Error: ${c}${l.outcome.error.length>100?"...":""}`}return l.evaluation&&(d+=`
4120
4118
  Eval: ${l.evaluation}`),d}).join(`
4121
4119
  `)}
4122
- `,a=()=>e.memory.length===0?"":`**Important Facts (Memory)**:
4120
+ `,o=()=>e.memory.length===0?"":`**Important Facts (Memory)**:
4123
4121
  ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
4124
4122
  `)}
4125
- `,o=()=>e.lastEvaluation?`**Previous Step Evaluation**: ${e.lastEvaluation}
4123
+ `,a=()=>e.lastEvaluation?`**Previous Step Evaluation**: ${e.lastEvaluation}
4126
4124
  `:"",r=()=>e.lastGoal?`**Previous Goal**: ${e.lastGoal}
4127
4125
  `:"",s=()=>{if(e.consecutiveFailures===0)return"";let l=e.maxFailures-e.consecutiveFailures;return`\u26A0\uFE0F **Warning**: ${e.consecutiveFailures} consecutive failure(s). ${l} attempts remaining before task fails.
4128
4126
  `};return`## TASK CONTEXT
@@ -4132,7 +4130,7 @@ ${e.memory.map((l,d)=>`${d+1}. ${l}`).join(`
4132
4130
  **Current URL**: ${i}
4133
4131
  **Step**: ${e.currentStep+1}/${e.maxSteps}
4134
4132
 
4135
- ${o()}${r()}${a()}${n()}${s()}`.trim()}function Vl(){return`
4133
+ ${a()}${r()}${o()}${n()}${s()}`.trim()}function ic(){return`
4136
4134
  \u26A0\uFE0F **FINAL STEP WARNING** \u26A0\uFE0F
4137
4135
 
4138
4136
  This is your last step. You MUST use the "done" action now.
@@ -4141,8 +4139,8 @@ This is your last step. You MUST use the "done" action now.
4141
4139
  - If the task is incomplete or partially complete, set success=false
4142
4140
  - Include everything you've accomplished in the done action's text field
4143
4141
  - No other actions are allowed on this step
4144
- `.trim()}function cm(){let e=H.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof wt.z.ZodObject){let a=i.schema.shape,o=[];Object.keys(a).forEach(r=>{let s=a[r],l="any";s instanceof wt.z.ZodNumber?l="number":s instanceof wt.z.ZodString?l="string":s instanceof wt.z.ZodBoolean?l="boolean":s instanceof wt.z.ZodEnum&&(l=s._def.values.map(d=>`"${d}"`).join(" | ")),o.push(`${r}: ${l}`)}),n=`{${o.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4145
- `)}function Kn(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:a=!0,useMultiAction:o=!0}=t,r=a?`
4142
+ `.trim()}function _m(){let e=H.getTools().filter(i=>!i.name.startsWith("ai_")&&!["set_goal","evaluate_step","update_memory","mark_complete"].includes(i.name)).map(i=>{let n="";if(i.schema instanceof bt.z.ZodObject){let o=i.schema.shape,a=[];Object.keys(o).forEach(r=>{let s=o[r],l="any";s instanceof bt.z.ZodNumber?l="number":s instanceof bt.z.ZodString?l="string":s instanceof bt.z.ZodBoolean?l="boolean":s instanceof bt.z.ZodEnum&&(l=s._def.values.map(d=>`"${d}"`).join(" | ")),a.push(`${r}: ${l}`)}),n=`{${a.join(", ")}}`}return{name:i.name,description:i.description,params:n}}).sort((i,n)=>i.name.localeCompare(n.name)),t=[];return t.push("## AVAILABLE ACTIONS"),t.push(""),t.push("Use these exact action names in your JSON response:"),t.push(""),e.forEach(i=>{t.push(`- \`${i.name}\` - ${i.description} (kwargs: ${i.params})`)}),t.push(""),t.join(`
4143
+ `)}function Xn(e,t={}){if(e)return e;let{useThinking:i=!0,useMemory:n=!0,useEvaluation:o=!0,useMultiAction:a=!0}=t,r=o?`
4146
4144
  1. **Evaluate Previous Step**: After each action, evaluate whether the previous goal was accomplished:
4147
4145
  - "success: <reason>" if the goal was fully achieved
4148
4146
  - "partial: <reason>" if the goal was partially achieved but needs more work
@@ -4162,9 +4160,9 @@ This is your last step. You MUST use the "done" action now.
4162
4160
  - Consider alternatives and tradeoffs
4163
4161
  - Plan the immediate next step
4164
4162
  `:"",d=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
4165
- `:"",c=a?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
4163
+ `:"",c=o?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
4166
4164
  `:"",u=n?` "memory": "<important facts to remember>", // Update only when learning something new
4167
- `:"",p=o?` "actions": [ // Can be single action or multiple actions in sequence
4165
+ `:"",p=a?` "actions": [ // Can be single action or multiple actions in sequence
4168
4166
  {
4169
4167
  "description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
4170
4168
  "action_name": "<name of action to execute>",
@@ -4175,7 +4173,7 @@ This is your last step. You MUST use the "done" action now.
4175
4173
  "description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>>",
4176
4174
  "action_name": "<name of action to execute>",
4177
4175
  "kwargs": { ... } // Action parameters
4178
- }],`,g=o?`
4176
+ }],`,g=a?`
4179
4177
  ## When to Use Multiple Actions:
4180
4178
  - Multiple actions can be batched if they all execute on the CURRENT page state
4181
4179
  - Good: Type username \u2192 Tab \u2192 Type password \u2192 Click submit (all on same page, submit can be last)
@@ -4249,7 +4247,7 @@ CRITICAL: Detect when you are stuck and stop immediately:
4249
4247
 
4250
4248
  When stuck, call \`done\` with success=false and explain what happened.
4251
4249
 
4252
- ${cm()}
4250
+ ${_m()}
4253
4251
  ## Reasoning Rules
4254
4252
 
4255
4253
  Use the \`thinking\` field to reason about each step:
@@ -4285,13 +4283,13 @@ ${p}
4285
4283
  **Current Goal Examples:**
4286
4284
  - "Add the product to the cart"
4287
4285
  - "Find more product listings and extract details from the next 5 items on the page"
4288
- ${g}`.trim()}var wt,jn=b(()=>{"use strict";Te();wt=require("zod")});var zn,go=b(()=>{"use strict";jn();ne();zn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,a,o={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=o,u=[],p=Un(a,e,t);if(u.push({type:"text",text:p}),u.push({type:"text",text:`## CURRENT PAGE STATE
4286
+ ${g}`.trim()}var bt,Yn=y(()=>{"use strict";Te();bt=require("zod")});var Jn,ya=y(()=>{"use strict";Yn();ie();Jn=class{constructor(e){this.messages=[],this.systemPrompt=e}getMessages(){return{system:this.systemPrompt,messages:[...this.messages]}}addStateMessage(e,t,i,n,o,a={}){let{executionHistory:r,placeholderData:s,sensitiveKeys:l,isFinalStep:d,finalStepWarning:c}=a,u=[],p=Vn(o,e,t);if(u.push({type:"text",text:p}),u.push({type:"text",text:`## CURRENT PAGE STATE
4289
4287
 
4290
4288
  **Interactive Elements**:
4291
- ${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([w,k],y)=>`${y+1}. ${w} \u2192 ${k}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4289
+ ${i}`}),r&&Array.isArray(r)&&r.length>0){let g=r.map(([f,k],x)=>`${x+1}. ${f} \u2192 ${k}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
4292
4290
 
4293
4291
  ${g.join(`
4294
- `)}`})}if(s&&Object.keys(s).length>0){f.log("Adding placeholder data description");let g=this.getPlaceholderDataDescription(s,l);f.log(`Placeholder data description: ${g}`),g&&u.push({type:"text",text:g})}d&&c&&u.push({type:"text",text:c}),u.push({type:"image",image:n}),f.log(`Adding state message: ${u.length} parts`),this.messages.push({role:"user",content:u})}addAssistantMessage(e){this.messages.push({role:"assistant",content:e})}addTextMessage(e,t){this.messages.push({role:e,content:t})}getMessageCount(){return this.messages.length}clear(){this.messages=[]}getRecentMessages(e){return this.messages.slice(-e)}updateSystemPrompt(e){this.systemPrompt=e}addAssistantMessageWithToolCalls(e){this.messages.push({role:"assistant",content:e.map(t=>({type:"tool-call",toolCallId:t.toolCallId,toolName:t.toolName,input:t.input}))})}addToolResponseMessage(e,t,i){this.messages.push({role:"tool",content:[{type:"tool-result",toolCallId:t,toolName:i,output:typeof e=="string"?{type:"text",value:e}:{type:"json",value:e}}]})}getPlaceholderDataDescription(e,t){let i=[];for(let a of Object.keys(e))if(e[a])if(t?.has(a))i.push(` - ${a}: [SENSITIVE - value hidden]`);else{let o=e[a],r=typeof o=="string"?o:JSON.stringify(o);i.push(` - ${a}: "${r}"`)}if(i.length===0)return"";let n=`## DATA PLACEHOLDERS
4292
+ `)}`})}if(s&&Object.keys(s).length>0){w.log("Adding placeholder data description");let g=this.getPlaceholderDataDescription(s,l);w.log(`Placeholder data description: ${g}`),g&&u.push({type:"text",text:g})}d&&c&&u.push({type:"text",text:c}),u.push({type:"image",image:n}),w.log(`Adding state message: ${u.length} parts`),this.messages.push({role:"user",content:u})}addAssistantMessage(e){this.messages.push({role:"assistant",content:e})}addTextMessage(e,t){this.messages.push({role:e,content:t})}getMessageCount(){return this.messages.length}clear(){this.messages=[]}getRecentMessages(e){return this.messages.slice(-e)}updateSystemPrompt(e){this.systemPrompt=e}addAssistantMessageWithToolCalls(e){this.messages.push({role:"assistant",content:e.map(t=>({type:"tool-call",toolCallId:t.toolCallId,toolName:t.toolName,input:t.input}))})}addToolResponseMessage(e,t,i){this.messages.push({role:"tool",content:[{type:"tool-result",toolCallId:t,toolName:i,output:typeof e=="string"?{type:"text",value:e}:{type:"json",value:e}}]})}getPlaceholderDataDescription(e,t){let i=[];for(let o of Object.keys(e))if(e[o])if(t?.has(o))i.push(` - ${o}: [SENSITIVE - value hidden]`);else{let a=e[o],r=typeof a=="string"?a:JSON.stringify(a);i.push(` - ${o}: "${r}"`)}if(i.length===0)return"";let n=`## DATA PLACEHOLDERS
4295
4293
 
4296
4294
  `;return n+=`The following placeholders are available for use in your actions:
4297
4295
  `,n+=`${i.join(`
@@ -4301,7 +4299,7 @@ ${g.join(`
4301
4299
  `,n+=`- Use the EXACT placeholder name as shown above
4302
4300
  `,n+=`- Do NOT use the actual value directly in the action
4303
4301
  `,n+=`- The values shown are for context only to help you understand what data is available
4304
- `,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var bt,yt=b(()=>{"use strict";bt=`
4302
+ `,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var yt,xt=y(()=>{"use strict";yt=`
4305
4303
  // check to make sure we're not inside the PDF viewer
4306
4304
  window.isPdfViewer = !!document?.body?.querySelector('body > embed[type="application/pdf"][width="100%"]')
4307
4305
  if (!window.isPdfViewer) {
@@ -4356,9 +4354,9 @@ if (!window.isPdfViewer) {
4356
4354
  };
4357
4355
  })();
4358
4356
  }
4359
- `});function Xl(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function Yl(e,t){let i=await e.newContext(t);return i.addInitScript(bt),i}async function Vn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function Jl(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function ql(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function pm(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=u=>{let p=u.resourceType(),g=u.url();if(!a.has(p)||s(g))return;let w=u.headers();w.purpose==="prefetch"||["video","audio"].includes(w["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let p=u.request();if(!i.has(p))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(p);return}if(![...o].some(k=>g.startsWith(k))){i.delete(p);return}let w=u.headers()["content-length"];if(w)try{if(parseInt(w,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-mm;for(let u of await e.requests()){let p=u.resourceType(),g=u.url(),w=u.timing();a.has(p)&&!s(g)&&w.responseEnd===-1&&w.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),p=hm;for(;;){await new Promise(w=>setTimeout(w,100));let g=Date.now();if(i.size===0&&g-n>=p){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Me(e,t=um,i=dm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),pm(e,t)])}catch(r){throw r instanceof Error?new Error(`Failed during network stabilization: ${r.message}`):new Error("An unknown error occurred during network stabilization.")}let a=Date.now()-n,o=Math.max(i-a,0);o>0&&await new Promise(r=>setTimeout(r,o))}var Xn,dm,um,hm,mm,Ie=b(()=>{"use strict";yt();R();Xn=async(e,t,i)=>{let n=await e.context().newCDPSession(e),a=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:a.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((o,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},dm=.5*1e3,um=30*1e3,hm=1*1e3,mm=3*1e3});function gm(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 ec(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),s=t.domService||new me(t.agentServices.getDomServiceOptions()),l={...t,domService:s};f.init(),f.section("Task Execution Started"),f.log(`Task: ${e}`),f.log(`Max steps: ${a}`),f.log(`Model: ${r}`);let d={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Kn(i.customPrompt),p=new zn(u);f.log(`System prompt length: ${u.length} chars`);let g=!1,w="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});d.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let y=Date.now();f.section(`Step ${d.currentStep}/${a}`),f.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{f.log("Waiting for page to stabilize..."),await Me(l.page),f.log("Page stabilized")}catch{f.log("Page stabilization timed out, continuing anyway")}let m;try{f.log("Preparing context (DOM + screenshot)...");let C=l.agentServices.getInteractiveClassNames(),I=l.agentServices.getIframeFallbackDomains();m=await Zl(l.page,l.domService,C,I),f.log("Context prepared")}catch(C){if(C.message.includes("Execution context was destroyed")){f.log("Page navigating, waiting for load..."),await Me(l.page);let I=l.agentServices.getInteractiveClassNames(),L=l.agentServices.getIframeFallbackDomains();m=await Zl(l.page,l.domService,I,L)}else throw f.error("Error preparing context",C),C}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let x=await wm(p,r,i,m.screenshotBase64);if(x.tokenUsages&&x.tokenUsages.length>0&&c.push(...x.tokenUsages),!x.stepOutput){if(f.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=o){w="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let T=x.stepOutput;vm(d.currentStep,a,T);let v=await ym(T,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,x.debugInfo);k.push(...v.actionEntities);let E=xm(d.currentStep,T,v,d,y,x.debugInfo,x.tokenUsages),A=Date.now()-y;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=o){f.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),w=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,w=v.doneResult.summary;break}if(v.completesInstruction){g=!0,w="Instruction completed";break}}return d.currentStep>=a&&!g&&(w="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),f.log(`Build success result: summary=${w}, completed=${g}, actions=${k.length}, tokens=${c.length}`),km(d,k,g,w,n,c,r)}catch(y){let m=y.message;return f.error(`Task execution failed: ${m}`,y),i.onEvent?.({type:"error",error:m,recoverable:!1}),_m(d,m,n,c,r)}}async function Zl(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 fm(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 wm(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(p=>p.type==="image").length);let l=ye(t,s),d={model:be(t),system:o,messages:r,temperature:a,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let p=Date.now();f.log(`Calling LLM (${t})...`);let g=await(0,Ql.generateText)(d),w=Date.now()-p,k=g,y=k.usage;f.llmCall(t,w,y);let m=k.reasoningText;m&&(f.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let x={systemPrompt:o,userPrompt:fm(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},T=[],v=gm(y,t);v&&T.push(v);let E=bm(g.text);if(!E)if(u<c-1){f.log(`Attempt ${u+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(A=>setTimeout(A,i.retryDelay||1e3));continue}else return f.error("All parsing attempts failed"),{stepOutput:null,debugInfo:x,tokenUsages:T};return{stepOutput:E,debugInfo:x,tokenUsages:T}}catch(p){if(u<c-1){f.log(`Attempt ${u+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw f.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function bm(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return f.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return f.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return f.error("Action missing required field: action_name"),null;if(!n.description)return f.error("Action missing required field: description"),null}return i}catch(i){return f.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),f.error(`Parse error: ${i.message}`),null}}async function ym(e,t,i,n,a,o,r){let s=[],l=!0,d=null;f.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},p=o;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let w={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let m=i.selectorMap.get(k);m&&(w=await N(t.page,m))}let y={...w,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await H.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(y=m.actionEntity);let x=await u.agentServices.getCurrentPage();if(x&&(u.page=x,t.page=u.page),m?.success===!1){l=!1,f.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(y),a?.({type:"action",action_entity:y,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,f.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function xm(e,t,i,n,a,o,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function vm(e,t,i){if(f.log(`Step ${e}/${t}`),i.thinking&&f.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&f.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&f.log(`Memory: ${i.memory}`),f.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];f.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else f.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{f.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function km(e,t,i,n,a,o,r){let s=o.reduce((c,u)=>c+u.prompt_tokens,0),l=o.reduce((c,u)=>c+u.completion_tokens,0),d=o.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-a,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:o}}}function _m(e,t,i,n,a){let o=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:a,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:s,tokenUsages:n}}}var Ql,tc=b(()=>{"use strict";go();jn();Te();je();ne();Ie();Ee();K();Ql=require("ai")});var ic={};Ue(ic,{TaskMessageManager:()=>zn,formatFinalStepWarning:()=>Vl,formatTaskContext:()=>Un,getBrowserTaskJSONPrompt:()=>Kn,runTaskLoop:()=>ec});var nc=b(()=>{"use strict";tc();go();jn();Te();Sn();je();Ht();Bt();ct();Gt();Ut();ne();Ie();yt();Ee();Ct();$t();at();K();Ke();R();ie();dt();F();fe()});async function jt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(H.has(i)){let a=await H.execute(i,n,t),o=a?.success!==!1,r=a?.error||a?.message;return{success:o,error:o?void 0:r}}else{let{page:a,agentServices:o}=t;return await(await Sm()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Sm(){if(Yn)return Yn;let e=await Promise.resolve().then(()=>(ft(),gt));return Yn=new e.default,Yn}async function mt(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ga(r,o,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function ze(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Ga(r,o,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,p=await jt(l,o);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:u}}async function Ve(e,t,i,n={}){let a={page:t,agentServices:i,domService:new me(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),ps(o,a,n)}async function Xe(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(nc(),ic)),r=n?l=>{n(l)}:void 0,s=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Yn,zt=b(()=>{"use strict";dn();Te();je();Yn=null});function ac(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:Em,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await ot(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,s=await jt(r,a);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var fo,Em,wo=b(()=>{"use strict";zt();rt();fo=require("zod"),Em=fo.z.object({instruction:fo.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});async function Tm(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let w=(c.message||{}).headers||{},k=w.subject||"",y=w.from||"",m=w.to||"";if(i.from_email&&!y.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:k,from:y,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:w["message-id"]||""});continue}let p=u.split("/"),g=p[p.length-1];if(h.info(`Storage key: ${g}`),g){let w=`https://api.mailgun.net/v3/domains/${a}/messages/${g}`;try{let k=await fetch(w,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let y=await k.json(),m=y.Subject||"",x=y.From||"",T=y.To||"",v=y.Date||"",E=y["Message-Id"]||"";h.info(`subject: ${m}`),h.info(`from_addr: ${x}`),h.info(`to_addr: ${T}`),h.info(`date: ${v}`),h.info(`message_id: ${E}`);let A=y["body-html"]||y["body-plain"]||"";if(A&&A.includes("<")&&(A=(0,rc.convert)(A)),h.info(`Body: ${A.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:m,from:x,to:T,date:v,body:A,message_id:E});continue}else h.warn(`Messages API returned ${k.status}`)}catch(k){h.warn(`Failed to parse JSON response: ${k}`)}}try{let w=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!w.ok){h.warn(`Could not fetch stored message: ${w.status}`);continue}let k=await w.text();h.info(`Fallback: Raw email length: ${k.length}`);let y=k.split(`
4360
- `),m=!0,x={},T="";for(let L=0;L<y.length;L++){let V=y[L];if(V.trim()===""&&m){m=!1;continue}if(m){let ee=V.match(/^([^:]+):\s*(.+)$/);ee&&(x[ee[1].toLowerCase()]=ee[2])}else T+=V+`
4361
- `}let v=x.subject||"",E=x.from||"",A=x.to||"",C=x.date||"",I=x["message-id"]||"";if(i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!T.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:v,from:E,to:A,date:C,body:T.trim(),message_id:I})}catch(w){h.warn(`Error fetching raw message: ${w}`)}}if(o.length>0){try{o.sort((u,p)=>{let g=new Date(u.date).getTime();return new Date(p.date).getTime()-g})}catch{}let c=o[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return o}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Am(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4357
+ `});function nc(e,t=!0,i=!1){return[...e!==void 0?[`--remote-debugging-port=${e}`,"--remote-allow-origins=*"]:[],"--no-sandbox","--disable-blink-features=AutomationControlled","--timezone=America/Los_Angeles",...i?["--headless"]:[],...t?["--disable-web-security","--disable-site-isolation-trials","--disable-features=IsolateOrigins,site-per-process","--allow-running-insecure-content","--ignore-certificate-errors","--ignore-ssl-errors","--ignore-certificate-errors-spki-list"]:[]]}async function oc(e,t){let i=await e.newContext(t);return i.addInitScript(yt),i}async function qn(e){return(await(await fetch(`http://127.0.0.1:${e}/json/version`)).json()).webSocketDebuggerUrl.replace("localhost","127.0.0.1")}async function ac(e,t){let i=await(await fetch(`http://localhost:${e}/json/list`)).json();for(let n of i)if(n.type==="page"&&n.id===t)return n.webSocketDebuggerUrl;throw new Error(`No page found for id: ${t}`)}async function rc(e){let t=await e.context().newCDPSession(e),i=await t.send("Target.getTargetInfo");return await t.detach(),i.targetInfo}async function Mm(e,t){let i=new Set,n=Date.now(),o=new Set(["document","stylesheet","image","font","script","iframe"]),a=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],s=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(g=>p.includes(g))},l=u=>{let p=u.resourceType(),g=u.url();if(!o.has(p)||s(g))return;let f=u.headers();f.purpose==="prefetch"||["video","audio"].includes(f["sec-fetch-dest"])||(i.add(u),n=Date.now())},d=async u=>{let p=u.request();if(!i.has(p))return;let g=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(k=>g.includes(k))){i.delete(p);return}if(![...a].some(k=>g.startsWith(k))){i.delete(p);return}let f=u.headers()["content-length"];if(f)try{if(parseInt(f,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},c=Date.now()-Am;for(let u of await e.requests()){let p=u.resourceType(),g=u.url(),f=u.timing();o.has(p)&&!s(g)&&f.responseEnd===-1&&f.startTime>=c&&(i.add(u),n=Date.now())}h.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",l),e.on("response",d);try{let u=Date.now(),p=Tm;for(;;){await new Promise(f=>setTimeout(f,100));let g=Date.now();if(i.size===0&&g-n>=p){h.debug(`[waitForStableNetwork] Network idle after ${g-u}ms`);break}if(g-u>t){h.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",l),e.removeListener("response",d)}}async function Me(e,t=Em,i=Sm){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),Mm(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 o=Date.now()-n,a=Math.max(i-o,0);a>0&&await new Promise(r=>setTimeout(r,a))}var Zn,Sm,Em,Tm,Am,Ce=y(()=>{"use strict";xt();R();Zn=async(e,t,i)=>{let n=await e.context().newCDPSession(e),o=await n.send("Browser.getWindowForTarget");await n.send("Browser.setWindowBounds",{windowId:o.windowId,bounds:{width:t,height:i,windowState:"normal"}});try{await Promise.race([n.detach(),new Promise((a,r)=>setTimeout(()=>r(new Error("CDP detach timeout")),1e3))])}catch{}},Sm=.5*1e3,Em=30*1e3,Tm=1*1e3,Am=3*1e3});function Cm(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 cc(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let o=i.maxSteps??15,a=3,r=t.agentServices.getModel(),s=t.domService||new ue(t.agentServices.getDomServiceOptions()),l={...t,domService:s};w.init(),w.section("Task Execution Started"),w.log(`Task: ${e}`),w.log(`Max steps: ${o}`),w.log(`Model: ${r}`);let d={currentStep:0,maxSteps:o,consecutiveFailures:0,maxFailures:a,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},c=[],u=Xn(i.customPrompt),p=new Jn(u);w.log(`System prompt length: ${u.length} chars`);let g=!1,f="",k=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:o});d.currentStep<o;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");d.currentStep++;let x=Date.now();w.section(`Step ${d.currentStep}/${o}`),w.log(`URL: ${l.page.url()}`),i.onEvent?.({type:"step_start",step:d.currentStep});try{w.log("Waiting for page to stabilize..."),await Me(l.page),w.log("Page stabilized")}catch{w.log("Page stabilization timed out, continuing anyway")}let m;try{w.log("Preparing context (DOM + screenshot)...");let I=l.agentServices.getInteractiveClassNames(),C=l.agentServices.getIframeFallbackDomains();m=await sc(l.page,l.domService,I,C),w.log("Context prepared")}catch(I){if(I.message.includes("Execution context was destroyed")){w.log("Page navigating, waiting for load..."),await Me(l.page);let C=l.agentServices.getInteractiveClassNames(),D=l.agentServices.getIframeFallbackDomains();m=await sc(l.page,l.domService,C,D)}else throw w.error("Error preparing context",I),I}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,d,{isFinalStep:d.currentStep===o-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let b=await Pm(p,r,i,m.screenshotBase64);if(b.tokenUsages&&b.tokenUsages.length>0&&c.push(...b.tokenUsages),!b.stepOutput){if(w.error("Failed to get valid LLM response"),d.consecutiveFailures++,d.consecutiveFailures>=a){f="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let _=b.stepOutput;Om(d.currentStep,o,_);let v=await Dm(_,l,m.domState,d.currentStep,i.onEvent,m.screenshotBase64,b.debugInfo);k.push(...v.actionEntities);let S=Lm(d.currentStep,_,v,d,x,b.debugInfo,b.tokenUsages),A=Date.now()-x;if(i.onEvent?.({type:"step_complete",step:d.currentStep,duration:A}),d.consecutiveFailures>=a){w.error(`Too many consecutive failures (${d.consecutiveFailures}), stopping`),f=`Reached the maximum allowed consecutive failures. Most recent error: ${d.lastFailReason}`;break}if(v.doneResult){g=v.doneResult.success,f=v.doneResult.summary;break}if(v.completesInstruction){g=!0,f="Instruction completed";break}}return d.currentStep>=o&&!g&&(f="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:d.currentStep,duration:Date.now()-n}),w.log(`Build success result: summary=${f}, completed=${g}, actions=${k.length}, tokens=${c.length}`),Nm(d,k,g,f,n,c,r)}catch(x){let m=x.message;return w.error(`Task execution failed: ${m}`,x),i.onEvent?.({type:"error",error:m,recoverable:!1}),Rm(d,m,n,c,r)}}async function sc(e,t,i,n){let{domState:o,screenshotBase64:a}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=o.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:a,domState:o}}function Im(e){return e.map(t=>({role:t.role,content:Array.isArray(t.content)?t.content.map(i=>{if(i.type==="image"){let n=i.image,o=typeof n=="string"?n:"";return{type:"image",file:o.startsWith("data:")?o:`data:image/png;base64,${o}`}}return{type:"text",text:i.text}}):t.content}))}async function Pm(e,t,i,n){let o=i.temperature??0,{system:a,messages:r}=e.getMessages(),s=0;for(let u of r)Array.isArray(u.content)&&(s+=u.content.filter(p=>p.type==="image").length);let l=be(t,s),d={model:we(t),system:a,messages:r,temperature:o,providerOptions:l},c=3;for(let u=0;u<c;u++)try{let p=Date.now();w.log(`Calling LLM (${t})...`);let g=await(0,lc.generateText)(d),f=Date.now()-p,k=g,x=k.usage;w.llmCall(t,f,x);let m=k.reasoningText;m&&(w.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(g.text);let b={systemPrompt:a,userPrompt:Im(r),rawLlmResponse:g.text,reasoningContent:m,screenshotWithSom:n},_=[],v=Cm(x,t);v&&_.push(v);let S=$m(g.text);if(!S)if(u<c-1){w.log(`Attempt ${u+1}/${c}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(A=>setTimeout(A,i.retryDelay||1e3));continue}else return w.error("All parsing attempts failed"),{stepOutput:null,debugInfo:b,tokenUsages:_};return{stepOutput:S,debugInfo:b,tokenUsages:_}}catch(p){if(u<c-1){w.log(`Attempt ${u+1}/${c}: LLM call failed (${p.message}), retrying...`),await new Promise(g=>setTimeout(g,i.retryDelay||1e3));continue}else throw w.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function $m(e){let t=e.trim();t.startsWith("```json")?t=t.replace(/^```json\s*/,"").replace(/\s*```\s*$/,""):t.startsWith("```")&&(t=t.replace(/^```\s*/,"").replace(/\s*```\s*$/,""));try{let i=JSON.parse(t);if(!i.current_goal)return w.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return w.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return w.error("Action missing required field: action_name"),null;if(!n.description)return w.error("Action missing required field: description"),null}return i}catch(i){return w.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),w.error(`Parse error: ${i.message}`),null}}async function Dm(e,t,i,n,o,a,r){let s=[],l=!0,d=null;w.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let c=null,u={...t,domState:i},p=a;for(let g of e.actions){if(g.action_name==="done"){c={success:g.kwargs.success??!0,summary:g.kwargs.summary||g.kwargs.text||"Task completed"};break}let f={},k=g.kwargs?.element_index??g.kwargs?.index;if(typeof k=="number"){let m=i.selectorMap.get(k);m&&(f=await N(t.page,m))}let x={...f,action_description:g.description,action_data:{action_name:g.action_name,kwargs:g.kwargs}};try{let m=await H.execute(g.action_name,g.kwargs,u);g.action_name==="perform_accurate_operation"&&(x=m.actionEntity);let b=await u.agentServices.getCurrentPage();if(b&&(u.page=b,t.page=u.page),m?.success===!1){l=!1,w.log("Action failed, stopping execution of remaining actions in this step"),d=m.error||"Action execution failed";break}s.push(x),o?.({type:"action",action_entity:x,step:n,debugInfo:r})}catch(m){l=!1,d=m.message,w.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:l,failReason:d,actionEntities:s,doneResult:c,completesInstruction:e.completes_instruction??!1}}function Lm(e,t,i,n,o,a,r){let s={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:o,duration:Date.now()-o,outcome:{success:i.allSuccess},debugInfo:a,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let l=t.memory.trim();n.memory.includes(l)||(n.memory.push(l),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(s),s}function Om(e,t,i){if(w.log(`Step ${e}/${t}`),i.thinking&&w.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&w.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&w.log(`Memory: ${i.memory}`),w.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];w.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else w.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,o)=>{w.log(` ${o+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Nm(e,t,i,n,o,a,r){let s=a.reduce((c,u)=>c+u.prompt_tokens,0),l=a.reduce((c,u)=>c+u.completion_tokens,0),d=a.reduce((c,u)=>c+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-o,model:r,successfulSteps:e.stepHistory.filter(c=>c.outcome.success).length,failedSteps:e.stepHistory.filter(c=>!c.outcome.success).length,promptTokens:s,completionTokens:l,totalTokens:d,tokenUsages:a}}}function Rm(e,t,i,n,o){let a=n.reduce((l,d)=>l+d.prompt_tokens,0),r=n.reduce((l,d)=>l+d.completion_tokens,0),s=n.reduce((l,d)=>l+d.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:o,successfulSteps:e.stepHistory.filter(l=>l.outcome.success).length,failedSteps:e.stepHistory.filter(l=>!l.outcome.success).length,promptTokens:a,completionTokens:r,totalTokens:s,tokenUsages:n}}}var lc,dc=y(()=>{"use strict";ya();Yn();Te();je();ie();Ce();Ee();j();lc=require("ai")});var uc={};Ge(uc,{TaskMessageManager:()=>Jn,formatFinalStepWarning:()=>ic,formatTaskContext:()=>Vn,getBrowserTaskJSONPrompt:()=>Xn,runTaskLoop:()=>cc});var hc=y(()=>{"use strict";dc();ya();Yn();Te();Mn();je();Bt();Gt();dt();Kt();jt();ie();Ce();xt();Ee();$t();Dt();ot();j();Ke();R();te();ut();F();pe()});async function Vt(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(H.has(i)){let o=await H.execute(i,n,t),a=o?.success!==!1,r=o?.error||o?.message;return{success:a,error:a?void 0:r}}else{let{page:o,agentServices:a}=t;return await(await Fm()).execute(o,e,a),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Fm(){if(Qn)return Qn;let e=await Promise.resolve().then(()=>(wt(),ft));return Qn=new e.default,Qn}async function pt(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Vo(r,a,n);return s.status==="error"?{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error,debugInfo:s.debugInfo}:{status:"success",completed:s.goalAccomplished||!1,actionEntities:s.actionEntity?[s.actionEntity]:[],explanation:s.reasoning,debugInfo:s.debugInfo}}async function ze(e,t,i,n={},o){let a=o||{page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),s=await Vo(r,a,n);if(s.status==="error"||!s.actionEntity)return{status:"error",completed:s.goalAccomplished||!1,actionEntities:[],explanation:s.reasoning,error:s.error||"No action generated",debugInfo:s.debugInfo};let{actionEntity:l,reasoning:d,goalAccomplished:c,debugInfo:u}=s,p=await Vt(l,a);return p.success?(d&&i.addNote(d),{status:"success",completed:c||!1,actionEntities:[l],explanation:d,debugInfo:u}):{status:"error",completed:!1,actionEntities:[l],error:p.error||"Action execution failed",debugInfo:u}}async function Ve(e,t,i,n={}){let o={page:t,agentServices:i,domService:new ue(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},a=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),_s(a,o,n)}async function Xe(e,t,i,n,o={}){let{runTaskLoop:a}=await Promise.resolve().then(()=>(hc(),uc)),r=n?l=>{n(l)}:void 0,s=await a(e,{page:t,agentServices:i,domService:void 0,executionHistory:o.executionHistory,variables:o.variables,sensitiveKeys:o.sensitiveKeys},{maxSteps:o.maxSteps,onEvent:r,abortSignal:o.abortSignal});return{status:s.success?"success":"error",completed:s.completed,actionEntities:s.trajectory.actions,explanation:s.summary,error:s.error,tokenUsages:s.metadata.tokenUsages}}var Qn,Xt=y(()=>{"use strict";pn();Te();je();Qn=null});function mc(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:Hm,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,o={page:i.page,agentServices:i.agentServices,domService:i.domService},a=await rt(n,o,{});if(a.status==="error"||!a.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:a.error||"Failed to generate action"};let{actionEntity:r}=a,s=await Vt(r,o);return{success:s.success,actionEntity:r,message:s.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:s.error}}})}var xa,Hm,va=y(()=>{"use strict";Xt();st();xa=require("zod"),Hm=xa.z.object({instruction:xa.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')})});async function Wm(e,t,i){let{apiKey:n,domain:o}=e;if(!n||!o)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let a=[];try{let r=`https://api.mailgun.net/v3/${o}/events`,s={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(s.from=i.from_email),i.since)s.begin=Math.floor(i.since/1e3).toString();else{let c=new Date(Date.now()-6e5);s.begin=Math.floor(c.getTime()/1e3).toString()}h.info(`Mailgun params: ${JSON.stringify(s)}`);let l=await fetch(r+"?"+new URLSearchParams(s),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!l.ok){let c=await l.text();throw new Error(`Mailgun events API error: ${c}`)}let d=(await l.json()).items||[];for(let c of d.slice(0,10)){if(c.event!=="accepted")continue;let u=(c.storage||{}).url;if(h.info(`message_url: ${u}`),!u){let f=(c.message||{}).headers||{},k=f.subject||"",x=f.from||"",m=f.to||"";if(i.from_email&&!x.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!m.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!k.toLowerCase().includes(i.subject.toLowerCase()))continue;a.push({subject:k,from:x,to:m,date:new Date(c.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:f["message-id"]||""});continue}let p=u.split("/"),g=p[p.length-1];if(h.info(`Storage key: ${g}`),g){let f=`https://api.mailgun.net/v3/domains/${o}/messages/${g}`;try{let k=await fetch(f,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(k.ok){let x=await k.json(),m=x.Subject||"",b=x.From||"",_=x.To||"",v=x.Date||"",S=x["Message-Id"]||"";h.info(`subject: ${m}`),h.info(`from_addr: ${b}`),h.info(`to_addr: ${_}`),h.info(`date: ${v}`),h.info(`message_id: ${S}`);let A=x["body-html"]||x["body-plain"]||"";if(A&&A.includes("<")&&(A=(0,gc.convert)(A)),h.info(`Body: ${A.substring(0,200)}...`),i.subject&&!m.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!A.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:m,from:b,to:_,date:v,body:A,message_id:S});continue}else h.warn(`Messages API returned ${k.status}`)}catch(k){h.warn(`Failed to parse JSON response: ${k}`)}}try{let f=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!f.ok){h.warn(`Could not fetch stored message: ${f.status}`);continue}let k=await f.text();h.info(`Fallback: Raw email length: ${k.length}`);let x=k.split(`
4358
+ `),m=!0,b={},_="";for(let D=0;D<x.length;D++){let K=x[D];if(K.trim()===""&&m){m=!1;continue}if(m){let Q=K.match(/^([^:]+):\s*(.+)$/);Q&&(b[Q[1].toLowerCase()]=Q[2])}else _+=K+`
4359
+ `}let v=b.subject||"",S=b.from||"",A=b.to||"",I=b.date||"",C=b["message-id"]||"";if(i.subject&&!v.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!_.toLowerCase().includes(i.body_contains.toLowerCase()))continue;a.push({subject:v,from:S,to:A,date:I,body:_.trim(),message_id:C})}catch(f){h.warn(`Error fetching raw message: ${f}`)}}if(a.length>0){try{a.sort((u,p)=>{let g=new Date(u.date).getTime();return new Date(p.date).getTime()-g})}catch{}let c=a[0];return h.info(`Returning most recent email: ${c.subject}`),[c]}return a}catch(r){throw h.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Bm(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
4362
4360
 
4363
4361
  Please carefully examine the email content and look for:
4364
4362
  1. Numeric codes (usually 4-8 digits)
@@ -4415,29 +4413,29 @@ Examples of what to extract:
4415
4413
  Extract: https://service.com/v/longtoken123456789abcdefghijklmnopqrstuvwxyz?param1=value1&param2=value2
4416
4414
 
4417
4415
  Return ONLY the complete extracted URL or "NOT_FOUND".`;if(e==="custom"){if(!t)throw new Error("Custom prompt is required when extraction_type is custom");return t+`
4418
- Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Mm(e,t,i){try{let n=`${t}
4416
+ Return only the required content or 'NOT_FOUND'.`}else throw new Error(`Unsupported extraction type: ${e}`)}async function Um(e,t,i){try{let n=`${t}
4419
4417
  ---
4420
4418
  Email Content:
4421
4419
  ---
4422
4420
  ${e}
4423
4421
  ---
4424
- `,a=be(i);return(await(0,oc.generateText)({model:a,messages:[{role:"user",content:n}],temperature:0,providerOptions:ye(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw h.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function sc(e,t){h.info(`extract_email_content:
4422
+ `,o=we(i);return(await(0,pc.generateText)({model:o,messages:[{role:"user",content:n}],temperature:0,providerOptions:be(i,0)})).text.trim()||"NOT_FOUND"}catch(n){throw h.error(`Error in LLM extraction: ${n.message}`),new Error(`Error in LLM extraction: ${n.message}`)}}async function fc(e,t){h.info(`extract_email_content:
4425
4423
  forward_email: ${t.forward_email}
4426
4424
  extraction_type: ${t.extraction_type}
4427
4425
  filters: ${JSON.stringify(t.filters||{})}
4428
4426
  timeout: ${t.timeout||60}
4429
- polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let a=Am(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),s=0;for(h.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,h.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await Tm(e,t.forward_email,d);if(c.length>0){h.info(`Found ${c.length} emails matching criteria`);let u=[];for(let p of c){let g=`Subject: ${p.subject}
4427
+ polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let o=Bm(t.extraction_type,t.prompt),a=new Date,r=new Date(a.getTime()+i*1e3),s=0;for(h.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){s++,h.info(`Polling attempt ${s}`);try{let d=t.filters||{},c=await Wm(e,t.forward_email,d);if(c.length>0){h.info(`Found ${c.length} emails matching criteria`);let u=[];for(let p of c){let g=`Subject: ${p.subject}
4430
4428
  From: ${p.from}
4431
4429
  To: ${p.to}
4432
4430
  Date: ${p.date}
4433
4431
 
4434
4432
  Body:
4435
- ${p.body}`,w=await Mm(g,a,t.model);h.info(`Extracted content: ${w}`),w&&w!=="NOT_FOUND"&&u.push({content:w,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=u[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let w=(new Date().getTime()-o.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${w.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${s})`}}else h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(a){return h.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}var oc,rc,bo=b(()=>{"use strict";Ee();R();oc=require("ai"),rc=require("html-to-text")});function lc(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}function dc(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:Im,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:p,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let w={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(p,w,g);let k=lc(o);return{success:!0,actionEntity:w,message:`Extracted ${o} and saved to $${k}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:w.message}}}}})}var ve,cc,Im,yo=b(()=>{"use strict";bo();R();ie();ve=require("zod");cc=class{getMailgunConfig(){let e=G().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await sc(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||lc(o.extraction_type);i.variableStore.set(l,s.data),h.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},Im=ve.z.object({forward_email:ve.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:ve.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:ve.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:ve.z.string().optional().describe("Filter emails by sender address"),filter_to_email:ve.z.string().optional().describe("Filter emails by recipient address"),filter_subject:ve.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:ve.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:ve.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ke(){if(Jn)return Jn;let e=(await Promise.resolve().then(()=>(ft(),gt))).default;return Jn=new e,Jn}async function qn(e){let t=await ke(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return zl(e,i),El(e,n),ll(e,a),Dl(e,o),"Click, hover, double-click, right-click, or drag elements"}async function Zn(e){let t=await ke(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return _l(e,i),kl(e,n),rl(e,a),"Navigate to URLs, go back, or reload the page"}async function Qn(e){let t=await ke(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Kl(e,i),Al(e,n),nl(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function ea(e){let t=await ke(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return pl(e,i),fl(e,n),ul(e,a),"Scroll the page or scroll to specific text/elements"}async function ta(e){let t=await ke(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Il(e,i),zs(e,n),"Switch between browser tabs or close tabs"}async function ia(e){let t=await ke(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return Zs(e,i),il(e,n),"Upload files or wait for downloads to complete"}async function na(e){let t=await ke(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return yl(e,i),Gs(e,n),Ks(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function aa(e){let t=await ke(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return el(e,i),dl(e,n),$l(e,a),ac(e),"Wait for conditions, save variables, or complete tasks"}async function oa(e){let t=(await ke()).getAction("generate_2fa_code");Ol(e,t);let i=new cc;return(await Promise.resolve().then(()=>(ft(),gt))).default.registerAction("extract_email_content",i),dc(e,i),"Generate 2FA codes or extract email/activation codes"}async function ra(e){let t=await ke(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return Hl(e,i),Bl(e,n),Hs(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}async function uc(e){let[t,i,n,a,o,r,s,l,d,c]=await Promise.all([qn(e),Zn(e),Qn(e),ea(e),ta(e),ia(e),na(e),aa(e),oa(e),ra(e)]);return{mouse:t,navigation:i,input:n,scroll:a,tabs:o,files:r,forms:s,utility:l,auth:d,ai:c}}function hc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
4436
- `)}var Jn,xo=b(()=>{"use strict";wo();yo();Vt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();li();ci();di();ui();hi();pi();gi();wi();bi();yi();xi();vi();ki();_i();Si();Ei();Jn=null});async function mc(){await $m}function pc(){return H}function gc(e=!0){let t=new st;return e&&(qn(t),Zn(t),Qn(t),ea(t),ta(t),ia(t),na(t),oa(t),aa(t),ra(t)),t}async function fc(){let e=new st,t=await uc(e),i=hc(t);return{registry:e,capabilities:t,summary:i}}function wc(){return["- Mouse: Click, hover, double-click, right-click or drag on elements","- Navigation: Navigate to URLs, go back, or reload the page","- Input: Type text into inputs, clear input fields, or press keyboard keys","- Scroll: Scroll the page or scroll to specific text/elements","- Tabs: Switch between browser tabs or close tabs","- Files: Upload files or wait for downloads to complete","- Forms: Get dropdown options or select dropdown values","- Utility: Wait for conditions, save variables, or complete tasks","- Auth: Generate 2FA codes or extract email/activation codes","- AI: Perform AI-powered verifications, extractions, or wait conditions"].join(`
4437
- `)}var Cm,$m,bc=b(()=>{"use strict";xo();Te();Cm=[qn(H),Zn(H),Qn(H),ea(H),ta(H),ia(H),na(H),aa(H),ra(H),oa(H)],$m=Promise.all(Cm)});function xc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:Qi(t.schema)}))}var yc,vc=b(()=>{"use strict";Dt();yc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:Qi(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:Qi(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var kc=b(()=>{"use strict"});function la(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var U0,_,z0,ek,nk,Pm,ca,Dm,Lm,Om,Nm,Rm,Fm,Hm,Wm,Ye,xt,Sc,Bm,sa,Mi,B0,G0,da,Ec,Tc,Ac,Mc,Ii,vo,ko,Gm,_c,Um,Ai,Km,jm,zm,le,Vm,Xm,j0,ik,vt=b(()=>{"use strict";fe();U0=require("uuid"),_=require("zod"),z0=require("yaml"),ek=require("uuid"),nk=require("yaml");Pm="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",ca=112,Dm=1920,Lm=1080,Om=1920,Nm=1080-ca,Rm=1280,Fm=720,Hm=500,Wm=500,Ye="Desktop Chrome",xt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(xt||{}),Sc={"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"}},Bm={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"]},sa=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Bm[e].map(n=>Sc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Mi=e=>Sc[e],B0={desktop:{label:"Desktop",type:"desktop",devices:sa("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:sa("mobile")}},G0={desktop:{label:"Desktop",type:"desktop",devices:sa("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:sa("mobile",!0)}},da=(e,t=!1)=>{let i={userAgent:Pm,viewport:{width:Om,height:Nm},isMobile:!1,hasTouch:!1};if(!e||e===Ye)return i;let n=Mi(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(Hm/a,1),s=Math.max(Wm/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Ec=e=>{let t={width:Dm,height:Lm};if(!e||e===Ye)return t;let i=da(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+ca}:t},Tc=e=>{let t={width:Rm,height:Fm};if(!e||e===Ye)return t;let i=da(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Ac=e=>!e||e===Ye?void 0:Mi(e)?.channel,Mc=e=>!e||e===Ye?"chromium":Mi(e)?.defaultBrowserType??"chromium",Ii=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ii||{}),vo=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(vo||{}),ko=class Ic{constructor(){Oa(this,"data",{}),Oa(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Ic;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}},Gm=_.z.enum(["JS_CODE","AI_MODE"]),_c=_.z.object({type:Gm,expression:_.z.string()}),Um=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ai=_.z.object({uid:_.z.string(),type:Um,comment:_.z.string().optional()}),Km=_.z.object({action_data:_.z.object({action_name:_.z.string(),kwargs:_.z.record(_.z.any()).optional(),args:_.z.array(_.z.any()).optional()}),action_description:_.z.string().optional(),url:_.z.string().optional(),xpath:_.z.string().nullable().optional(),locator:_.z.string().nullable().optional(),css_selector:_.z.string().nullable().optional(),unique_selector:_.z.string().nullable().optional(),element_index:_.z.number().nullable().optional(),frame_path:_.z.array(_.z.any()).optional(),artifacts:_.z.record(_.z.any()).optional(),feedback:_.z.string().optional(),original_browser_use_action:_.z.any().optional()}).passthrough(),jm=Ai.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),zm=Ai.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:Km.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),le=_.z.lazy(()=>_.z.union([jm,zm,Ai.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(le),reference_id:_.z.number().optional()}),Ai.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:_c,then:_.z.array(le),else:_.z.array(le).optional()}),Ai.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:_c,body:_.z.array(le),timeout_ms:_.z.number().optional()})])),Vm=_.z.object({name:_.z.string(),statements:_.z.array(le),teardown:_.z.array(le).optional(),skip:_.z.union([_.z.boolean(),_.z.string()]).optional(),timeout:_.z.number().optional(),fail:_.z.union([_.z.boolean(),_.z.string()]).optional(),only:_.z.boolean().optional(),slow:_.z.boolean().optional()}),Xm=_.z.object({tests:_.z.array(Vm).min(1),beforeAll:_.z.array(le).optional(),afterAll:_.z.array(le).optional(),beforeEach:_.z.array(le).optional(),afterEach:_.z.array(le).optional()}),j0=_.z.object({comment:_.z.string().optional(),version:_.z.string().optional(),goal:_.z.string().optional(),url:_.z.string().optional(),baseURL:_.z.string().optional(),final_feedback:_.z.string().optional(),completed:_.z.boolean().optional(),success:_.z.boolean().optional(),statements:_.z.array(le).optional(),teardown:_.z.array(le).optional(),last_modified_at:_.z.string().optional(),testGroup:Xm.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"}),ik=1024*1024});async function Ym(e,t){let i=JSON.parse(Oe.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Oe,Cc,kt,Je,$c,Pc=b(()=>{"use strict";vt();Ie();yt();R();Oe=W(require("fs"),1),Cc=W(require("os"),1),kt=W(require("path"),1),Je=require("playwright");$c=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=kt.default.join(e.testDir,"videos"),this.statesBasePath=kt.default.join(e.testDir,"states"),this.downloadsBasePath=kt.default.join(e.testDir,"downloads"),Oe.default.mkdirSync(this.videoBasePath,{recursive:!0}),Oe.default.mkdirSync(this.statesBasePath,{recursive:!0}),Oe.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Mc(e.deviceName),a=Ac(e.deviceName),o=n===xt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(o){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let v=[];(e.enableCamera||e.enableMicrophone)&&(v.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(v.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let E=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...Xl(t,e.disableSecurity??!0,i),...v,...E,...this.additionalArgs],a&&(s.channel=a,h.debug(`[BrowserManager] Launching browser with channel: ${a}`))}let l=da(e.deviceName),d=Tc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&o?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy);let p,g,w,k=!1;if(o&&(r||e.userDataDir)){if(e.userDataDir)w=e.userDataDir;else{let E=this.testDir||Oe.default.mkdtempSync(kt.default.join(Cc.default.tmpdir(),"shiplight-"));w=kt.default.join(E,`ext-profile-${Date.now()}`),Oe.default.mkdirSync(w,{recursive:!0}),k=!0}let v={...s,...c};g=await Je.chromium.launchPersistentContext(w,v),u&&(await Ym(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),p=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${w}`}`)}else{switch(n){case xt.Firefox:p=await Je.firefox.launch(s);break;case xt.Webkit:p=await Je.webkit.launch(s);break;case xt.Chromium:default:p=await Je.chromium.launch(s);break}g=await p.newContext(c)}if(g.addInitScript(bt),o){let v=["clipboard-read","clipboard-write"];e.enableCamera&&v.push("camera"),e.enableMicrophone&&v.push("microphone");try{await g.grantPermissions(v),h.info(`[BrowserManager] Granted permissions: ${v.join(", ")}`)}catch(E){h.warn("[BrowserManager] Failed to grant permissions:",E)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let v=(Date.now()+31536e6)/1e3,E=e.cookies.map(A=>({...A,expires:v}));await g.addCookies(E),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${v}`)}let y=e.viewport,m=y?{width:y.width,height:y.height+ca}:Ec(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),o){let v=async E=>{try{await Xn(E,m.width,m.height),y&&await E.setViewportSize(y)}catch(A){h.warn("[BrowserManager] Failed to set window bounds via CDP:",A)}};for(let E of g.pages())await v(E);g.on("page",v)}let x="";if(o&&t!==void 0)try{x=await Vn(t)}catch(v){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",v)}let T={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:x,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:w,isTempUserDataDir:k};if(this.terminationTimeout!==null){let v=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(T).catch(E=>h.error("[BrowserManager] Error terminating browser:",E))},this.terminationTimeout);T.timeout=v}return T}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Oe.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var Dc,Lc=b(()=>{"use strict";vt();Dc=e=>{if(!e||e===Ye)return"desktop";let t=Mi(e);return t&&t.isMobile?"mobile":"desktop"}});var Jm,Oc=b(()=>{"use strict";Jm=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Jm||{})});async function Nc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4433
+ ${p.body}`,f=await Um(g,o,t.model);h.info(`Extracted content: ${f}`),f&&f!=="NOT_FOUND"&&u.push({content:f,email_subject:p.subject,email_from:p.from,email_date:p.date})}if(u.length>0){let p=u[0],g=`$email_${t.extraction_type}`;t.extraction_type==="custom"?g="$email_extracted_content":t.extraction_type==="activation_link"?g="$email_magic_link":t.extraction_type==="verification_code"&&(g="$email_otp_code");let f=(new Date().getTime()-a.getTime())/1e3;return h.info(`Successfully extracted content after ${s} attempts in ${f.toFixed(1)} seconds`),{data:p.content,result_variable:g,status:"success",message:`Successfully extracted content from email: ${p.email_subject.substring(0,50)}... (attempts: ${s})`}}else h.info(`Found emails but no extractable content in attempt ${s}`)}else h.info(`No emails found in attempt ${s}`)}catch(d){h.warn(`Error in polling attempt ${s}: ${d.message}`)}if(new Date(Date.now()+n*1e3)>=r){h.info("Not enough time for another polling attempt");break}h.info(`Waiting ${n} seconds before next attempt...`),await new Promise(d=>setTimeout(d,n*1e3))}let l=(new Date().getTime()-a.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${s} attempts over ${l.toFixed(1)} seconds`}}catch(o){return h.error(`Error extracting email content: ${o.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${o.message}`}}}var pc,gc,ka=y(()=>{"use strict";Ee();R();pc=require("ai"),gc=require("html-to-text")});function wc(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}function yc(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:Gm,async execute(i,n){let{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}=i,{page:p,agentServices:g}=n;h.info(`[extract_email_content] Extracting ${a} from ${o}`);try{let f={action_description:`Extract ${a} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}}};await t.execute(p,f,g);let k=wc(a);return{success:!0,actionEntity:f,message:`Extracted ${a} and saved to $${k}`}}catch(f){return{success:!1,error:f.message,actionEntity:{action_description:`Extract ${a} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:o,extraction_type:a,prompt:r,filter_from_email:s,filter_to_email:l,filter_subject:d,filter_body_contains:c,timeout:u}},feedback:f.message}}}}})}var xe,bc,Gm,_a=y(()=>{"use strict";ka();R();te();xe=require("zod");bc=class{getMailgunConfig(){let e=U().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let o=this.getMailgunConfig();if(!o)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let a=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",s=await fc(o,{model:r,forward_email:a.forward_email,extraction_type:a.extraction_type,prompt:a.prompt,filters:{from_email:a.filter_from_email,to_email:a.filter_to_email,subject:a.filter_subject,body_contains:a.filter_body_contains},timeout:a.timeout});if(s.status==="success"&&s.data){let l=s.result_variable?.replace(/^\$/,"")||wc(a.extraction_type);i.variableStore.set(l,s.data),h.info(`[extract_email_content] Extracted and saved to ${l}`)}else throw new Error(s.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},Gm=xe.z.object({forward_email:xe.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:xe.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:xe.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:xe.z.string().optional().describe("Filter emails by sender address"),filter_to_email:xe.z.string().optional().describe("Filter emails by recipient address"),filter_subject:xe.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:xe.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:xe.z.number().optional().describe("Timeout in seconds for polling (default: 60)")})});async function ve(){if(eo)return eo;let e=(await Promise.resolve().then(()=>(wt(),ft))).default;return eo=new e,eo}async function to(e){let t=await ve(),i=t.getAction("click"),n=t.getAction("hover"),o=t.getAction("right_click"),a=t.getAction("double_click");return tc(e,i),Ll(e,n),wl(e,o),Ul(e,a),"Click, hover, double-click, right-click, or drag elements"}async function io(e){let t=await ve(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),o=t.getAction("reload_page");return $l(e,i),Pl(e,n),gl(e,o),"Navigate to URLs, go back, or reload the page"}async function no(e){let t=await ve(),i=t.getAction("clear_input"),n=t.getAction("input_text"),o=t.getAction("press");return Ql(e,i),Nl(e,n),hl(e,o),"Type text into inputs, clear input values, or press keyboard keys"}async function oo(e){let t=await ve(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),o=t.getAction("scroll");return _l(e,i),El(e,n),xl(e,o),"Scroll the page or scroll to specific text/elements"}async function ao(e){let t=await ve(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Fl(e,i),tl(e,n),"Switch between browser tabs or close tabs"}async function ro(e){let t=await ve(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return sl(e,i),ul(e,n),"Upload files or wait for downloads to complete"}async function so(e){let t=await ve(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),o=t.getAction("set_date_for_native_date_picker");return Ml(e,i),qs(e,n),Qs(e,o),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function lo(e){let t=await ve(),i=t.getAction("wait"),n=t.getAction("save_variable"),o=t.getAction("done");return cl(e,i),yl(e,n),Wl(e,o),mc(e),"Wait for conditions, save variables, or complete tasks"}async function co(e){let t=(await ve()).getAction("generate_2fa_code");Kl(e,t);let i=new bc;return(await Promise.resolve().then(()=>(wt(),ft))).default.registerAction("extract_email_content",i),yc(e,i),"Generate 2FA codes or extract email/activation codes"}async function uo(e){let t=await ve(),i=t.getAction("verify"),n=t.getAction("ai_extract"),o=t.getAction("ai_wait_until");return Xl(e,i),Jl(e,n),Xs(e,o),"Perform AI-powered assertions, extractions, or wait conditions"}async function xc(e){let[t,i,n,o,a,r,s,l,d,c]=await Promise.all([to(e),io(e),no(e),oo(e),ao(e),ro(e),so(e),lo(e),co(e),uo(e)]);return{mouse:t,navigation:i,input:n,scroll:o,tabs:a,files:r,forms:s,utility:l,auth:d,ai:c}}function vc(e){return[`- Mouse: ${e.mouse}`,`- Navigation: ${e.navigation}`,`- Input: ${e.input}`,`- Scroll: ${e.scroll}`,`- Tabs: ${e.tabs}`,`- Files: ${e.files}`,`- Forms: ${e.forms}`,`- Utility: ${e.utility}`,`- Auth: ${e.auth}`,`- AI: ${e.ai}`].join(`
4434
+ `)}var eo,Sa=y(()=>{"use strict";va();_a();Yt();qt();Qt();ei();ii();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();fi();wi();yi();xi();vi();ki();_i();Si();Ei();Ti();Ai();eo=null});async function kc(){await jm}function _c(){return H}function Sc(e=!0){let t=new lt;return e&&(to(t),io(t),no(t),oo(t),ao(t),ro(t),so(t),co(t),lo(t),uo(t)),t}async function Ec(){let e=new lt,t=await xc(e),i=vc(t);return{registry:e,capabilities:t,summary:i}}function Tc(){return["- Mouse: Click, hover, double-click, right-click or drag on elements","- Navigation: Navigate to URLs, go back, or reload the page","- Input: Type text into inputs, clear input fields, or press keyboard keys","- Scroll: Scroll the page or scroll to specific text/elements","- Tabs: Switch between browser tabs or close tabs","- Files: Upload files or wait for downloads to complete","- Forms: Get dropdown options or select dropdown values","- Utility: Wait for conditions, save variables, or complete tasks","- Auth: Generate 2FA codes or extract email/activation codes","- AI: Perform AI-powered verifications, extractions, or wait conditions"].join(`
4435
+ `)}var Km,jm,Ac=y(()=>{"use strict";Sa();Te();Km=[to(H),io(H),no(H),oo(H),ao(H),ro(H),so(H),lo(H),uo(H),co(H)],jm=Promise.all(Km)});function Cc(e){return e.getTools().map(t=>({name:t.name,description:t.description,inputSchema:on(t.schema)}))}var Mc,Ic=y(()=>{"use strict";Ot();Mc=class{constructor(e,t){this.registry=e,this.getContext=t}getToolDefinitions(){return this.registry.getTools().filter(e=>e.availability.mcp).map(e=>({name:e.name,description:e.description,inputSchema:on(e.schema)}))}getToolDefinitionsFiltered(e){let t=new Set(e);return this.registry.getTools().filter(i=>t.has(i.name)&&i.availability.mcp).map(i=>({name:i.name,description:i.description,inputSchema:on(i.schema)}))}async createServer(e="web-sdk-tools"){throw new Error("MCP server creation not yet implemented. Install and configure an MCP SDK like @modelcontextprotocol/sdk")}async executeTool(e,t){let i=await this.getContext(),n=await this.registry.execute(e,t,i);return{content:[{type:"text",text:n.success?n.message||"Tool executed successfully":n.error||"Tool execution failed"}]}}getToolCount(){return this.registry.size()}getToolNames(){return this.registry.getToolNames()}}});var Pc=y(()=>{"use strict"});function go(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var E,sk,gk,bk,vk,zm,mo,Vm,Xm,Ym,Jm,qm,Zm,Qm,ep,Ye,vt,Dc,tp,ho,Ii,ok,ak,po,Lc,Oc,Nc,Rc,Pi,Ea,Ta,ip,$c,np,Ci,op,ap,rp,re,sp,lp,rk,wk,kt=y(()=>{"use strict";pe();E=require("zod"),sk=require("yaml"),gk=require("uuid"),bk=require("yaml"),vk=require("uuid"),zm="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",mo=112,Vm=1920,Xm=1080,Ym=1920,Jm=1080-mo,qm=1280,Zm=720,Qm=500,ep=500,Ye="Desktop Chrome",vt=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(vt||{}),Dc={"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"}},tp={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"]},ho=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),tp[e].map(n=>Dc[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Ii=e=>Dc[e],ok={desktop:{label:"Desktop",type:"desktop",devices:ho("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:ho("mobile")}},ak={desktop:{label:"Desktop",type:"desktop",devices:ho("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:ho("mobile",!0)}},po=(e,t=!1)=>{let i={userAgent:zm,viewport:{width:Ym,height:Jm},isMobile:!1,hasTouch:!1};if(!e||e===Ye)return i;let n=Ii(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(Qm/o,1),s=Math.max(ep/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},Lc=e=>{let t={width:Vm,height:Xm};if(!e||e===Ye)return t;let i=po(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+mo}:t},Oc=e=>{let t={width:qm,height:Zm};if(!e||e===Ye)return t;let i=po(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Nc=e=>!e||e===Ye?void 0:Ii(e)?.channel,Rc=e=>!e||e===Ye?"chromium":Ii(e)?.defaultBrowserType??"chromium",Pi=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Pi||{}),Ea=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Ea||{});Ta=class Fc{constructor(){Wo(this,"data",{}),Wo(this,"sensitive",new Set)}get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new Fc;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}},ip=E.z.enum(["JS_CODE","AI_MODE"]),$c=E.z.object({type:ip,expression:E.z.string()}),np=E.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Ci=E.z.object({uid:E.z.string(),type:np,comment:E.z.string().optional()}),op=E.z.object({action_data:E.z.object({action_name:E.z.string(),kwargs:E.z.record(E.z.any()).optional(),args:E.z.array(E.z.any()).optional()}),action_description:E.z.string().optional(),url:E.z.string().optional(),xpath:E.z.string().nullable().optional(),locator:E.z.string().nullable().optional(),css_selector:E.z.string().nullable().optional(),unique_selector:E.z.string().nullable().optional(),element_index:E.z.number().nullable().optional(),frame_path:E.z.array(E.z.any()).optional(),artifacts:E.z.record(E.z.any()).optional(),feedback:E.z.string().optional(),original_browser_use_action:E.z.any().optional()}).passthrough(),ap=Ci.extend({type:E.z.literal("DRAFT"),description:E.z.string()}),rp=Ci.extend({type:E.z.literal("ACTION"),description:E.z.string(),action_entity:op.optional(),locator:E.z.string().optional(),use_pure_vision:E.z.boolean().optional()}),re=E.z.lazy(()=>E.z.union([ap,rp,Ci.extend({type:E.z.literal("STEP"),description:E.z.string().optional().default(""),statements:E.z.array(re),reference_id:E.z.number().optional()}),Ci.extend({type:E.z.literal("IF_ELSE"),description:E.z.string().optional(),condition:$c,then:E.z.array(re),else:E.z.array(re).optional()}),Ci.extend({type:E.z.literal("WHILE_LOOP"),description:E.z.string().optional(),condition:$c,body:E.z.array(re),timeout_ms:E.z.number().optional()})])),sp=E.z.object({name:E.z.string(),statements:E.z.array(re),teardown:E.z.array(re).optional(),skip:E.z.union([E.z.boolean(),E.z.string()]).optional(),timeout:E.z.number().optional(),fail:E.z.union([E.z.boolean(),E.z.string()]).optional(),only:E.z.boolean().optional(),slow:E.z.boolean().optional()}),lp=E.z.object({tests:E.z.array(sp).min(1),beforeAll:E.z.array(re).optional(),afterAll:E.z.array(re).optional(),beforeEach:E.z.array(re).optional(),afterEach:E.z.array(re).optional()}),rk=E.z.object({comment:E.z.string().optional(),version:E.z.string().optional(),goal:E.z.string().optional(),url:E.z.string().optional(),baseURL:E.z.string().optional(),final_feedback:E.z.string().optional(),completed:E.z.boolean().optional(),success:E.z.boolean().optional(),statements:E.z.array(re).optional(),teardown:E.z.array(re).optional(),last_modified_at:E.z.string().optional(),testGroup:lp.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"}),wk=1024*1024});async function cp(e,t){let i=JSON.parse(Oe.default.readFileSync(t,"utf-8"));i.cookies?.length&&await e.addCookies(i.cookies)}var Oe,Hc,_t,Je,Wc,Bc=y(()=>{"use strict";kt();Ce();xt();R();Oe=W(require("fs"),1),Hc=W(require("os"),1),_t=W(require("path"),1),Je=require("playwright");Wc=class{constructor(e={}){e.testDir&&(this.testDir=e.testDir,this.videoBasePath=_t.default.join(e.testDir,"videos"),this.statesBasePath=_t.default.join(e.testDir,"states"),this.downloadsBasePath=_t.default.join(e.testDir,"downloads"),Oe.default.mkdirSync(this.videoBasePath,{recursive:!0}),Oe.default.mkdirSync(this.statesBasePath,{recursive:!0}),Oe.default.mkdirSync(this.downloadsBasePath,{recursive:!0})),this.terminationTimeout=e.terminationTimeout??null,this.defaultHeadless=e.headless??!1,this.additionalArgs=e.additionalArgs??[]}async launchBrowser(e={}){let t=e.debugPort,i=e.headless??this.defaultHeadless,n=Rc(e.deviceName),o=Nc(e.deviceName),a=n===vt.Chromium,r=!!e.extensionPath;h.info(`[BrowserManager] Launching ${n} browser for device: ${e.deviceName||"default"}${t?` on port ${t}`:""}`);let s={headless:i};if(a){r&&i&&(h.warn("[BrowserManager] Extension requested in headless mode; forcing headed mode to load extension."),i=!1,s.headless=!1);let v=[];(e.enableCamera||e.enableMicrophone)&&(v.push("--use-fake-device-for-media-stream","--use-fake-ui-for-media-stream"),e.enableMicrophone&&e.fakeAudioCapturePath&&(v.push(`--use-file-for-fake-audio-capture=${e.fakeAudioCapturePath}`),h.info(`[BrowserManager] Using fake audio capture file: ${e.fakeAudioCapturePath}`)));let S=r&&e.extensionPath?[`--disable-extensions-except=${e.extensionPath}`,`--load-extension=${e.extensionPath}`]:[];s.args=[...nc(t,e.disableSecurity??!0,i),...v,...S,...this.additionalArgs],o&&(s.channel=o,h.debug(`[BrowserManager] Launching browser with channel: ${o}`))}let l=po(e.deviceName),d=Oc(e.deviceName),c={acceptDownloads:!0,...l,timezoneId:e.timezoneId||"America/Los_Angeles",locale:e.locale||"en-US"};e.viewport&&(c.viewport=e.viewport,c.screen=e.viewport),e.isMobile!==void 0&&(c.isMobile=e.isMobile),e.hasTouch!==void 0&&(c.hasTouch=e.hasTouch),e.userAgent&&(c.userAgent=e.userAgent),e.colorScheme&&(c.colorScheme=e.colorScheme),e.geolocation&&(c.geolocation=e.geolocation,c.permissions=[...c.permissions||[],"geolocation"]);let u=r&&a?e.localStorageStatePath:void 0;e.localStorageStatePath&&!u&&(c.storageState=e.localStorageStatePath),e.recordVideo&&this.videoBasePath&&(c.recordVideo={dir:this.videoBasePath,size:{width:d.width,height:d.height}}),e.proxy&&(c.proxy=e.proxy),e.extraHTTPHeaders&&Object.keys(e.extraHTTPHeaders).length>0&&(c.extraHTTPHeaders=e.extraHTTPHeaders);let p,g,f,k=!1;if(a&&(r||e.userDataDir)){if(e.userDataDir)f=e.userDataDir;else{let S=this.testDir||Oe.default.mkdtempSync(_t.default.join(Hc.default.tmpdir(),"shiplight-"));f=_t.default.join(S,`ext-profile-${Date.now()}`),Oe.default.mkdirSync(f,{recursive:!0}),k=!0}let v={...s,...c};g=await Je.chromium.launchPersistentContext(f,v),u&&(await cp(g,u),h.info(`[BrowserManager] Loaded storage state into persistent context from ${u}`)),p=g.browser(),h.info(`[BrowserManager] Launched persistent context${e.extensionPath?` for extension at ${e.extensionPath}`:` with profile at ${f}`}`)}else{switch(n){case vt.Firefox:p=await Je.firefox.launch(s);break;case vt.Webkit:p=await Je.webkit.launch(s);break;case vt.Chromium:default:p=await Je.chromium.launch(s);break}g=await p.newContext(c)}if(g.addInitScript(yt),a){let v=["clipboard-read","clipboard-write"];e.enableCamera&&v.push("camera"),e.enableMicrophone&&v.push("microphone");try{await g.grantPermissions(v),h.info(`[BrowserManager] Granted permissions: ${v.join(", ")}`)}catch(S){h.warn("[BrowserManager] Failed to grant permissions:",S)}}else(e.enableCamera||e.enableMicrophone)&&h.warn("[BrowserManager] Camera/microphone enabled but browser is not Chromium; ignoring.");if(e.cookies&&e.cookies.length>0){let v=(Date.now()+31536e6)/1e3,S=e.cookies.map(A=>({...A,expires:v}));await g.addCookies(S),h.info(`[BrowserManager] Added ${e.cookies.length} cookies to browser context with expires=${v}`)}let x=e.viewport,m=x?{width:x.width,height:x.height+mo}:Lc(e.deviceName);if(h.info(`[BrowserManager] windowSize=${JSON.stringify(m)}`),a){let v=async S=>{try{await Zn(S,m.width,m.height),x&&await S.setViewportSize(x)}catch(A){h.warn("[BrowserManager] Failed to set window bounds via CDP:",A)}};for(let S of g.pages())await v(S);g.on("page",v)}let b="";if(a&&t!==void 0)try{b=await qn(t)}catch(v){h.warn("[BrowserManager] Failed to get CDP WebSocket URL:",v)}let _={debugPort:t,browser:p,context:g,startTime:new Date,timeout:null,browserWsUrl:b,downloadsBasePath:this.downloadsBasePath,browserType:n,userDataDir:f,isTempUserDataDir:k};if(this.terminationTimeout!==null){let v=setTimeout(()=>{h.info(`[BrowserManager] Browser auto-terminated after ${this.terminationTimeout}ms`),this.terminateBrowser(_).catch(S=>h.error("[BrowserManager] Error terminating browser:",S))},this.terminationTimeout);_.timeout=v}return _}async terminateBrowser(e){if(e.timeout&&clearTimeout(e.timeout),await e.context.close(),await e.browser.close(),e.isTempUserDataDir&&e.userDataDir)try{Oe.default.rmSync(e.userDataDir,{recursive:!0,force:!0})}catch(t){h.warn("[BrowserManager] Failed to clean up temp user data dir:",e.userDataDir,t)}}getVideoBasePath(){return this.videoBasePath}getStatesBasePath(){return this.statesBasePath}getDownloadsBasePath(){return this.downloadsBasePath}}});var Uc,Gc=y(()=>{"use strict";kt();Uc=e=>{if(!e||e===Ye)return"desktop";let t=Ii(e);return t&&t.isMobile?"mobile":"desktop"}});var dp,Kc=y(()=>{"use strict";dp=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(dp||{})});async function jc(e,t){let i=Object.getPrototypeOf(async()=>{}).constructor,n=`
4438
4436
  return await (${t});
4439
- `;return await new i("page",n)(e)}async function Ci(e,t,i){let n=[],a=[];for(let o of t){let r=!1;try{let s=`page.${o}`;f.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await Nc(e,`${s}.waitFor({ state: 'attached', timeout: ${qm} })`),f.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await Nc(e,`${s}.count()`)>0?(f.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(f.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){f.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(a.push(r),!r&&i)break}return{successResults:a,logs:n}}async function _o(e,t,i=!0){let{successResults:n,logs:a}=await Ci(e,t,i);return{success:n.length===t.length&&n.every(o=>o),logs:a}}async function $i(e,t){if(!t||t.length===0)return f.log("No validation expressions provided, cannot validate login"),!1;f.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await _o(e,t,!0);return i?f.log("All validation expressions passed"):f.log(`Validation failed: ${n.join(", ")}`),i}async function So(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),a=await n.newPage();return await a.goto(t),await Me(a,Zm),{context:n,page:a,close:async()=>{await a.close(),await n.close()}}}async function Eo(e,t,i,n,a,o){let r=`
4440
- Based on the current page status, generate ${a} Playwright locators in JavaScript code that can
4437
+ `;return await new i("page",n)(e)}async function $i(e,t,i){let n=[],o=[];for(let a of t){let r=!1;try{let s=`page.${a}`;w.log(`Checking element existence: ${s}`),n.push(`Checking element existence: ${s}`);try{await jc(e,`${s}.waitFor({ state: 'attached', timeout: ${up} })`),w.log(`Element is attached: ${s}`),n.push(`Element is attached: ${s}`),r=!0}catch{await jc(e,`${s}.count()`)>0?(w.log(`Element found (snapshot): ${s}`),n.push(`Element found (snapshot): ${s}`),r=!0):(w.log(`Element not found: ${s}`),n.push(`Element not found: ${s}`),r=!1)}}catch(s){w.log(`Error checking element: ${s.message}`),n.push(`Error checking element: ${s.message}`),r=!1}if(o.push(r),!r&&i)break}return{successResults:o,logs:n}}async function Aa(e,t,i=!0){let{successResults:n,logs:o}=await $i(e,t,i);return{success:n.length===t.length&&n.every(a=>a),logs:o}}async function Di(e,t){if(!t||t.length===0)return w.log("No validation expressions provided, cannot validate login"),!1;w.log(`Validating login with ${t.length} expression(s)`);let{success:i,logs:n}=await Aa(e,t,!0);return i?w.log("All validation expressions passed"):w.log(`Validation failed: ${n.join(", ")}`),i}async function Ma(e,t){let i=e.context().browser();if(!i)throw new Error("Cannot create unsigned-in context: browser not available");let n=await i.newContext(),o=await n.newPage();return await o.goto(t),await Me(o,hp),{context:n,page:o,close:async()=>{await o.close(),await n.close()}}}async function Ca(e,t,i,n,o,a){let r=`
4438
+ Based on the current page status, generate ${o} Playwright locators in JavaScript code that can
4441
4439
  be used by a program to verify the page is signed in.
4442
4440
  Each expression should yield a locator object that can be used for waiting and checking visibility.
4443
4441
  `;t&&(r+=`
@@ -4478,22 +4476,22 @@ Avoid regenerating these failed ones, but can reuse the successful ones.`),n&&(r
4478
4476
  ${n}
4479
4477
  `),r+=`
4480
4478
  Remember, you must have the javascript code block in your final response.
4481
- `,f.log("Agent generating validation locators"),f.log(`Prompt:
4482
- ${r}`);let s=await o(e,r);if(!s.success)throw new Error(s.details||"Agent failed to generate verification code");let l=(s.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
4483
- `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function ua(e,t,i,n,a){let o=null;try{o=await So(e,t);let r=await a(o.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await Eo(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);f.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:p}=await Ci(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4479
+ `,w.log("Agent generating validation locators"),w.log(`Prompt:
4480
+ ${r}`);let s=await a(e,r);if(!s.success)throw new Error(s.details||"Agent failed to generate verification code");let l=(s.details||"").match(/```javascript\n(.*)\n```/s);if(!l)throw new Error("Agent failed to generate verification code: no javascript code block found");return l[1].split(`
4481
+ `).map(d=>d.trim()).filter(d=>d.length>0).map(d=>(d.startsWith("page.")&&(d=d.slice(5)),d))}async function fo(e,t,i,n,o){let a=null;try{a=await Ma(e,t);let r=await o(a.page),s=3,l="";for(let d=0;d<s;d++)try{let c=await Ca(e,r,l||null,i.verification_hint??null,i.num_verification_exprs??1,n);w.log(`Generated validation locators: ${JSON.stringify(c)}`);{let{successResults:u,logs:p}=await $i(e,c,!1);if(l+=`Test results on a SIGNED IN page. EXPECT ALL PASS:
4484
4482
  ${p.join(`
4485
4483
  `)}
4486
4484
 
4487
- `,!u.every(g=>g)){f.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(u)}`),f.log(`Validation logs:
4485
+ `,!u.every(g=>g)){w.log(`Locator validation on signed-in page failed. Results: ${JSON.stringify(u)}`),w.log(`Validation logs:
4488
4486
  ${p.join(`
4489
- `)}`);continue}}{f.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:p}=await Ci(o.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4487
+ `)}`);continue}}{w.log("Validating locators in unsigned-in context, EXPECT ALL TO FAIL");let{successResults:u,logs:p}=await $i(a.page,c,!1);if(l+=`Test results on an UNSIGNED IN page. EXPECT ALL FAIL:
4490
4488
  ${p.join(`
4491
4489
  `)}
4492
4490
 
4493
- `,u.some(g=>g)){f.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(u)}`),f.log(`Validation logs:
4491
+ `,u.some(g=>g)){w.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(u)}`),w.log(`Validation logs:
4494
4492
  ${p.join(`
4495
- `)}`);continue}}return f.log("Generated validation locators passed dual validation"),c}catch(c){f.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return f.log("Failed to generate valid locators after max retries"),null}finally{o&&await o.close()}}var qm,Zm,ha=b(()=>{"use strict";ne();Ie();qm=5e3,Zm=1e4});var Rc,To=b(()=>{"use strict";Rc=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(n=>!n.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}}});async function Fc(e,t=3e3,i=1e3){try{await Me(e,t,i)}catch{}}async function Hc(e,t,i){let n=i*1e3,a=100,o=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-o>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(a)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Wc(e,t,i,n=60,a){let o=Math.min(n,280),r=Math.max(10,o/10)*1e3,s=Date.now()+o*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${o}s)`);;){let l=Date.now();try{if(await i(e,t,a))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var ma=b(()=>{"use strict";Ie();R()});function Gc(e){return e.url()===":"}var Bc,Pi,pa,Qm,ga,Ao=b(()=>{"use strict";To();vt();ma();Ie();R();Bc=W(require("fs"),1),Pi=W(require("path"),1),pa=require("otplib"),Qm=(0,pa.createGuardrails)({MIN_SECRET_BYTES:1});ga=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new Rc(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return la(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Pi.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let a=Pi.basename(n),o=Pi.join(t,a),r=Bc.existsSync(o);return r&&h.debug(`[AgentServices] File already exists locally: ${a}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Hc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),h.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4496
- ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,pa.generateSync)({secret:e,guardrails:Qm});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Me(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion||!1}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let a=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${a.length} knowledges for statement`),a}catch(a){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${a.message}`),[]}}}});var Mo,fa,Io=b(()=>{"use strict";Mo=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(Mo||{}),fa=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Uc={};Ue(Uc,{LoginType:()=>Ii,checkLocators:()=>Ci,createUnsignedInContext:()=>So,generateAndValidateLoginLocators:()=>ua,generateValidationLocators:()=>Eo,validateLogin:()=>$i,validateLoginLocators:()=>_o});var Kc=b(()=>{"use strict";ha();ne();vt();Ie();yt();R();ie();dt();fe()});function Di(e,t){let i={};for(let[n,a]of Object.entries(e))i[n]=t.has(n)?"*****":a;return i}var j,Q,ep,tp,ip,Co,jc=b(()=>{"use strict";zt();je();ha();ne();Ao();ma();Io();Qt();R();j=W(require("fs"),1),Q=W(require("path"),1),ep=1,tp=3,ip=40;Co=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new ga(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(ft(),gt));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let n=(await this.getActionHandler()).getAction(e);if(!n)throw new Error(`Unknown action: ${e}`);await n.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
4493
+ `)}`);continue}}return w.log("Generated validation locators passed dual validation"),c}catch(c){w.log(`Failed to generate validation expressions (attempt ${d+1}/${s}): ${c.message}`)}return w.log("Failed to generate valid locators after max retries"),null}finally{a&&await a.close()}}var up,hp,wo=y(()=>{"use strict";ie();Ce();up=5e3,hp=1e4});var zc,Ia=y(()=>{"use strict";zc=class{constructor(e){this.currentPage=null,this.currentIndex=-1,this.context=e,this.initialize()}initialize(){this.context.on("page",async t=>{await this.handleNewPage(t)});let e=this.context.pages();e.length>0&&(this.currentPage=e[0],this.currentIndex=0);for(let t of e)this.setupPageListeners(t)}async handleNewPage(e){try{this.setupPageListeners(e);let t=this.context.pages().indexOf(e);await this.setCurrentPage(e,t)}catch{}}setupPageListeners(e){e.on("close",async()=>{await this.handlePageClose(e)})}async handlePageClose(e){try{if(this.currentPage===e){let t=this.context.pages(),i=t.slice().reverse().find(n=>!n.isClosed());i&&await this.setCurrentPage(i,t.indexOf(i))}}catch{}}async setCurrentPage(e,t){let i=this.currentPage!==e;this.currentPage=e,this.currentIndex=t,i&&await e.bringToFront()}async switchToPage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is closed`);return await this.setCurrentPage(i,e),i}async closePage(e){let t=this.context.pages();if(e<0||e>=t.length)throw new Error(`Invalid page index: ${e}. Available pages: 0-${t.length-1}`);let i=t[e];if(i.isClosed())throw new Error(`Page at index ${e} is already closed`);await i.close()}getCurrentPage(){return this.currentPage}getCurrentIndex(){return this.currentIndex}getAllPages(){return this.context.pages()}getPageCount(){return this.context.pages().length}}});async function Vc(e,t=3e3,i=1e3){try{await Me(e,t,i)}catch{}}async function Xc(e,t,i){let n=i*1e3,o=100,a=Date.now();for(;!t.downloadStatus||t.downloadStatus.status==="inProgress";){if(Date.now()-a>n){let r;throw t.downloadStatus?r=`Timed out after ${n}ms waiting for download to complete`:r="No download in progress or completed",h.error(r),new Error(r)}await e.waitForTimeout(o)}if(t.downloadStatus.status==="failed"){let r=`Download failed: ${t.downloadStatus.error||"Unknown error"}`;throw h.error(r),new Error(r)}t.agentNote=`Download completed: ${t.downloadStatus.filename}`}async function Yc(e,t,i,n=60,o){let a=Math.min(n,280),r=Math.max(10,a/10)*1e3,s=Date.now()+a*1e3;for(h.info(`Waiting for condition: "${t}" (timeout: ${a}s)`);;){let l=Date.now();try{if(await i(e,t,o))return h.info(`Condition met: "${t}"`),!0}catch(c){h.warn(`Error evaluating condition: ${c.message}`)}if(Date.now()>s)return h.warn(`Timeout waiting for condition: "${t}"`),!1;let d=r-(Date.now()-l);d>0&&await e.waitForTimeout(d)}}var bo=y(()=>{"use strict";Ce();R()});function qc(e){return e.url()===":"}var Jc,Li,yo,mp,xo,Pa=y(()=>{"use strict";Ia();kt();bo();Ce();R();Jc=W(require("fs"),1),Li=W(require("path"),1),yo=require("otplib"),mp=(0,yo.createGuardrails)({MIN_SECRET_BYTES:1});xo=class{constructor(e){this.context=e,this.testDataFileNames=[],this.extensionEnabled=!1}setTestDataDownloader(e,t){this.testDataDownloader=e,this.testDataFileNames=t??[]}setupPageTracking(e){this.tabManager=new zc(e)}async switchTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");return await this.tabManager.switchToPage(e)}async closeTab(e){if(!this.tabManager)throw new Error("Tab manager not initialized");await this.tabManager.closePage(e)}getCurrentPage(){return this.tabManager?this.tabManager.getCurrentPage():null}validatePage(e){let t=this.getCurrentPage();if(t&&t!==e&&!t.isClosed())return h.info(`[validatePage] Page changed, switching to ${t.url()}`),t;if(e.isClosed()){let i=e.context().pages().filter(n=>!n.isClosed());if(i.length>0){let n=i[i.length-1];return h.info(`[validatePage] Page closed, switching to ${n.url()}`),n}h.error("[validatePage] No valid pages found")}return e}replaceVariables(e){return go(e,this.context.variableStore.getAll())}getTestDataFileNames(){return this.testDataFileNames}getTestDataFilePath(e){let t=this.context.testDataDir||process.cwd();return Li.join(t,e)}async downloadTestDataFiles(e){if(e.length===0){h.debug("[AgentServices] No file paths provided for download");return}let t=this.context.testDataDir||process.cwd(),i=e.filter(n=>{let o=Li.basename(n),a=Li.join(t,o),r=Jc.existsSync(a);return r&&h.debug(`[AgentServices] File already exists locally: ${o}`),!r});if(i.length===0){h.debug("[AgentServices] All files exist locally, no download needed");return}if(!this.testDataDownloader){h.debug("[AgentServices] No test data downloader configured, assuming files are pre-populated");return}h.info(`[AgentServices] Downloading ${i.length} test data files: ${i.join(", ")}`),await this.testDataDownloader(i,t)}async waitForDownloadComplete(e,t){return Xc(e,this.context,t)}getRecentDownloadedFilePath(){return this.context.downloadStatus?this.context.downloadStatus.status!=="completed"?(h.debug(`Download is ${this.context.downloadStatus.status}, not completed`),null):this.context.downloadStatus.filePath?(h.info(`Retrieved recent download path: ${this.context.downloadStatus.filePath}`),this.context.downloadStatus.filePath):(h.warn("Download completed but file path is missing"),null):(h.debug("No download found"),null)}addSensitive(e,t){this.context.variableStore.set(e,t,!0)}saveVariable(e,t){let i=e.startsWith("$")?e.slice(1):e;this.context.variableStore.set(i,t),h.debug(`Saved variable: ${i} = ${JSON.stringify(t)}`),this.context.agentNote=`A new value is saved to the variable "${i}".`}addNote(e){!e||e.trim()===""||(this.context.agentNote?this.context.agentNote+=`
4494
+ ${e.trim()}`:this.context.agentNote=e.trim())}readVariable(e){let t=e.startsWith("$")?e.slice(1):e,i=this.context.variableStore.get(t);return h.debug(`Read variable: ${t} = ${JSON.stringify(i)}`),i}async generate2faCode(e){try{let t=(0,yo.generateSync)({secret:e,guardrails:mp});return h.info(`Generated 2FA code: ${t}`),t}catch(t){throw h.error(`Failed to generate 2FA code: ${t.message}`),new Error(`Failed to generate 2FA code: ${t.message}`)}}async getDOMText(e){return await e.evaluate(()=>document.body.innerText)}async waitUntilStable(e,t){return Me(e,t)}setPage(e){this.context.setPage?(h.info("[AgentServices] Calling setPage callback"),this.context.setPage(e)):h.debug("[AgentServices] setPage callback not configured")}getModel(){if(!this.context.model)throw new Error("No LLM model configured. An LLM model is required for AI-powered actions (login, verify, ai_extract, ai_wait_until, etc.). Set GOOGLE_API_KEY or ANTHROPIC_API_KEY in your MCP server configuration.");return this.context.model}getComputerUseModel(){return this.context.computer_use_model}get variableStore(){return this.context.variableStore}getDownloadDir(){return this.context.downloadDir}getActionSettings(){return this.context.organizationSettings?.action_code_conversion_settings||{}}getInteractiveClassNames(){return this.context.organizationSettings?.agent_settings?.interactive_class_names||[]}getIframeFallbackDomains(){return this.context.organizationSettings?.agent_settings?.iframe_fallback_domains||[]}isUseCleanScreenshotForAssertion(){return this.context.organizationSettings?.use_clean_screenshot_for_assertion??!0}isKnowledgeImagesEnabled(){return this.context.organizationSettings?.agent_settings?.enable_knowledge_images||!1}isSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.use_sliced_screenshots||!1}isResizeSlicedScreenshotsEnabled(){return this.context.organizationSettings?.agent_settings?.resize_sliced_screenshots||!1}isAccessibilityTreeEnabled(){return this.context.organizationSettings?.agent_settings?.use_accessibility_tree||!1}isActionIntentFilteringEnabled(){return this.context.organizationSettings?.agent_settings?.use_action_intent_filtering||!1}isDomTreeTsEnabled(){let e=process.env.USE_DOM_TREE_TS;return e!==void 0?e==="true"||e==="1":this.context.organizationSettings?.agent_settings?.use_dom_tree_ts||!1}setExtensionEnabled(e){this.extensionEnabled=e}getDomServiceOptions(){return{useDomTreeTs:this.isDomTreeTsEnabled(),domTreeRoot:this.extensionEnabled?"document":"body"}}setKnowledgeRetriever(e){this.knowledgeRetriever=e}hasKnowledgeRetriever(){return this.knowledgeRetriever!==void 0}async retrieveKnowledges(e,t,i,n){if(!this.knowledgeRetriever)return h.debug("[AgentServices] No knowledge retriever configured"),[];try{let o=await this.knowledgeRetriever(e,t,i,n);return h.debug(`[AgentServices] Retrieved ${o.length} knowledges for statement`),o}catch(o){return h.warn(`[AgentServices] Failed to retrieve knowledges: ${o.message}`),[]}}}});var $a,vo,Da=y(()=>{"use strict";$a=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))($a||{}),vo=class extends Error{constructor(e){super(e),this.name="AgentTaskFailedError",this.details=e}}});var Zc={};Ge(Zc,{LoginType:()=>Pi,checkLocators:()=>$i,createUnsignedInContext:()=>Ma,generateAndValidateLoginLocators:()=>fo,generateValidationLocators:()=>Ca,validateLogin:()=>Di,validateLoginLocators:()=>Aa});var Qc=y(()=>{"use strict";wo();ie();kt();Ce();xt();R();te();ut();pe()});function Oi(e,t){let i={};for(let[n,o]of Object.entries(e))i[n]=t.has(n)?"*****":o;return i}var z,Z,pp,gp,fp,La,ed=y(()=>{"use strict";Xt();je();wo();ie();Pa();bo();Da();ti();R();z=W(require("fs"),1),Z=W(require("path"),1),pp=1,gp=3,fp=40;La=class{constructor(e){this.context=e,this._newActionEntities=new Map,this.agentServices=new xo(e),this.agentServices.agent=this,this.context.tokenUsages||(this.context.tokenUsages=[])}getNewActionEntities(){return this._newActionEntities}getAgentNote(){return this.context.agentNote||void 0}async getActionHandler(){if(!this._actionHandler){let{default:e}=await Promise.resolve().then(()=>(wt(),ft));this._actionHandler=new e}return this._actionHandler}async execAction(e,t,i){let n=(await this.getActionHandler()).getAction(e);if(!n)throw new Error(`Unknown action: ${e}`);await n.execute(t,i,this.agentServices)}async dismissModalIfPresent(e,t){try{let i=await this.execute(e,`TASK: Check if there is an INTRUSIVE POPUP blocking the page, and dismiss it if present.
4497
4495
 
4498
4496
  ONLY dismiss intrusive popups such as:
4499
4497
  - Cookie/GDPR consent banners
@@ -4515,7 +4513,7 @@ If you find an intrusive popup, dismiss it by clicking its close/X button or "No
4515
4513
  IMPORTANT: Only act with HIGH CONFIDENCE. If unsure whether something is an intrusive popup, do nothing.
4516
4514
  It's better to miss a popup than to accidentally interact with normal page elements.
4517
4515
 
4518
- If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,tp),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),Gc(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||Q.join(process.cwd(),"downloads");j.existsSync(n)||j.mkdirSync(n,{recursive:!0});let a=Q.join(n,i);h.info(`[Download Tracking] Downloading file to: ${a}`),await t.saveAs(a),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:a,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${a}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let a=i==="beforeunload";try{a?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:a?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${a?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(o){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${o}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,a,o){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),o&&(s.explanation=o)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:a,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:o,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ve(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";if(i&&this.trackAIAction(i,"assert",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,a.success?"success":"failure",o,void 0,a.debugInfo),!a.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${o}`),new Error(`Assertion failed: ${o}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${o}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),a=await Ve(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(a.debugInfo),this.context.lastActionDebugInfo=a.debugInfo;let o=a.explanation||a.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",a.debugInfo,1,t,o),this.context.agentNote=o,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",o,void 0,a.debugInfo),a.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${o}`),!0):(h.warn(`AI evaluation returned false/unknown: ${o}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${o}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await ze(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let a=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,a),{success:!0,details:n.explanation}}async execute(e,t,i,n,a){if(a!==void 0&&a<=0)throw new Error(`maxSteps must be >= 1, got ${a}`);let o=a!==void 0&&a>1;h.info(`Executing statement: ${t} (${o?`multi, maxSteps: ${a}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(o){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let p=`${i}-step${u.step}`;this.saveDebugInfoToFiles(p,u.debugInfo,this.context.model)}}:void 0;if(s=await Xe(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:a??ip}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await ze(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory(),o=await mt(t,e,this.agentServices,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(o.debugInfo),o.status!=="success"||o.actionEntities.length===0){let l=o.explanation||o.error||"No explanation";throw i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,o.debugInfo),new Error(l)}let r=o.completed,s=o.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",o.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,o.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${o.completed}`),{success:r,details:s,actions:o.actionEntities,debugInfo:o.debugInfo}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),a}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let a=this.getCompletedExecutionHistory();this.context.agentNote="";let o=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||o?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),o&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await Xe(t,e,this.agentServices,r,{executionHistory:a,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});f.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new fa(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),f.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),f.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(a){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",a.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${a.message}`),a}}async step(e,t,i,n,a,o=!0,r){let s=Date.now();this.context.stepTracking&&await this.createStepResult(e,n,i),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?Di(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),w=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Di(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,x=this.context.stepTracking.results[n]?.screenshot,T=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:w||void 0,variables:k,screenshotPath:x,timestamp:T})}let y=this.context.agentNote;return(!y||y.trim()==="")&&(y="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=y),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=o&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),x=await this.captureDOMSnapshot(e),T=this.context.stepTracking.captureVariables?Di(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-s,E=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:x||void 0,variables:T,timestamp:E})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${p.message}`);let w,k;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){w=`[Auto-dismissed modal: ${m.details}]`,k=m.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let x=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=w+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",w),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=w,x}catch(x){h.info(`Retry after modal dismissal failed: ${x.message}, falling back to self-healing`)}}}let y=r??ep;h.info(`Calling execute() to self-heal (maxSteps: ${y})`);try{let m=await this.execute(e,i,n,!1,y);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let x=m.actions?.at(-1);a&&x&&(this._newActionEntities.set(a,x),h.info(`Stored new action entity for stmtUid: ${a} (last of ${m.actions?.length} actions)`));let T=e.url(),v=await this.captureDOMSnapshot(e),E=this.context.stepTracking?.captureVariables?Di(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=x,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let A=w||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-s,C=this.context.stepTracking.results[n]?.screenshot,I=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:x,playwrightCode:m.actions?.map(L=>L.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:T,domSnapshot:v||void 0,variables:E,screenshotPath:C,timestamp:I})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let x=e.url(),T=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Di(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},E=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:E,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:x,domSnapshot:T||void 0,variables:v,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`);try{let a=`Extract ${t} and save to ${i}`,o=await this.execute(e,a,n);if(!o.success)throw new Error(`AI extraction failed: ${o.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(a){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",a.message),a}}async getDOMText(e){let t=new me(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new me(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),a=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:a.elementTree.clickableElementsToString(),elementCount:a.selectorMap.size,timestamp:Date.now()}}catch(t){return h.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return Fc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Wc(e,t,(a,o,r)=>this.evaluate(a,o,r),i,n)}async uploadFile(e,t,i={},n){return Ys(e,t,i,this.context,(a,o,r)=>this.execute(a,o,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Kc(),Uc));if(h.info("Start login"),f.section("Login Flow"),f.log(`Site URL: ${t.site_url}`),f.log(`Account type: ${t.account.type}`),f.log(`Has cached actions: ${!!i?.cached_actions?.length}`),f.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let a=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),o=a?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(a){f.log("Level 1: Checking if already logged in via AI verification hint..."),f.log(`Verification statement: ${o}`);try{if(await this.evaluate(e,o))return f.log("Level 1 SUCCESS: Already logged in via AI verification"),h.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){f.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&f.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!a&&i?.validation_exprs&&i.validation_exprs.length>0){if(f.log("Level 1: Checking if already logged in via storage state..."),f.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await $i(e,i.validation_exprs))return f.log("Level 1 SUCCESS: Already logged in via storage state"),h.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};f.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(a||r)){f.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:o})).success){f.log("Level 2 SUCCESS: Cached login succeeded"),h.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}f.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){f.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&f.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4516
+ If NO intrusive popup is present, do nothing and report that no intrusive popup was found.`,void 0,!1,gp),n=!!(i.actions&&i.actions.length>0);return{success:i.success,modalDismissed:n,details:i.details||(n?"Modal dismissed":"No modal found"),actions:i.actions}}catch(i){return{success:!1,modalDismissed:!1,details:i.message||"Modal dismissal failed"}}}_getContext(){return this.context}setupDownloadTracking(e){if(h.info(`[Download Tracking] Setting up download tracking for page: ${e.url()}`),qc(e)){h.info(`[Download Tracking] Skipping download tracking for blank tab: ${e.url()}`),e.close();return}e.on("download",async t=>{let i=t.suggestedFilename();h.info(`[Download Tracking] Download event detected! File: ${i}`),this.context.downloadStatus={filename:i,status:"inProgress",startTime:Date.now()},h.info(`[Download Tracking] Download status set to inProgress: ${JSON.stringify(this.context.downloadStatus)}`);try{let n=this.context.downloadDir||Z.join(process.cwd(),"downloads");z.existsSync(n)||z.mkdirSync(n,{recursive:!0});let o=Z.join(n,i);h.info(`[Download Tracking] Downloading file to: ${o}`),await t.saveAs(o),this.context.downloadStatus={filename:i,status:"completed",startTime:this.context.downloadStatus.startTime,filePath:o,timestamp:Date.now()},h.info(`[Download Tracking] Download completed: ${o}`),h.info(`[Download Tracking] Download status set to completed: ${JSON.stringify(this.context.downloadStatus)}`)}catch(n){this.context.downloadStatus={filename:i,status:"failed",startTime:this.context.downloadStatus.startTime,error:n.message,timestamp:Date.now()},h.error(`[Download Tracking] Download failed for ${i}: ${n.message}`)}})}setupDialogHandling(e){if(h.debug(`[Dialog Handling] setupDialogHandling called, isClosed=${e.isClosed()}, url=${e.url()}`),e.isClosed()){h.debug("[Dialog Handling] Skipping - page is closed");return}h.info(`[Dialog Handling] Setting up dialog handling for page: ${e.url()}`),e.on("dialog",async t=>{let i=t.type(),n=t.message();h.info(`[Dialog Handling] Dialog detected - type: ${i}, message: "${n}"`);let o=i==="beforeunload";try{o?await t.dismiss():await t.accept(),this.context.dialogStatus={type:i,message:n,response:o?"dismiss":"accept",timestamp:Date.now()},h.info(`[Dialog Handling] Dialog ${o?"dismissed":"accepted"} - type: ${i}, message: "${n}"`)}catch(a){h.warn(`[Dialog Handling] Failed to handle dialog (already dismissed?): ${a}`)}})}getRecentDownloadedFilePath(){return this.agentServices.getRecentDownloadedFilePath()}addNote(e){this.agentServices.addNote(e)}collectTokenUsages(e){let t;Array.isArray(e)?t=e:e?.tokenUsages&&(t=e.tokenUsages),t&&t.length>0?(this.context.tokenUsages||(this.context.tokenUsages=[]),this.context.tokenUsages.push(...t),h.debug(`[collectTokenUsages] Added ${t.length} token usage(s), total: ${this.context.tokenUsages.length}`)):h.debug("[collectTokenUsages] No token usages to collect (undefined or empty)")}trackAIAction(e,t,i,n=1,o,a){if(!e)return;let r=i?.tokenUsages||[];this.context.aiActionDetails||(this.context.aiActionDetails=[]);let s=this.context.aiActionDetails.find(l=>l.stepId===e&&l.actionType===t);s?(s.count+=n,r.length>0&&s.tokenUsages.push(...r),i?.userPrompt&&(s.userPrompt=i.userPrompt),i?.rawLlmResponse&&(s.rawLlmResponse=i.rawLlmResponse),i?.reasoningContent&&(s.reasoningContent=i.reasoningContent),i?.elementTree&&(s.elementTree=i.elementTree),i?.screenshotWithSom&&(s.screenshotWithSom=i.screenshotWithSom),a&&(s.explanation=a)):this.context.aiActionDetails.push({stepId:e,actionType:t,count:n,tokenUsages:[...r],statement:o,userPrompt:i?.userPrompt,rawLlmResponse:i?.rawLlmResponse,reasoningContent:i?.reasoningContent,explanation:a,elementTree:i?.elementTree,screenshotWithSom:i?.screenshotWithSom}),h.debug(`[trackAIAction] Tracked ${t} for step ${e}, count: ${n}`)}async assert(e,t,i){h.info(`Asserting statement: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ve(t,e,this.agentServices,{executionHistory:n,useCleanScreenshotForAssertion:!0,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";if(i&&this.trackAIAction(i,"assert",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,o.success?"success":"failure",a,void 0,o.debugInfo),!o.success)throw this.addToExecutionHistory(`Assert: "${t}"`,`Failed: ${a}`),new Error(`Assertion failed: ${a}`);return this.addToExecutionHistory(`Assert: "${t}"`,`Passed: ${a}`),!0}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async evaluate(e,t,i){h.info(`Evaluating condition: ${t}`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),await this.agentServices.waitUntilStable(e);try{let n=this.getCompletedExecutionHistory(),o=await Ve(t,e,this.agentServices,{executionHistory:n,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});this.collectTokenUsages(o.debugInfo),this.context.lastActionDebugInfo=o.debugInfo;let a=o.explanation||o.error||"No explanation";return i&&this.trackAIAction(i,"evaluate",o.debugInfo,1,t,a),this.context.agentNote=a,i&&this.context.stepTracking&&await this.updateStepResult(i,"success",a,void 0,o.debugInfo),o.success?(this.addToExecutionHistory(`Evaluate: "${t}"`,`Result: true - ${a}`),!0):(h.warn(`AI evaluation returned false/unknown: ${a}`),this.addToExecutionHistory(`Evaluate: "${t}"`,`Unknown/False: ${a}`),!1)}catch(n){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",n.message),n}}async performAction(e,t){h.info(`Act: ${t}`);let i=this.getCompletedExecutionHistory(),n=await ze(t,e,this.agentServices,{executionHistory:i,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys()});if(this.collectTokenUsages(n.debugInfo),n.status!=="success"||n.actionEntities.length===0)return{success:!1,details:n.explanation||n.error||"Action failed"};let o=n.actionEntities[0]?.action_description||t;return this.addToExecutionHistory(t,o),{success:!0,details:n.explanation}}async execute(e,t,i,n,o){if(o!==void 0&&o<=0)throw new Error(`maxSteps must be >= 1, got ${o}`);let a=o!==void 0&&o>1;h.info(`Executing statement: ${t} (${a?`multi, maxSteps: ${o}`:"single"})`),i&&this.context.stepTracking&&await this.createStepResult(e,i,t),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e);try{let r=this.getCompletedExecutionHistory();this.context.agentNote="";let s,l;if(a){let c=i&&this.context.stepTracking?.artifactsDir?u=>{if(u.type==="action"&&u.debugInfo){let p=`${i}-step${u.step}`;this.saveDebugInfoToFiles(p,u.debugInfo,this.context.model)}}:void 0;if(s=await Xe(t,e,this.agentServices,c,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),maxSteps:o??fp}),l=s.completed,this.collectTokenUsages(s.tokenUsages),i&&s.tokenUsages){let u={tokenUsages:s.tokenUsages};this.trackAIAction(i,"execute",u,s.actionEntities?.length||1,t,s.explanation||"Multi-step execution completed")}}else if(e=this.agentServices.validatePage(e),s=await ze(t,e,this.agentServices,{executionHistory:r,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n}),l=s.completed,this.collectTokenUsages(s.debugInfo),this.context.lastActionDebugInfo=s.debugInfo,i){let c=s.explanation||s.error||"No explanation";this.trackAIAction(i,"execute",s.debugInfo,1,t,c)}if(s.status!=="success"||s.actionEntities.length===0||!l){let c=s.explanation||s.error||"Goal not completed";throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",c,void 0,s.debugInfo),new Error(`Action failed: ${c}`)}let d=this.context.agentNote||s.explanation||"Action executed successfully";return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,s.debugInfo),this.addToExecutionHistory(`Execute: "${t}"`,d),{success:!0,details:d,actions:s.actionEntities,debugInfo:s.debugInfo}}catch(r){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",r.message),this.addToExecutionHistory(`Execute: "${t}"`,`Failed: ${r.message}`),r}}async generate(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory(),a=await pt(t,e,this.agentServices,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),usePureVision:n});if(this.collectTokenUsages(a.debugInfo),a.status!=="success"||a.actionEntities.length===0){let l=a.explanation||a.error||"No explanation";throw i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,l),i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",l,void 0,a.debugInfo),new Error(l)}let r=a.completed,s=a.explanation||"Action generated successfully";return i&&this.trackAIAction(i,"generate",a.debugInfo,1,t,s),i&&this.context.stepTracking&&await this.updateStepResult(i,"success",s,void 0,a.debugInfo),h.info(`[generate] Generated action for "${t}": ${s}, goalAccomplished: ${a.completed}`),{success:r,details:s,actions:a.actionEntities,debugInfo:a.debugInfo}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),o}}async run(e,t,i,n){i&&this.context.stepTracking&&await this.createStepResult(e,i,t);try{let o=this.getCompletedExecutionHistory();this.context.agentNote="";let a=i&&this.context.stepTracking?.artifactsDir,r=n?.onAction||a?c=>{if(c.type==="action"&&c.action_entity&&(n?.onAction?.(c.action_entity),a&&c.debugInfo)){let u=`${i}-step${c.step}`;this.saveDebugInfoToFiles(u,c.debugInfo,this.context.model)}}:void 0,s=await Xe(t,e,this.agentServices,r,{executionHistory:o,variables:this.context.variableStore.getAll(),sensitiveKeys:this.context.variableStore.getAllSensitiveKeys(),abortSignal:n?.abortSignal,maxSteps:n?.maxSteps});w.log(`Run task result: status=${s.status}, completed=${s.completed}, actions=${s.actionEntities?.length||0}`),this.collectTokenUsages(s.tokenUsages);let l=s.status==="success"&&s.completed,d=this.context.agentNote?.trim()||s.explanation||s.error||(l?"Step completed":"Step failed");if(i&&s.tokenUsages){let c={tokenUsages:s.tokenUsages};this.trackAIAction(i,"run",c,s.actionEntities?.length||1,t,d)}if(!l)throw new vo(d);if(n?.stmtUid&&s.actionEntities?.length){let c=s.actionEntities.at(-1);c&&(this._newActionEntities.set(n.stmtUid,c),w.log(`Stored resolved action entity for DRAFT stmtUid: ${n.stmtUid}`))}return i&&this.context.stepTracking&&await this.updateStepResult(i,"success",d,void 0,void 0),this.addToExecutionHistory(`Run: "${t}"`,d),w.log(`Run result: success=${l}, details=${d}`),{success:l,details:d,actions:s.actionEntities}}catch(o){throw i&&this.context.stepTracking&&await this.updateStepResult(i,"failure",o.message),this.addToExecutionHistory(`Run: "${t}"`,`Failed: ${o.message}`),o}}async step(e,t,i,n,o,a=!0,r){let s=Date.now();this.context.stepTracking&&await this.createStepResult(e,n,i),e=this.agentServices.validatePage(e),await this.agentServices.waitUntilStable(e),this.context.stepTracking&&(this.context.stepTracking.currentStepId=n),e=this.agentServices.validatePage(e);let l=e.url(),d=await this.captureDOMSnapshot(e),c=this.context.stepTracking?.captureVariables?Oi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},u=this.context.stepTracking?.results[n]?.screenshot;try{h.info(`Executing step ${n}: ${i}`),this.addToExecutionHistory(i,""),this.context.agentNote="",e=this.agentServices.validatePage(e);let p=await t();e=this.agentServices.validatePage(e);let g=e.url(),f=await this.captureDOMSnapshot(e),k=this.context.stepTracking?.captureVariables?Oi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking&&await this.updateStepResult(n,"success",""),this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=Date.now()-s,b=this.context.stepTracking.results[n]?.screenshot,_=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:m,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:g,domSnapshot:f||void 0,variables:k,screenshotPath:b,timestamp:_})}let x=this.context.agentNote;return(!x||x.trim()==="")&&(x="Execution successful"),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=x),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p}catch(p){e=this.agentServices.validatePage(e);let g=a&&!this.context.isSelfHealing;if(g&&(this.context.stepTracking&&await this.updateStepResult(n,"failure",p.message),this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=p.message)),!i||i.trim()==="")throw h.error("No description provided for self-healing"),this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),p;if(!g){if(h.info(`Failed to heal at step ${n}. ${i}`),this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let m=e.url(),b=await this.captureDOMSnapshot(e),_=this.context.stepTracking.captureVariables?Oi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},v=Date.now()-s,S=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:v,status:"failure",errorMessage:p.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:m,domSnapshot:b||void 0,variables:_,timestamp:S})}throw this.context.stepTracking&&(await this.updateStepResult(n,void 0,void 0),this.context.stepTracking.currentStepId=void 0),p}this.context.isSelfHealing=!0,h.info(`Action failed at step ${n}. ${i}`),h.info(`with error: ${p.message}`);let f,k;if(this.context.autoDismissModal){h.info("Attempting modal dismissal before self-healing...");let m=await this.dismissModalIfPresent(e,i);if(h.info(`Modal dismissal result: ${m.details}`),m.modalDismissed){f=`[Auto-dismissed modal: ${m.details}]`,k=m.actions,h.info(`Modal dismissed, retrying original action for step ${n}`);try{let b=await t();return this.context.isSelfHealing=!1,this.context.executionHistory&&this.context.executionHistory.length>0&&(this.context.executionHistory[this.context.executionHistory.length-1][1]=f+" Retry successful"),this.context.stepTracking&&(await this.updateStepResult(n,"success",f),this.context.stepTracking.results[n].dismissedModalActions=k,this.context.stepTracking.currentStepId=void 0),this.context.agentNote=f,b}catch(b){h.info(`Retry after modal dismissal failed: ${b.message}, falling back to self-healing`)}}}let x=r??pp;h.info(`Calling execute() to self-heal (maxSteps: ${x})`);try{let m=await this.execute(e,i,n,!1,x);if(this.context.isSelfHealing=!1,!m.success)throw new Error(`Self-healing failed: ${m.details}`);let b=m.actions?.at(-1);o&&b&&(this._newActionEntities.set(o,b),h.info(`Stored new action entity for stmtUid: ${o} (last of ${m.actions?.length} actions)`));let _=e.url(),v=await this.captureDOMSnapshot(e),S=this.context.stepTracking?.captureVariables?Oi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{};if(this.context.stepTracking){this.context.stepTracking.results[n].autoHealed=!0,this.context.stepTracking.results[n].healedAction=b,k&&(this.context.stepTracking.results[n].dismissedModalActions=k);let A=f||"";await this.updateStepResult(n,"success",A)}if(this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let A=Date.now()-s,I=this.context.stepTracking.results[n]?.screenshot,C=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{actionEntity:b,playwrightCode:m.actions?.map(D=>D.locator||""),llmPrompt:m.debugInfo?.userPrompt,llmResponse:m.debugInfo?.rawLlmResponse,llmReasoning:m.debugInfo?.reasoningContent},consoleLogs:this.getConsoleLogsForStep(n),durationMs:A,status:"success"}),this.context.stepTracking.stateTransitions.push({type:"state",url:_,domSnapshot:v||void 0,variables:S,screenshotPath:I,timestamp:C})}return this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}catch(m){if(this.context.isSelfHealing=!1,this.context.stepTracking?.captureStateTransitions&&this.context.stepTracking.stateTransitions){let b=e.url(),_=await this.captureDOMSnapshot(e),v=this.context.stepTracking.captureVariables?Oi(this.context.variableStore.getAll(),this.context.variableStore.getAllSensitiveKeys()):{},S=Date.now()-s,A=Date.now();this.context.stepTracking.stateTransitions.length===0&&this.context.stepTracking.stateTransitions.push({type:"state",url:l,domSnapshot:d||void 0,variables:c,screenshotPath:u,timestamp:s}),this.context.stepTracking.stateTransitions.push({type:"action",stepId:n,description:i,action:{playwrightCode:[t.toString()]},consoleLogs:this.getConsoleLogsForStep(n),durationMs:S,status:"failure",errorMessage:m.message}),this.context.stepTracking.stateTransitions.push({type:"state",url:b,domSnapshot:_||void 0,variables:v,timestamp:A})}throw this.context.stepTracking&&(this.context.stepTracking.currentStepId=void 0),m}}}async extract(e,t,i,n){n&&this.context.stepTracking&&await this.createStepResult(e,n,`Extract ${t} into ${i}`);try{let o=`Extract ${t} and save to ${i}`,a=await this.execute(e,o,n);if(!a.success)throw new Error(`AI extraction failed: ${a.details}`);n&&this.context.stepTracking&&await this.updateStepResult(n,"success",`Extracted ${t} to ${i}`)}catch(o){throw n&&this.context.stepTracking&&await this.updateStepResult(n,"failure",o.message),o}}async getDOMText(e){let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains();return(await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n})).elementTree.clickableElementsToString()}async captureDOMSnapshot(e){if(!this.context.stepTracking?.captureStateTransitions||!this.context.stepTracking?.captureDom)return null;try{let t=new ue(this.agentServices.getDomServiceOptions()),i=this.agentServices.getInteractiveClassNames(),n=this.agentServices.getIframeFallbackDomains(),o=await t.getClickableElements(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n,highlightElements:!1,viewportExpansion:0});return{elementTreeText:o.elementTree.clickableElementsToString(),elementCount:o.selectorMap.size,timestamp:Date.now()}}catch(t){return h.warn("Failed to capture DOM snapshot:",t),null}}getConsoleLogsForStep(e){return this.context.stepTracking?.consoleLogs?this.context.stepTracking.consoleLogs.filter(t=>t.stepId===e).map(t=>({type:t.type,message:t.message,timestamp:t.timestamp})):[]}async waitUntilStable(e,t=3e3,i=1e3){return Vc(e,t,i)}async waitUntilCondition(e,t,i=60,n){return Yc(e,t,(o,a,r)=>this.evaluate(o,a,r),i,n)}async uploadFile(e,t,i={},n){return ol(e,t,i,this.context,(o,a,r)=>this.execute(o,a,r),n)}async loginPage(e,t,i){let{LoginType:n}=await Promise.resolve().then(()=>(Qc(),Zc));if(h.info("Start login"),w.section("Login Flow"),w.log(`Site URL: ${t.site_url}`),w.log(`Account type: ${t.account.type}`),w.log(`Has cached actions: ${!!i?.cached_actions?.length}`),w.log(`Has validation exprs: ${!!i?.validation_exprs?.length}`),t.skip_verification)return h.info("Skipping login verification (skip_verification=true)"),{success:!0,page:e};(t.account.type===n.PASSWORD||t.account.type===n.OAUTH2)&&(this.context.variableStore.set("username",t.account.username,!0),this.context.variableStore.set("password",t.account.password,!0)),t.account.two_factor_auth_config?.type==="totp"&&this.context.variableStore.set("otp_secret_key",t.account.two_factor_auth_config.data,!0),h.info(`Navigating to: ${t.site_url}`),await e.goto(t.site_url),await this.waitUntilStable(e,1e4,3e3);let o=!!(t.use_ai_verification_for_login_check&&t.verification_hint?.trim()),a=o?`Check if the page is already signed in. Consider it signed in only when this verification statement is satisfied: ${t.verification_hint.trim()}`:void 0;if(o){w.log("Level 1: Checking if already logged in via AI verification hint..."),w.log(`Verification statement: ${a}`);try{if(await this.evaluate(e,a))return w.log("Level 1 SUCCESS: Already logged in via AI verification"),h.info("Login: Already logged in via AI verification"),{success:!0,page:e,storage_state:null,cached_actions:i?.cached_actions,validation_exprs:i?.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: AI verification indicates not signed in, trying Level 2")}catch(l){w.log(`Level 1 ERROR: AI verification failed (${l.message}), trying Level 2`)}}else t.use_ai_verification_for_login_check&&!t.verification_hint?.trim()&&w.log("Level 1 SKIPPED: use_ai_verification_for_login_check is enabled but verification_hint is empty, falling back to cached validation expressions");if(!o&&i?.validation_exprs&&i.validation_exprs.length>0){if(w.log("Level 1: Checking if already logged in via storage state..."),w.log(`Validation expressions: ${JSON.stringify(i.validation_exprs)}`),await Di(e,i.validation_exprs))return w.log("Level 1 SUCCESS: Already logged in via storage state"),h.info("Login: Already logged in via storage state"),{success:!0,page:e,storage_state:null,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs,alreadyLoggedIn:!0};w.log("Level 1 FAILED: Storage state validation failed, trying Level 2")}let r=!!(i?.validation_exprs&&i.validation_exprs.length>0);if(i?.cached_actions&&i.cached_actions.length>0&&(o||r)){w.log(`Level 2: Attempting cached login with ${i.cached_actions.length} actions`);try{if((await this.executeCachedLogin(e,i.cached_actions,{validationExprs:i.validation_exprs,aiVerificationStatement:a})).success){w.log("Level 2 SUCCESS: Cached login succeeded"),h.info("Login: Cached login succeeded");let l=await e.context().storageState();return{success:!0,page:e,storage_state:l,cached_actions:i.cached_actions,validation_exprs:i.validation_exprs}}w.log("Level 2 FAILED: Cached login failed, trying Level 3")}catch(l){w.log(`Level 2 ERROR: ${l.message}, trying Level 3`)}}else i?.cached_actions&&i.cached_actions.length>0&&w.log("Level 2 SKIPPED: Cached actions exist but no verification method available, going to Level 3");let s=`First check if the page is already signed in. If it is, do nothing.
4519
4517
  Use your best judgement to determine if the page is signed in.
4520
4518
  `;if(t.verification_hint&&(s+=`
4521
4519
  Signed in verification hint: ${t.verification_hint}
@@ -4526,8 +4524,10 @@ If the page is not signed in, sign in with the OAuth provider "${l.provider_name
4526
4524
  ($username, $password), and use $otp_secret_key to generate $otp_code for two-factor authentication. If you can't login with the provided credentials, just stop and report the failure.
4527
4525
  `}t.additional_prompt&&(s+=`
4528
4526
  Additional instructions: ${t.additional_prompt}
4529
- `);try{f.log("Level 3: Attempting agent-based login"),f.log(`Login prompt:
4530
- ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(f.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,y,m,x)=>await l(k,y,m,"login")),d=!0,f.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return f.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),f.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),p;if(a)f.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{f.log("Generating validation locators for future login verification...");let k=await ua(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(y,m)=>this.run(y,m),async y=>this.getDOMText(y));k?(p=k,f.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):f.log("Failed to generate validation locators, login will still succeed")}catch(k){f.log(`Error generating validation locators: ${k.message}`)}else f.log("Skipping validation locator generation (num_verification_exprs=0)");f.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],w=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:w,validation_exprs:p}}catch(l){return f.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(ft(),gt))).default,a=new n;for(let o=0;o<t.length;o++){let r=t[o];f.log(`Executing cached action ${o+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){f.log(`Action ${o+1} missing action_data, skipping`);continue}await a.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return f.error(`Cached action ${o+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(f.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await $i(e,i.validationExprs)?{success:!0}:{success:!1}:(f.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let a=Q.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));j.mkdirSync(a,{recursive:!0});let o=Q.join(a,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:o}),n.screenshot=o}this.context.stepTracking.results[t]=n}catch(n){h.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let a={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),a;let o=Q.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(j.mkdirSync(o,{recursive:!0}),t.systemPrompt){let r=Q.join(o,`system_prompt_${n}.txt`);j.writeFileSync(r,t.systemPrompt),a.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Q.join(o,`user_prompt_${n}.txt`);j.writeFileSync(r,t.userPrompt),a.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=Q.join(o,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};j.writeFileSync(s,JSON.stringify(l,null,2)),a.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Q.join(o,`${r}_response_${n}.txt`);j.writeFileSync(s,t.rawLlmResponse),a.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Q.join(o,`screenshot_${n}.png`);j.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),a.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Q.join(o,`reasoning_${n}.txt`);j.writeFileSync(r,t.reasoningContent),a.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(a).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return a}async updateStepResult(e,t,i,n,a){if(!this.context.stepTracking)return;let o=this.context.stepTracking.results[e];if(o){if(t&&(o.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(o.message=i),n&&o.artifacts.push(n),a){let r=a.tokenUsages?.[0]?.model,s=o.artifacts.length,l=this.saveDebugInfoToFiles(e,a,r,s);Object.keys(l).length>0&&o.artifacts.push(l)}o.duration=Date.now()-o.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,o)}}async writeExecutionResults(e,t){try{if(await j.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=Q.join(e,"test-results.json");await j.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),h.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=Q.join(e,"token-usages.json");await j.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),h.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=Q.join(e,"ai-actions.json");await j.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function np(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,a=t.find(m=>m.type==="day").value,o=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${a}T${o}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-u)/(1e3*60)),w=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),y=g<=0?"+":"-";return`${i}-${n}-${a}T${o}:${r}:${s}.${l}${y}${w}:${k}`}function $o(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",np()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var zc=b(()=>{"use strict"});var Vc={};Ue(Vc,{ActionHandler:()=>Gn,ActionHelper:()=>Ti,Agent:()=>Co,AgentServices:()=>ga,AgentStepEventTypes:()=>Mo,AgentTaskFailedError:()=>fa,BrowserManager:()=>$c,DEFAULT_EVENT_LISTENER_LIMIT:()=>hn,DomService:()=>me,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>un,HistoryTreeProcessor:()=>Os,INIT_SCRIPT:()=>bt,INTERACTION_EVENT_TYPES:()=>lt,INTERACTIVE_ROLES:()=>Wt,LogLevel:()=>ja,LoginType:()=>Ii,MCPToolProvider:()=>yc,OpenAIToolProvider:()=>en,SDK_VERSION:()=>op,ToolRegistry:()=>st,TwoFactorAuthType:()=>vo,VariableStore:()=>ko,WebAgent:()=>Co,configureSdk:()=>$r,createAgent:()=>ap,createAgentContext:()=>$o,createToolRegistry:()=>gc,createToolRegistryWithCapabilities:()=>fc,ensureToolsRegistered:()=>mc,evaluateStatement:()=>Ve,executeStep:()=>ze,exportMCPTools:()=>xc,filterInteractionListeners:()=>xs,generateActionStep:()=>mt,getActionEntityLocatorInfo:()=>N,getBrowserCdpUrl:()=>Vn,getCapabilitySummary:()=>wc,getFramePath:()=>Ba,getModel:()=>be,getPageInfo:()=>ql,getPageWsUrl:()=>Jl,getPlatformFromDeviceName:()=>Dc,getProviderOptions:()=>ye,getSdkConfig:()=>G,getToolRegistry:()=>pc,injectUserFunction:()=>Ca,isInteractionEventType:()=>ys,isInteractiveRole:()=>bs,loadKnowledgeMappings:()=>Rr,loadKnowledges:()=>Nr,loadUserFunctions:()=>Lr,logger:()=>h,newBrowserContext:()=>Yl,parseSSEStream:()=>Hr,parseSdkLogLevelFromEnv:()=>Pr,pickBestLocator:()=>It,pickBestLocatorForElement:()=>Ki,pickBestLocators:()=>Kr,replaceVariables:()=>la,runTask:()=>Xe,setWindowBounds:()=>Xn,toolRegistry:()=>H});function ap(e){let t=new ko,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[a,o]of Object.entries(e.variables))t.set(a,o,i.has(a));let n=$o({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new Co(n)}var op,Xc=b(()=>{"use strict";Or();Fr();Wr();bc();xo();vc();kc();wo();yo();bo();Pc();Lc();Oc();jc();zt();dn();ln();rt();Yi();Ji();nt();tn();an();Ot();Nt();Te();Dt();Lt();Sn();je();Ht();Bt();ct();Gt();Ut();ha();ne();Ao();To();vt();ma();Ie();yt();Ee();Ct();$t();at();Io();po();pn();gn();fn();wn();bn();yn();xn();vn();kn();En();Tn();Vt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();li();ci();di();ui();hi();pi();gi();wi();bi();yi();xi();vi();ki();_i();Si();Ei();On();Qt();K();Ke();R();ie();dt();Bn();F();zc();fe();op="1.0.0"});var Yc,Jc=b(()=>{"use strict";Yc=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4527
+ `);try{w.log("Level 3: Attempting agent-based login"),w.log(`Login prompt:
4528
+ ${s}`);let l=this.agentServices.knowledgeRetriever,d=!1;this.agentServices.hasKnowledgeRetriever()&&l&&(w.log("Setting up login knowledge retriever..."),this.agentServices.setKnowledgeRetriever(async(k,x,m,b)=>await l(k,x,m,"login")),d=!0,w.log("Login knowledge retriever configured"));let c;try{if(c=await this.run(e,s,"login"),!c.success)return w.log("Level 3 FAILED: Agent login failed"),h.info("Login: Failed"),{success:!1,page:e}}finally{d&&l&&(this.agentServices.setKnowledgeRetriever(l),w.log("Restored original knowledge retriever"))}let u=await e.context().storageState(),p;if(o)w.log("Skipping validation locator generation (AI verification mode enabled)");else if(t.num_verification_exprs!==0)try{w.log("Generating validation locators for future login verification...");let k=await fo(e,t.site_url,{verification_hint:t.verification_hint,num_verification_exprs:t.num_verification_exprs},async(x,m)=>this.run(x,m),async x=>this.getDOMText(x));k?(p=k,w.log(`Generated ${p.length} validation locator(s): ${JSON.stringify(p)}`)):w.log("Failed to generate validation locators, login will still succeed")}catch(k){w.log(`Error generating validation locators: ${k.message}`)}else w.log("Skipping validation locator generation (num_verification_exprs=0)");w.log("Level 3 SUCCESS: Agent login succeeded"),h.info("Login: Agent login succeeded");let g=c.actions||[],f=g.length>0?g:i?.cached_actions;return{success:!0,page:e,storage_state:u,cached_actions:f,validation_exprs:p}}catch(l){return w.error(`Agent login failed: ${l.message}`),h.info("Login: Failed"),{success:!1,page:e}}}async executeCachedLogin(e,t,i){let n=(await Promise.resolve().then(()=>(wt(),ft))).default,o=new n;for(let a=0;a<t.length;a++){let r=t[a];w.log(`Executing cached action ${a+1}/${t.length}: ${r.action_description||r.action_data?.action_name}`);try{if(!r.action_data){w.log(`Action ${a+1} missing action_data, skipping`);continue}await o.execute(e,r,this.agentServices),await this.waitUntilStable(e,5e3)}catch(s){return w.error(`Cached action ${a+1} failed: ${s.message}`),{success:!1}}}return i?.aiVerificationStatement?(w.log("Verifying cached login result with AI verification statement"),await this.evaluate(e,i.aiVerificationStatement)?{success:!0}:{success:!1}):i?.validationExprs&&i.validationExprs.length>0?await Di(e,i.validationExprs)?{success:!0}:{success:!1}:(w.log("Cached login cannot be verified: missing AI verification statement and validation expressions"),{success:!1})}getCompletedExecutionHistory(){if(!this.context.executionHistory||this.context.executionHistory.length===0)return[];let e=this.context.executionHistory[this.context.executionHistory.length-1];return!e[1]||e[1].trim()===""?this.context.executionHistory.slice(0,-1):this.context.executionHistory}addToExecutionHistory(e,t){this.context.executionHistory||(this.context.executionHistory=[]),this.context.executionHistory.push([e,t])}async createStepResult(e,t,i){if(this.context.stepTracking&&!this.context.stepTracking.results[t]){this.context.stepTracking.currentStepId=t,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(t);try{e=this.agentServices.validatePage(e),await this.waitUntilStable(e);let n={description:i,startTime:Date.now(),artifacts:[]};if(this.context.stepTracking.artifactsDir){let o=Z.join(this.context.stepTracking.artifactsDir,t.replace(/\./g,"-"));z.mkdirSync(o,{recursive:!0});let a=Z.join(o,"screenshot.png");e=this.agentServices.validatePage(e),await e.screenshot({type:"png",path:a}),n.screenshot=a}this.context.stepTracking.results[t]=n}catch(n){h.warn(`createStepResult failed for step ${t}: ${n}`),this.context.stepTracking.results[t]={description:i,startTime:Date.now(),artifacts:[]}}}}saveDebugInfoToFiles(e,t,i,n=0){let o={};if(!this.context.stepTracking?.artifactsDir)return h.debug("[saveDebugInfoToFiles] No artifacts directory configured, skipping debug info save"),o;let a=Z.join(this.context.stepTracking.artifactsDir,e.replace(/\./g,"-"));try{if(z.mkdirSync(a,{recursive:!0}),t.systemPrompt){let r=Z.join(a,`system_prompt_${n}.txt`);z.writeFileSync(r,t.systemPrompt),o.system_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved system prompt to: ${r}`)}if(t.userPrompt)if(typeof t.userPrompt=="string"){let r=Z.join(a,`user_prompt_${n}.txt`);z.writeFileSync(r,t.userPrompt),o.user_prompt_path=r,h.debug(`[saveDebugInfoToFiles] Saved user prompt to: ${r}`)}else{let r=t.userPrompt.map(d=>Array.isArray(d.content)?{...d,content:d.content.map(c=>c.type==="image"&&c.file?.startsWith("data:")?{...c,file:"[base64 image data stripped]"}:c)}:d),s=Z.join(a,`messages_${n}.json`),l={system:t.systemPrompt,messages:r};z.writeFileSync(s,JSON.stringify(l,null,2)),o.messages_path=s,h.debug(`[saveDebugInfoToFiles] Saved messages to: ${s}`)}if(t.rawLlmResponse){let r=i?i.replace(/[\/\\:]/g,"-"):"llm",s=Z.join(a,`${r}_response_${n}.txt`);z.writeFileSync(s,t.rawLlmResponse),o.response_path=s,h.debug(`[saveDebugInfoToFiles] Saved LLM response to: ${s}`)}if(t.screenshotWithSom){let r=Z.join(a,`screenshot_${n}.png`);z.writeFileSync(r,Buffer.from(t.screenshotWithSom,"base64")),o.screenshot_path=r,h.debug(`[saveDebugInfoToFiles] Saved SOM screenshot to: ${r}`)}if(t.reasoningContent){let r=Z.join(a,`reasoning_${n}.txt`);z.writeFileSync(r,t.reasoningContent),o.reasoning_path=r,h.debug(`[saveDebugInfoToFiles] Saved reasoning to: ${r}`)}h.debug(`[saveDebugInfoToFiles] Saved ${Object.keys(o).length} artifacts for step ${e}`)}catch(r){h.error(`[saveDebugInfoToFiles] Failed to save debug info for step ${e}:`,r)}return o}async updateStepResult(e,t,i,n,o){if(!this.context.stepTracking)return;let a=this.context.stepTracking.results[e];if(a){if(t&&(a.status=t,this.context.stepTracking.currentStepId=void 0,this.context.stepTracking.onStepChange&&this.context.stepTracking.onStepChange(void 0)),i!==void 0&&(a.message=i),n&&a.artifacts.push(n),o){let r=o.tokenUsages?.[0]?.model,s=a.artifacts.length,l=this.saveDebugInfoToFiles(e,o,r,s);Object.keys(l).length>0&&a.artifacts.push(l)}a.duration=Date.now()-a.startTime,this.context.stepTracking.onStepComplete&&this.context.stepTracking.onStepComplete(e,a)}}async writeExecutionResults(e,t){try{if(await z.promises.mkdir(e,{recursive:!0}),this.context.stepTracking?.results&&Object.keys(this.context.stepTracking.results).length>0){let i=Z.join(e,"test-results.json");await z.promises.writeFile(i,JSON.stringify(this.context.stepTracking.results,null,2)),h.debug(`Test results written to: ${i}`)}if(t?.tokenUsages&&this.context.tokenUsages&&this.context.tokenUsages.length>0){let i=Z.join(e,"token-usages.json");await z.promises.writeFile(i,JSON.stringify(this.context.tokenUsages,null,2)),h.debug(`Token usages written to: ${i}`)}if(this.context.aiActionDetails&&this.context.aiActionDetails.length>0){let i=Z.join(e,"ai-actions.json");await z.promises.writeFile(i,JSON.stringify(this.context.aiActionDetails,null,2)),h.debug(`AI action details written to: ${i}`)}}catch(i){throw h.error("Failed to write execution results:",i),i}}}});function wp(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1}).formatToParts(e),i=t.find(m=>m.type==="year").value,n=t.find(m=>m.type==="month").value,o=t.find(m=>m.type==="day").value,a=t.find(m=>m.type==="hour").value,r=t.find(m=>m.type==="minute").value,s=t.find(m=>m.type==="second").value,l=String(e.getMilliseconds()).padStart(3,"0"),d=`${i}-${n}-${o}T${a}:${r}:${s}.${l}`,c=e.toISOString().slice(0,-1),u=Date.parse(d+"Z"),p=Date.parse(c+"Z"),g=Math.round((p-u)/(1e3*60)),f=String(Math.floor(Math.abs(g)/60)).padStart(2,"0"),k=String(Math.abs(g)%60).padStart(2,"0"),x=g<=0?"+":"-";return`${i}-${n}-${o}T${a}:${r}:${s}.${l}${x}${f}:${k}`}function Oa(e){let t=e.variableStore;return t.has("currentTime")||t.set("currentTime",wp()),{model:e.model,computer_use_model:e.computer_use_model,variableStore:t,organizationId:e.organizationId,organizationSettings:e.organizationSettings,executionHistory:e.executionHistory||[],testDataDir:e.testDataDir,downloadDir:e.downloadDir,useNativeGenerator:e.useNativeGenerator,autoDismissModal:e.autoDismissModal,tokenUsages:[],aiActionDetails:[]}}var td=y(()=>{"use strict"});var id={};Ge(id,{ActionHandler:()=>zn,ActionHelper:()=>Mi,Agent:()=>La,AgentServices:()=>xo,AgentStepEventTypes:()=>$a,AgentTaskFailedError:()=>vo,BrowserManager:()=>Wc,DEFAULT_EVENT_LISTENER_LIMIT:()=>fn,DomService:()=>ue,EVENT_LISTENER_CANDIDATE_SELECTORS:()=>gn,HistoryTreeProcessor:()=>Ks,INIT_SCRIPT:()=>yt,INTERACTION_EVENT_TYPES:()=>ct,INTERACTIVE_ROLES:()=>Ut,LogLevel:()=>Jo,LoginType:()=>Pi,MCPToolProvider:()=>Mc,OpenAIToolProvider:()=>an,SDK_VERSION:()=>yp,ToolRegistry:()=>lt,TwoFactorAuthType:()=>Ea,VariableStore:()=>Ta,WebAgent:()=>La,configureSdk:()=>Rr,createAgent:()=>bp,createAgentContext:()=>Oa,createToolRegistry:()=>Sc,createToolRegistryWithCapabilities:()=>Ec,ensureToolsRegistered:()=>kc,evaluateStatement:()=>Ve,executeStep:()=>ze,exportMCPTools:()=>Cc,filterInteractionListeners:()=>Cs,generateActionStep:()=>pt,getActionEntityLocatorInfo:()=>N,getBrowserCdpUrl:()=>qn,getCapabilitySummary:()=>Tc,getFramePath:()=>zo,getModel:()=>we,getPageInfo:()=>rc,getPageWsUrl:()=>ac,getPlatformFromDeviceName:()=>Uc,getProviderOptions:()=>be,getSdkConfig:()=>U,getToolRegistry:()=>_c,injectUserFunction:()=>Oo,isInteractionEventType:()=>Ms,isInteractiveRole:()=>As,loadKnowledgeMappings:()=>Gr,loadKnowledges:()=>Ur,loadUserFunctions:()=>Wr,logger:()=>h,newBrowserContext:()=>oc,parseSSEStream:()=>jr,parseSdkLogLevelFromEnv:()=>Fr,pickBestLocator:()=>It,pickBestLocatorForElement:()=>Vi,pickBestLocators:()=>Jr,replaceVariables:()=>go,runTask:()=>Xe,setWindowBounds:()=>Zn,toolRegistry:()=>H});function bp(e){let t=new Ta,i=new Set(e.sensitiveKeys||[]);if(e.variables)for(let[o,a]of Object.entries(e.variables))t.set(o,a,i.has(o));let n=Oa({model:e.model,variableStore:t,testDataDir:e.testDataDir,downloadDir:e.downloadDir});return new La(n)}var yp,nd=y(()=>{"use strict";Br();Kr();zr();Ac();Sa();Ic();Pc();va();_a();ka();Bc();Gc();Kc();ed();Xt();pn();hn();st();Zi();en();Qi();nt();rn();ln();Rt();Ft();Te();Ot();Nt();Mn();je();Bt();Gt();dt();Kt();jt();wo();ie();Pa();Ia();kt();bo();Ce();xt();Ee();$t();Dt();ot();Da();ba();bn();yn();xn();vn();kn();_n();Sn();En();Tn();Cn();In();Yt();qt();Qt();ei();ii();ni();oi();ai();ri();si();li();di();ui();hi();mi();pi();fi();wi();yi();xi();vi();ki();_i();Si();Ei();Ti();Ai();Hn();ti();j();Ke();R();te();ut();jn();F();td();pe();yp="1.0.0"});var T,Na,ko,Ra,qe,Fa,Ha,Wa,ne,Ba,Ni,_o,Ua=y(()=>{"use strict";T=require("zod"),Na=T.z.enum(["JS_CODE","AI_MODE"]),ko=T.z.object({type:Na,expression:T.z.string()}),Ra=T.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),qe=T.z.object({uid:T.z.string(),type:Ra,comment:T.z.string().optional()}),Fa=T.z.object({action_data:T.z.object({action_name:T.z.string(),kwargs:T.z.record(T.z.any()).optional(),args:T.z.array(T.z.any()).optional()}),action_description:T.z.string().optional(),url:T.z.string().optional(),xpath:T.z.string().nullable().optional(),locator:T.z.string().nullable().optional(),css_selector:T.z.string().nullable().optional(),unique_selector:T.z.string().nullable().optional(),element_index:T.z.number().nullable().optional(),frame_path:T.z.array(T.z.any()).optional(),artifacts:T.z.record(T.z.any()).optional(),feedback:T.z.string().optional(),original_browser_use_action:T.z.any().optional()}).passthrough(),Ha=qe.extend({type:T.z.literal("DRAFT"),description:T.z.string()}),Wa=qe.extend({type:T.z.literal("ACTION"),description:T.z.string(),action_entity:Fa.optional(),locator:T.z.string().optional(),use_pure_vision:T.z.boolean().optional()}),ne=T.z.lazy(()=>T.z.union([Ha,Wa,qe.extend({type:T.z.literal("STEP"),description:T.z.string().optional().default(""),statements:T.z.array(ne),reference_id:T.z.number().optional()}),qe.extend({type:T.z.literal("IF_ELSE"),description:T.z.string().optional(),condition:ko,then:T.z.array(ne),else:T.z.array(ne).optional()}),qe.extend({type:T.z.literal("WHILE_LOOP"),description:T.z.string().optional(),condition:ko,body:T.z.array(ne),timeout_ms:T.z.number().optional()})])),Ba=T.z.object({name:T.z.string(),statements:T.z.array(ne),teardown:T.z.array(ne).optional(),skip:T.z.union([T.z.boolean(),T.z.string()]).optional(),timeout:T.z.number().optional(),fail:T.z.union([T.z.boolean(),T.z.string()]).optional(),only:T.z.boolean().optional(),slow:T.z.boolean().optional()}),Ni=T.z.object({tests:T.z.array(Ba).min(1),beforeAll:T.z.array(ne).optional(),afterAll:T.z.array(ne).optional(),beforeEach:T.z.array(ne).optional(),afterEach:T.z.array(ne).optional()}),_o=T.z.object({comment:T.z.string().optional(),version:T.z.string().optional(),goal:T.z.string().optional(),url:T.z.string().optional(),baseURL:T.z.string().optional(),final_feedback:T.z.string().optional(),completed:T.z.boolean().optional(),success:T.z.boolean().optional(),statements:T.z.array(ne).optional(),teardown:T.z.array(ne).optional(),last_modified_at:T.z.string().optional(),testGroup:Ni.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function Ka(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(le)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(le)),i}function sd(e,t){if(e.testGroup)return ja(e,t);let i=Ka(e,t),n=new $.Document(i);return e.comment&&(n.commentBefore=e.comment),od(n,e.statements??[]),e.teardown&&od(n,e.teardown,"teardown"),n.toString(Et)}function od(e,t,i="statements"){let n=e.contents;if(!n||!(0,$.isMap)(n))return;let o=n.get(i,!0);(0,$.isSeq)(o)&&Ri(o,t)}function Ri(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],o=e.items[i];if(i>0&&(o.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:o.commentBefore=n.comment),(0,$.isMap)(o)){let a=o;if(n.type==="STEP"){let r=a.get("statements",!0);(0,$.isSeq)(r)&&Ri(r,n.statements)}else if(n.type==="IF_ELSE"){let r=a.get("THEN",!0);(0,$.isSeq)(r)&&Ri(r,n.then);let s=a.get("ELSE",!0);(0,$.isSeq)(s)&&n.else&&Ri(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=a.get("DO",!0);(0,$.isSeq)(r)&&Ri(r,n.body)}}}}function ja(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use);let o={};return e.baseURL&&(o.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(o.beforeAll=i.beforeAll.map(le)),i.beforeEach&&i.beforeEach.length>0&&(o.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(o.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(o.afterAll=i.afterAll.map(le)),o.tests=i.tests.map(a=>{let r={name:a.name};return a.skip!==void 0&&(r.skip=a.skip),a.timeout!==void 0&&(r.timeout=a.timeout),a.fail!==void 0&&(r.fail=a.fail),a.only!==void 0&&(r.only=a.only),a.slow!==void 0&&(r.slow=a.slow),r.statements=a.statements.map(le),a.teardown&&a.teardown.length>0&&(r.teardown=a.teardown.map(le)),r}),n.suite=o,(0,$.stringify)(n,Et)}function ld(e){return e.map(t=>(0,$.stringify)(t,Et)).join(`---
4529
+ `)}function le(e){switch(e.type){case"DRAFT":return xp(e);case"ACTION":return cd(e);case"STEP":return kp(e);case"IF_ELSE":return _p(e);case"WHILE_LOOP":return Sp(e)}}function xp(e){return{intent:e.description}}function cd(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let o={intent:e.description,action:n.action_name},a=e.locator??e.action_entity.locator;a&&(o.locator=a);let r=e.action_entity.xpath;if(r&&(o.xpath=r),e.use_pure_vision&&(o.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))o[s]=l;return n.args&&n.args.length>0&&(o.args=n.args),o}function dd(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},o=cd(n);if(typeof o=="object"&&o!==null){let a={...o};return delete a.intent,delete a.VERIFY,delete a.WAIT_UNTIL,delete a.WAIT,delete a.statement,Object.keys(a).length>0?(0,$.stringify)(a,Et).trim():""}return(0,$.stringify)(o,Et).trim()}function ud(e){let t=(0,$.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,o=typeof t.locator=="string"?t.locator:void 0,a=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))vp.has(c)||(l[c]=u);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...o?{locator:o}:{},...a?{xpath:a}:{},...r?{frame_path:r}:{}},description:i,locator:o}:{description:i,actionEntity:{action_description:i||""}}}function kp(e){let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function _p(e){let t={IF:hd(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function Sp(e){let t={WHILE:hd(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function hd(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function md(e){let t=(0,$.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,o)=>n.errors.length>0?{__parseError:`Document ${o+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,$.parse)(e)}catch(o){throw new Error(`Invalid YAML: ${o instanceof Error?o.message:String(o)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,o)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${o+1}: expected an object`};let a=n,r=typeof a.name=="string"&&a.name.trim()||void 0,s=typeof a.goal=="string"?a.goal.trim():"";if(!s)return{error:`Item ${o+1}: missing "goal" field`};if(Array.isArray(a.statements))try{let l=(0,$.stringify)(a,Et),d=Ze(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(a){return{error:`Item ${o+1}: ${a instanceof Error?a.message:String(a)}`}}})}function pd(e){try{let t=(0,$.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function 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 o=i[0];if(o.startsWith("{ ")&&o.endsWith(" }")&&t[o]===null)return`{{${o.slice(2,-2)}}}`}let n={};for(let[o,a]of Object.entries(t))n[o]=Ga(a);return n}function Ze(e){if(e.length>ad)throw new Error(`YAML input too large (${e.length} bytes, max ${ad})`);let t=Ga((0,$.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return Ep(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ce(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ce(t.teardown));let n=_o.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let o=n.data;return za(e,o),o}function Ep(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let o={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ce(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ce(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(o.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(o.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(o.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(o.afterEach=ce(t.afterEach));let a=Ni.safeParse(o);if(!a.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(a.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:a.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(Tp)}function Tp(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 Ap(t);if("WHILE"in t)return Mp(t);if("STEP"in t)return Cp(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,o=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,a={url:typeof i=="string"?i:String(i)};return n&&(a.new_tab=!0),o!==void 0&&(a.timeout_seconds=o),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:a}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,se.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:(0,se.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return rd({...n,action:"function",functionName:i})}if("action"in t)return rd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function gd(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 Ap(e){let t=gd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function Mp(e){let t=gd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function Cp(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,se.v4)(),type:"STEP",description:t,statements:ce(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function rd(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,o=typeof e.xpath=="string"?e.xpath:void 0,a=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))Ip.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),o&&(s.xpath=o);let l={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:s};return a&&(l.use_pure_vision=!0),l}function za(e,t){let i;try{i=(0,$.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,$.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let o=n,a=o.get("statements",!0);(0,$.isSeq)(a)&&t.statements&&St(a,t.statements);let r=o.get("teardown",!0);(0,$.isSeq)(r)&&t.teardown&&St(r,t.teardown)}function St(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let o=t[i];if(o.type==="STEP"&&(0,$.isMap)(n)){let a=n.get("statements",!0);(0,$.isSeq)(a)&&St(a,o.statements)}else if(o.type==="IF_ELSE"&&(0,$.isMap)(n)){let a=n.get("THEN",!0);(0,$.isSeq)(a)&&St(a,o.then);let r=n.get("ELSE",!0);(0,$.isSeq)(r)&&o.else&&St(r,o.else)}else if(o.type==="WHILE_LOOP"&&(0,$.isMap)(n)){let a=n.get("DO",!0);(0,$.isSeq)(a)&&St(a,o.body)}}}var $,se,Et,vp,ad,Ip,So=y(()=>{"use strict";Ua();$=require("yaml"),se=require("uuid");Et={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};vp=new Set(["intent","action","locator","xpath","frame_path","args"]);ad=1024*1024;Ip=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function Va(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let o=t.operations[n],a=`operations[${n}]`;switch(o.reason||i.push(`${a}: missing reason`),o.op){case"remove":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}case"insert":{(typeof o.index!="number"||o.index<0||o.index>=e.length)&&i.push(`${a}: index ${o.index} out of bounds (0..${e.length-1})`),o.position!=="before"&&o.position!=="after"&&i.push(`${a}: position must be 'before' or 'after'`),(o.statement===void 0||o.statement===null)&&i.push(`${a}: missing statement`);break}default:i.push(`${a}: unknown operation type "${o.op}"`)}}return{valid:i.length===0,errors:i}}function Xa(e,t){let i=Va(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],o=t.operations.map((s,l)=>({...s,originalOrder:l})),a={remove:0,modify:1,insert:2},r=[...o].sort((s,l)=>s.index!==l.index?l.index-s.index:a[s.op]-a[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function fd(e,t){let i=(0,Eo.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let o=Xa(n,t);i.statements=o;let a=(0,Eo.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Ze(a),{modifiedYaml:a,modifiedStatements:o}}var Eo,wd=y(()=>{"use strict";So();Eo=require("yaml")});function Ya(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Ie(t);for(let n of i)if(Ya(n.statements))return!0}return!1}function xd(e){let t=new Set;function i(n){for(let o of n){o.type==="STEP"&&o.reference_id&&t.add(o.reference_id);let a=Ie(o);for(let r of a)i(r.statements)}}return i(e),Array.from(t)}function _d(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return We(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&We(e.teardown,"teardown",t),t}function Ne(e,t,i){let n=e+".",o=t.filter(([c])=>c===e||c.startsWith(n));if(o.length===0)return[];let a=[],r=new Set;for(let[c]of o){let u=c===e?"":c.slice(n.length);if(!u)continue;let p=u.split(".")[0];r.has(p)||r.add(p)}let s=Array.from(r);s.sort((c,u)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return p>=0&&g>=0?p-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,p=l(u),g=p?.description??"",f=u;if(c==="then"){let v=`${e}.then`,S=`${e}.else`,A=Ne(v,t,i),I=Ne(S,t,i),C=l(e),D=C?d(C.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"IF_ELSE",condition:D,then:A,...I.length>0?{else:I}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,S=Ne(v,t,i),A=l(e),I=A?d(A.description):{type:"JS_CODE",expression:"true"};a.push({uid:e,type:"WHILE_LOOP",condition:I,body:S});continue}let k=`${e}.${c}`,x=t.some(([v])=>v.startsWith(k+".then.")||v===k+".then"),m=t.some(([v])=>v.startsWith(k+".else.")||v===k+".else"),b=t.some(([v])=>v.startsWith(k+".body.")||v===k+".body"),_=t.filter(([v])=>{if(!v.startsWith(k+"."))return!1;let A=v.slice(k.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(x||m){let v=k+".then",S=k+".else",A=Ne(v,t,i),I=Ne(S,t,i),C=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"IF_ELSE",condition:C,then:A,...I.length>0?{else:I}:{}})}else if(b){let v=k+".body",S=Ne(v,t,i),A=p?d(g):{type:"JS_CODE",expression:"true"};a.push({uid:u,type:"WHILE_LOOP",condition:A,body:S})}else if(_.length>0){let v=Ne(k,t,i);a.push({uid:u,type:"STEP",description:g||"Group",statements:v})}else a.push({uid:u,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return a}function Sd(e){let t=Object.entries(e),i=n=>{let o=n+".";return t.some(([r])=>r===n||r.startsWith(o))?Ne(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ie,oe,Re,Fe,He,Fi,bd,yd,Pp,$p,vd,kd,We,To=y(()=>{"use strict";Ie=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},oe=(e,t,i=void 0,n="root")=>{for(let o=0;o<e.length;o++){let a=e[o],r=a.uid;if(r===t)return{stableId:r,path:[o],statement:a,parent:i,containerKey:n,index:o};let s=Ie(a);for(let l of s){let d=oe(l.statements,t,a,l.key);if(d)return{...d,path:[o,l.key,...d.path]}}}return null},Re=(e,t,i)=>{let n=oe(e,t);if(!n)return null;let{statement:o,parent:a,containerKey:r,index:s}=n,l=null;switch(o.type){case"DRAFT":case"ACTION":l=Fe(e,n)||He(e,n);break;case"STEP":if(o.statements&&o.statements.length>0)return o.statements[0];l=Fe(e,n)||He(e,n);break;case"IF_ELSE":if(i===!0&&o.then&&o.then.length>0)return o.then[0];if(i===!1&&o.else&&o.else.length>0)return o.else[0];l=Fe(e,n)||He(e,n);break;case"WHILE_LOOP":if(i===!0&&o.body&&o.body.length>0)return o.body[0];l=Fe(e,n)||He(e,n);break;default:l=Fe(e,n)||He(e,n);break}if(a&&a.type==="WHILE_LOOP"&&r==="body"){if(!l)return a;let d=oe(e,l.uid);if(!d||d.parent!==a)return a}return l},Fe=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ie(t.parent).find(o=>o.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},He=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=oe(e,i);return n?Fe(e,n)||He(e,n):null},Fi=e=>{let t=[],i=n=>{for(let o of n){t.push(o);let a=Ie(o);for(let r of a)i(r.statements)}};return i(e),t},bd=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},yd=(e,t,i)=>{if(!oe(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&oe(e,l);)if(s.push(l),l=Re(e,l)?.uid||null,s.length>1e3)return null;return s}if(!oe(e,i))return null;if(t===i)return[];let a=[],r=t;for(;r&&r!==i;){let s=oe(e,r);if(!s)break;if(a.push(r),s.statement.type==="IF_ELSE"){let l=Pp(s.statement,i);l?r=Re(e,r,l==="then")?.uid||null:r=Re(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?$p(s.statement,i)?r=Re(e,r,!0)?.uid||null:r=Re(e,r,!1)?.uid||null:r=Re(e,r)?.uid||null;if(a.length>1e3)return null}return r===i?a:null},Pp=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&oe(i.then,t)?"then":i.else&&oe(i.else,t)?"else":null},$p=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&oe(i.body,t))};vd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),kd=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),We=(e,t,i)=>{e.forEach((n,o)=>{let a=`${t}.${o}`;n.type==="DRAFT"?i[a]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[a]={description:n.description||"Action",action_entity:n.action_entity}:n.type==="STEP"&&n.statements?We(n.statements,a,i):n.type==="IF_ELSE"?(i[a]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&We(n.then,`${a}.then`,i),n.else&&We(n.else,`${a}.else`,i)):n.type==="WHILE_LOOP"&&(i[a]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&We(n.body,`${a}.body`,i))})}});function qa(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let o=n.action_entity?.action_data?.action_name??"";Ja.has(o)||t++}return{action:t,draft:i}}function Lp(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Ed(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Td(e,t){let i=t?.coverageThreshold??Dp,n=[],o=[],a;try{a=Ze(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}a.goal||n.push('Missing required field: "goal"'),a.statements?.length||n.push('Missing required field: "statements"');let r=[...Fi(a.statements??[]),...a.teardown?Fi(a.teardown):[]],{action:s,draft:l}=qa(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of r){if(p.type==="ACTION"){let g=p,f=g.action_entity?.action_data?.action_name??"";if(f==="js_code"||f==="js_action"||f==="verify"||f==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let x=Lp(k);if(x){let m=g.description||f;n.push(`Invalid JS in "${m}": ${x}. ${d}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ed(g.condition.expression);f&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${f}. ${d}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let f=Ed(g.condition.expression);f&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${f}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&o.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:o,stats:{total:c,action:s,draft:l,coverage:u}}}var Dp,Ja,Ad=y(()=>{"use strict";So();To();Dp=.5,Ja=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function Md(){return{version:"1.0",entries:{}}}function Cd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Id(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function Pd(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function $d(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,o]of t)i.entries[n]=o;return i}function Dd(e){return e?Object.keys(e.entries).length===0:!0}function Ld(e){return e?Object.keys(e.entries).length:0}function Od(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=Za(e.statements??[],t),n=e.teardown?Za(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function Za(e,t){return e.map(i=>Op(i,t))}function Op(e,t){if(e.type==="ACTION"){let o=e,a=t.entries[o.uid];return a?{...o,action_entity:a.action_entity}:o}let i=Ie(e);if(i.length===0)return e;let n={};for(let o of i)n[o.key]=Za(o.statements,t);return{...e,...n}}var Nd=y(()=>{"use strict";To()});function er(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let m=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(m&&m[1]){let _=m[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${_}"`}let b=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(b&&b[1]){let _=b[1].replace(/^\/|\/$/g,""),v=_.length>30?`${_.substring(0,27)}...`:_;return`${t[1]} element with text matching "${v}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let m=Tt(e),b=i[1].replace(/\\(.)/g,"$1");return`${m} with text "${b}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${Tt(e)} with text matching ${n[1]}`;let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let m=Tt(e),b=o[1].replace(/\\(.)/g,"$1");return`${m} containing "${b}"`}let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let m=Tt(e),b=a[1].replace(/\\(.)/g,"$1");return`${m} containing "${b}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let m=Tt(e),b=r[1].replace(/\\(.)/g,"$1");return`${m} not containing "${b}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let m=Tt(e),b=s[1].replace(/\\(.)/g,"$1");return`${m} not containing "${b}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let p=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(p&&p[1])return`input with placeholder "${p[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let f=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(f&&f[1])return`"${f[1].replace(/\\(.)/g,"$1")}"`;let k=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(k&&k[1])return`"${k[1].replace(/\\(.)/g,"$1")}"`;let x=e.match(/getByRole\(['"]([^'"]+)['"]/);return x&&x[1]?`${x[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function tr(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4530
+ `);for(let o of n){if(!o.includes(`[ref=${i}]`))continue;let s=o.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function ir(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let o=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return o&&o[1]?`frameLocator(${o[1]})`:t}function Tt(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let o=t[1],a=o.match(/^([a-zA-Z][\w-]*)/);return a?a[1]:o.length>20?`${o.substring(0,17)}...`:o}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function Qa(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function Np(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function Rp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function Hd(e,t){let i=e.name||"unknown",n=ir(t,e.selector||""),o=e.ariaSnapshot??e.arIAaSnapshot??"",a=e.ref,r=/getByTestId\s*\(/.test(n),l=(a&&o&&r?tr(o,a):null)??er(n),d,c,u={};switch(i){case"click":{let p=Np(t),g=Rp(t);p==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},p&&p!=="left"&&(u.button=p),g&&(u.modifiers=g);break}case"fill":{let p=e.text||e.value||Qa(t)||"";d="fill",c=p?`Fill ${l} with '${p}'`:`Fill ${l}`,u={value:p,index:0};break}case"press":{let p=e.key||Qa(t)||"";d="press",c=`Press '${p}' on ${l}`,u={keyComb:p,index:0};break}case"selectOption":{let p=e.options?.[0]||Qa(t)||"";d="select_dropdown_option",c=`Select '${p}' from ${l}`,u={text:p,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let p=e.files||[];d="upload_file",c=p.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:p,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var Rd,Fd,Wd=y(()=>{"use strict";Rd=require("uuid"),Fd=()=>(0,Rd.v4)()});var nr,or,Bd,Ud=y(()=>{"use strict";nr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(nr||{}),or=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(or||{}),Bd=18e4});function Gd(e){return e?e.startsWith(he)?"android":e.startsWith(me)?"ios":"web":"web"}function Kd(e){return e?e.startsWith(he)||e.startsWith(me):!1}function jd(e){return!!e&&e.startsWith(he)}function zd(e){return!!e&&e.startsWith(me)}function Vd(e){return e.startsWith(he)?e.slice(he.length):e.startsWith(me)?e.slice(me.length):e}function Xd(e){return`${he}${e}`}function Yd(e){return`${me}${e}`}function Ao(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Jd(e){return e?!Ao(e):!1}function ar(e){return e?Ao(e)?["web"]:["android","ios"]:["web","android","ios"]}function qd(e,t){if(!t)return!0;let i=ar(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var he,me,Mo=y(()=>{"use strict";he="android:",me="ios:"});function Zd(e){return e.startsWith(me)?e:`${me}${e}`}function Qd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function eu(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var tu=y(()=>{"use strict";Mo()});var rr,Co,sr,lr,cr,dr,ur,hr,mr,pr,Qe,gr,Hi,fr,wr,At,iu,Wi,nu,ou,Io,au,ru,su,lu,cu=y(()=>{"use strict";rr="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Co=112,sr=1920,lr=1080,cr=1920,dr=1080-Co,ur=1280,hr=720,mr=500,pr=500,Qe="Desktop Chrome",gr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(gr||{}),Hi={"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"}},fr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(fr||{}),wr={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},At=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),wr[e].map(n=>Hi[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},iu=()=>Object.keys(Hi),Wi=e=>Hi[e],nu={desktop:{label:"Desktop",type:"desktop",devices:At("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:At("mobile")}},ou={desktop:{label:"Desktop",type:"desktop",devices:At("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:At("mobile",!0)}},Io=(e,t=!1)=>{let i={userAgent:rr,viewport:{width:cr,height:dr},isMobile:!1,hasTouch:!1};if(!e||e===Qe)return i;let n=Wi(e);if(!n)return i;let{width:o,height:a}=n.viewport,r=Math.max(mr/o,1),s=Math.max(pr/a,1),l=Math.max(r,s),d={width:Math.round(o*l),height:Math.round(a*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},au=e=>{let t={width:sr,height:lr};if(!e||e===Qe)return t;let i=Io(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Co}:t},ru=e=>{let t={width:ur,height:hr};if(!e||e===Qe)return t;let i=Io(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},su=e=>!e||e===Qe?void 0:Wi(e)?.channel,lu=e=>!e||e===Qe?"chromium":Wi(e)?.defaultBrowserType??"chromium"});var br,yr,du=y(()=>{"use strict";br=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(br||{}),yr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(yr||{})});function uu(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=a=>{let r=a.startsWith("$")?a.slice(1):a,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},o=e;return o=o.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/<secret>\$?([\w-]+)<\/secret>/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o=o.replace(/\$\{([^}]+)\}/g,(a,r)=>{let s=n(r.trim());return s!==void 0?s:a}),o=o.replace(/\$([a-zA-Z_]\w*)/g,(a,r)=>{let s=n(r);return s!==void 0?s:a}),o}var hu=y(()=>{"use strict"});var mu,pu=y(()=>{"use strict";mu=class{version;goal;url;constructor(e,t){this.version=e,this.goal=t.goal,this.url=t.url}generatePrelude(){let e=`// version ${this.version}
4531
4531
  `,t=this.goal,i=this.url;e+=`// Navigate to the specified URL
4532
4532
  const targetUrl = process.env.PLAYWRIGHT_STARTING_URL || '${i}';
4533
4533
  if (targetUrl !== null) {
@@ -4540,7 +4540,5 @@ await page.waitForTimeout(2000);
4540
4540
 
4541
4541
  `,e+=` // Goal:
4542
4542
  `;let n=t.trim().split(`
4543
- `);for(let a of n)e+=` // ${a}
4544
- `;return e}generatePostlude(){return""}}});function qc(e){if(!e)return"desktop";for(let t of rp)if(t.test(e))return"mobile";return"desktop"}var rp,Zc=b(()=>{"use strict";rp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});function Qc(e,t){if(!e||typeof e!="string")return e;let i=t instanceof Map?Object.fromEntries(t):t,n=o=>{let r=o.startsWith("$")?o.slice(1):o,s=i[r]??i[`$${r}`];return s!=null?String(s):void 0},a=e;return a=a.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/<secret>\$?([\w-]+)<\/secret>/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a=a.replace(/\$\{([^}]+)\}/g,(o,r)=>{let s=n(r.trim());return s!==void 0?s:o}),a=a.replace(/\$([a-zA-Z_]\w*)/g,(o,r)=>{let s=n(r);return s!==void 0?s:o}),a}var ed=b(()=>{"use strict"});function Do(e){let t=e.match(/\.getByRole\(['"]([^'"]+)['"]/);if(t&&t[1]){let m=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(m&&m[1]){let T=m[1].replace(/\\(.)/g,"$1");return`${t[1]} element with text "${T}"`}let x=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(x&&x[1]){let T=x[1].replace(/^\/|\/$/g,""),v=T.length>30?`${T.substring(0,27)}...`:T;return`${t[1]} element with text matching "${v}"`}return`${t[1]} element`}let i=e.match(/\.filter\(\{\s*hasText:\s*['"]([^'"]*(?:\\.[^'"]*)*)['"]\s*\}\)/);if(i&&i[1]){let m=_t(e),x=i[1].replace(/\\(.)/g,"$1");return`${m} with text "${x}"`}let n=e.match(/\.filter\(\{\s*hasText:\s*(\/.*?\/[gimuy]*)\s*\}\)/);if(n&&n[1])return`${_t(e)} with text matching ${n[1]}`;let a=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(a&&a[1]){let m=_t(e),x=a[1].replace(/\\(.)/g,"$1");return`${m} containing "${x}"`}let o=e.match(/\.filter\(\{\s*has:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(o&&o[1]){let m=_t(e),x=o[1].replace(/\\(.)/g,"$1");return`${m} containing "${x}"`}let r=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(r&&r[1]){let m=_t(e),x=r[1].replace(/\\(.)/g,"$1");return`${m} not containing "${x}"`}let s=e.match(/\.filter\(\{\s*hasNot:\s*[^}]+getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(s&&s[1]){let m=_t(e),x=s[1].replace(/\\(.)/g,"$1");return`${m} not containing "${x}"`}let l=e.match(/name:\s*'((?:[^'\\]|\\.)*)'/);if(l&&l[1])return`"${l[1].replace(/\\(.)/g,"$1")}"`;let d=e.match(/name:\s*"((?:[^"\\]|\\.)*)"/);if(d&&d[1])return`"${d[1].replace(/\\(.)/g,"$1")}"`;let c=e.match(/getByText\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(c&&c[1])return`"${c[1].replace(/\\(.)/g,"$1")}"`;let u=e.match(/getByText\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(u&&u[1])return`"${u[1].replace(/\\(.)/g,"$1")}"`;let p=e.match(/getByPlaceholder\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(p&&p[1])return`input with placeholder "${p[1].replace(/\\(.)/g,"$1")}"`;let g=e.match(/getByPlaceholder\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(g&&g[1])return`input with placeholder "${g[1].replace(/\\(.)/g,"$1")}"`;let w=e.match(/getByLabel\('((?:[^'\\]|\\.)*)'(?:,\s*\{[^}]*\})?\)/);if(w&&w[1])return`"${w[1].replace(/\\(.)/g,"$1")}"`;let k=e.match(/getByLabel\("((?:[^"\\]|\\.)*)"(?:,\s*\{[^}]*\})?\)/);if(k&&k[1])return`"${k[1].replace(/\\(.)/g,"$1")}"`;let y=e.match(/getByRole\(['"]([^'"]+)['"]/);return y&&y[1]?`${y[1]} element`:e.length>50?`${e.substring(0,47)}...`:e}function Lo(e,t){if(!e||!t)return null;let i=t.replace(/^ref=/,""),n=e.split(`
4545
- `);for(let a of n){if(!a.includes(`[ref=${i}]`))continue;let s=a.replace(/\s+\[[^\]]+\](?:\s*\[[^\]]+\])*.*$/,"").trim().replace(/^[-–—]\s*/,"").trim().replace(/\\"/g,'"');return s.length>0?s:null}return null}function Oo(e,t=""){let i=e.match(/page\d*\.(.+?)\.(click|fill|press|check|uncheck|hover|selectOption|dragTo|dblclick|screenshot|setInputFiles|locator|frameLocator)/);if(i&&i[1])return i[1].trim();let n=e.match(/page\d*\.locator\(([^)]+)\)/);if(n&&n[1])return`locator(${n[1]})`;let a=e.match(/page\d*\.frameLocator\(([^)]+)\)/);return a&&a[1]?`frameLocator(${a[1]})`:t}function _t(e){let t=e.match(/^locator\(['"]([^'"]+)['"]\)/);if(t&&t[1]){let a=t[1],o=a.match(/^([a-zA-Z][\w-]*)/);return o?o[1]:a.length>20?`${a.substring(0,17)}...`:a}let i=e.match(/getByRole\(['"]([^'"]+)['"]/);if(i&&i[1])return i[1];let n=e.match(/getByTestId\(['"]([^'"]+)['"]/);return n&&n[1]?`element with testId "${n[1]}"`:"element"}function Po(e){let t=e.match(/\.fill\(['"]([^'"]*)['"]\)/);if(t&&t[1]!==void 0)return t[1];let i=e.match(/\.press\(['"]([^'"]+)['"]\)/);if(i&&i[1])return i[1];let n=e.match(/\.selectOption\(['"]([^'"]+)['"]\)/);return n&&n[1]?n[1]:""}function sp(e){let t=e.match(/button:\s*['"]([^'"]+)['"]/);return t?t[1]:void 0}function lp(e){let t=e.match(/modifiers:\s*\[([^\]]+)\]/);if(t&&t[1])return t[1].split(",").map(i=>i.trim().replace(/['"]/g,""))}function nd(e,t){let i=e.name||"unknown",n=Oo(t,e.selector||""),a=e.ariaSnapshot??e.arIAaSnapshot??"",o=e.ref,r=/getByTestId\s*\(/.test(n),l=(o&&a&&r?Lo(a,o):null)??Do(n),d,c,u={};switch(i){case"click":{let p=sp(t),g=lp(t);p==="right"?(d="right_click_on_element",c=`Right click on ${l}`):(d="click_element",c=`Click on ${l}`),u={index:0},p&&p!=="left"&&(u.button=p),g&&(u.modifiers=g);break}case"fill":{let p=e.text||e.value||Po(t)||"";d="fill",c=p?`Fill ${l} with '${p}'`:`Fill ${l}`,u={value:p,index:0};break}case"press":{let p=e.key||Po(t)||"";d="press",c=`Press '${p}' on ${l}`,u={keyComb:p,index:0};break}case"selectOption":{let p=e.options?.[0]||Po(t)||"";d="select_dropdown_option",c=`Select '${p}' from ${l}`,u={text:p,index:0};break}case"check":d="click_element",c=`Check ${l}`,u={index:0};break;case"uncheck":d="click_element",c=`Uncheck ${l}`,u={index:0};break;case"setInputFiles":{let p=e.files||[];d="upload_file",c=p.length>0?`Upload file(s) to ${l}`:`Upload file to ${l}`,u={paths:p,index:0};break}case"navigate":case"goto":d="go_to_url",c=`Navigate to ${e.url||"URL"}`,u={url:e.url||"",new_tab:!1};break;case"dblclick":d="double_click_on_element",c=`Double click on ${l}`,u={index:0};break;case"hover":d="hover",c=`Hover over ${l}`,u={index:0};break;case"wheel":case"scroll":d="scroll",c=`Scroll on ${l}`,u={x:e.deltaX||0,y:e.deltaY||0,index:e.selector?0:-1};break;case"dragTo":d="drag_drop",c=`Drag ${l} to target`,u={index:0};break;case"screenshot":d="wait",c="Take screenshot",u={seconds:.5};break;case"wait":d="wait",c=`Wait for ${e.timeout||1e3}ms`,u={seconds:(e.timeout||1e3)/1e3};break;default:d="click_element",c=`${i} on ${l}`,u={index:0};break}return{locator:n,xpath:e.xpath||"",css_selector:e.css_selector||"",unique_selector:e.selector||e.css_selector||"",frame_path:e.frame_path||[],action_data:{action_name:d,args:[],kwargs:u},action_description:c,url:"",feedback:""}}var td,id,ad=b(()=>{"use strict";td=require("uuid"),id=()=>(0,td.v4)()});var S,No,wa,Ro,qe,Fo,Ho,Wo,ae,Bo,Li,ba,Go=b(()=>{"use strict";S=require("zod"),No=S.z.enum(["JS_CODE","AI_MODE"]),wa=S.z.object({type:No,expression:S.z.string()}),Ro=S.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),qe=S.z.object({uid:S.z.string(),type:Ro,comment:S.z.string().optional()}),Fo=S.z.object({action_data:S.z.object({action_name:S.z.string(),kwargs:S.z.record(S.z.any()).optional(),args:S.z.array(S.z.any()).optional()}),action_description:S.z.string().optional(),url:S.z.string().optional(),xpath:S.z.string().nullable().optional(),locator:S.z.string().nullable().optional(),css_selector:S.z.string().nullable().optional(),unique_selector:S.z.string().nullable().optional(),element_index:S.z.number().nullable().optional(),frame_path:S.z.array(S.z.any()).optional(),artifacts:S.z.record(S.z.any()).optional(),feedback:S.z.string().optional(),original_browser_use_action:S.z.any().optional()}).passthrough(),Ho=qe.extend({type:S.z.literal("DRAFT"),description:S.z.string()}),Wo=qe.extend({type:S.z.literal("ACTION"),description:S.z.string(),action_entity:Fo.optional(),locator:S.z.string().optional(),use_pure_vision:S.z.boolean().optional()}),ae=S.z.lazy(()=>S.z.union([Ho,Wo,qe.extend({type:S.z.literal("STEP"),description:S.z.string().optional().default(""),statements:S.z.array(ae),reference_id:S.z.number().optional()}),qe.extend({type:S.z.literal("IF_ELSE"),description:S.z.string().optional(),condition:wa,then:S.z.array(ae),else:S.z.array(ae).optional()}),qe.extend({type:S.z.literal("WHILE_LOOP"),description:S.z.string().optional(),condition:wa,body:S.z.array(ae),timeout_ms:S.z.number().optional()})])),Bo=S.z.object({name:S.z.string(),statements:S.z.array(ae),teardown:S.z.array(ae).optional(),skip:S.z.union([S.z.boolean(),S.z.string()]).optional(),timeout:S.z.number().optional(),fail:S.z.union([S.z.boolean(),S.z.string()]).optional(),only:S.z.boolean().optional(),slow:S.z.boolean().optional()}),Li=S.z.object({tests:S.z.array(Bo).min(1),beforeAll:S.z.array(ae).optional(),afterAll:S.z.array(ae).optional(),beforeEach:S.z.array(ae).optional(),afterEach:S.z.array(ae).optional()}),ba=S.z.object({comment:S.z.string().optional(),version:S.z.string().optional(),goal:S.z.string().optional(),url:S.z.string().optional(),baseURL:S.z.string().optional(),final_feedback:S.z.string().optional(),completed:S.z.boolean().optional(),success:S.z.boolean().optional(),statements:S.z.array(ae).optional(),teardown:S.z.array(ae).optional(),last_modified_at:S.z.string().optional(),testGroup:Li.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"})});function Ko(e,t){let i={...t?.test_case_id!==void 0?{test_case_id:t.test_case_id}:{},...t?.name?{name:t.name}:{},goal:e.goal??"",url:e.url,base_url:e.baseURL,statements:(e.statements??[]).map(de)};return e.final_feedback&&(i.final_feedback=e.final_feedback),e.teardown&&e.teardown.length>0&&(i.teardown=e.teardown.map(de)),i}function ld(e,t){if(e.testGroup)return jo(e,t);let i=Ko(e,t),n=new P.Document(i);return e.comment&&(n.commentBefore=e.comment),od(n,e.statements??[]),e.teardown&&od(n,e.teardown,"teardown"),n.toString(Et)}function od(e,t,i="statements"){let n=e.contents;if(!n||!(0,P.isMap)(n))return;let a=n.get(i,!0);(0,P.isSeq)(a)&&Oi(a,t)}function Oi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),(0,P.isMap)(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);(0,P.isSeq)(r)&&Oi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);(0,P.isSeq)(r)&&Oi(r,n.then);let s=o.get("ELSE",!0);(0,P.isSeq)(s)&&n.else&&Oi(s,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);(0,P.isSeq)(r)&&Oi(r,n.body)}}}}function jo(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use);let a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(de)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(de)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(de)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(de)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(de),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(de)),r}),n.suite=a,(0,P.stringify)(n,Et)}function cd(e){return e.map(t=>(0,P.stringify)(t,Et)).join(`---
4546
- `)}function de(e){switch(e.type){case"DRAFT":return cp(e);case"ACTION":return dd(e);case"STEP":return up(e);case"IF_ELSE":return hp(e);case"WHILE_LOOP":return mp(e)}}function cp(e){return{intent:e.description}}function dd(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let s=i?.statement;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l=i?.code;return typeof l=="string"?{VERIFY:s,js:l}:{VERIFY:s}}}if(t==="go_to_url"){let s=i?.url;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let l={URL:s};return i?.new_tab===!0&&(l.new_tab=!0),typeof i?.timeout_seconds=="number"&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="js_action"){let s=i?.code;if(typeof s=="string"&&e.description)return{intent:e.description,js:s}}if(t==="ai_wait_until"){let s=i?.condition;if(typeof s=="string"){let l={WAIT_UNTIL:s};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(l.timeout_seconds=i.timeout_seconds),l}}if(t==="wait"){let s=i?.seconds,d={WAIT:e.description||`Wait ${s}s`};return typeof s=="number"&&(d.seconds=s),d}if(t==="js_code"){let s=i?.code;if(typeof s=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:s}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[s,l]of Object.entries(n.kwargs))a[s]=l;return n.args&&n.args.length>0&&(a.args=n.args),a}function ud(e,t,i){let n={uid:"",type:"ACTION",description:t||e.action_description||"",action_entity:e,locator:i},a=dd(n);if(typeof a=="object"&&a!==null){let o={...a};return delete o.intent,delete o.VERIFY,delete o.WAIT_UNTIL,delete o.WAIT,delete o.statement,Object.keys(o).length>0?(0,P.stringify)(o,Et).trim():""}return(0,P.stringify)(a,Et).trim()}function hd(e){let t=(0,P.parse)(e);if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object");if("VERIFY"in t){let c=String(t.VERIFY),u=typeof t.js=="string"?t.js:void 0;return{description:c,actionEntity:{action_description:c,action_data:{action_name:"verify",kwargs:{statement:c,...u?{code:u}:{}}}}}}if("URL"in t){let c=String(t.URL),u={url:c};return t.new_tab===!0&&(u.new_tab=!0),typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Navigate to ${c}`,actionEntity:{action_description:`Navigate to ${c}`,action_data:{action_name:"go_to_url",kwargs:u}}}}if("CODE"in t){let c=String(t.CODE);return{description:c,actionEntity:{action_description:c,action_data:{action_name:"js_code",kwargs:{code:c}}}}}if("WAIT_UNTIL"in t){let c=String(t.WAIT_UNTIL),u={condition:c};return typeof t.timeout_seconds=="number"&&(u.timeout_seconds=t.timeout_seconds),{description:`Wait until ${c}`,actionEntity:{action_description:`Wait until ${c}`,action_data:{action_name:"ai_wait_until",kwargs:u}}}}if("WAIT"in t){let c=String(t.WAIT),u={};return typeof t.seconds=="number"&&(u.seconds=t.seconds),{description:c,actionEntity:{action_description:c,action_data:{action_name:"wait",kwargs:u}}}}let i=typeof t.intent=="string"?t.intent:void 0,n=typeof t.action=="string"?t.action:void 0,a=typeof t.locator=="string"?t.locator:void 0,o=typeof t.xpath=="string"?t.xpath:void 0,r=Array.isArray(t.frame_path)?t.frame_path:void 0,s=Array.isArray(t.args)?t.args:void 0,l={};for(let[c,u]of Object.entries(t))dp.has(c)||(l[c]=u);return!n&&t.js?{description:i,actionEntity:{action_description:i||"",action_data:{action_name:"js_action",kwargs:{code:t.js}}}}:n?{actionEntity:{action_description:i||"",action_data:{action_name:n,kwargs:l,...s&&s.length>0?{args:s}:{}},...a?{locator:a}:{},...o?{xpath:o}:{},...r?{frame_path:r}:{}},description:i,locator:a}:{description:i,actionEntity:{action_description:i||""}}}function up(e){let t={STEP:e.description,statements:e.statements.map(de)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function hp(e){let t={IF:md(e.condition),THEN:e.then.map(de)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(de)),t}function mp(e){let t={WHILE:md(e.condition),DO:e.body.map(de)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function md(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function pd(e){let t=(0,P.parseAllDocuments)(e),i;if(t.length>1||t.length===1&&!Array.isArray(t[0]?.toJSON()))i=t.map((n,a)=>n.errors.length>0?{__parseError:`Document ${a+1}: ${n.errors[0].message}`}:n.toJSON());else{let n;try{n=(0,P.parse)(e)}catch(a){throw new Error(`Invalid YAML: ${a instanceof Error?a.message:String(a)}`)}if(!Array.isArray(n))throw new Error("Expected a YAML array or multi-document YAML (separated by ---)");i=n}return i.map((n,a)=>{try{if(n&&typeof n=="object"&&"__parseError"in n)return{error:n.__parseError};if(!n||typeof n!="object")return{error:`Item ${a+1}: expected an object`};let o=n,r=typeof o.name=="string"&&o.name.trim()||void 0,s=typeof o.goal=="string"?o.goal.trim():"";if(!s)return{error:`Item ${a+1}: missing "goal" field`};if(Array.isArray(o.statements))try{let l=(0,P.stringify)(o,Et),d=Ze(l);return{name:r,goal:d.goal??s,testFlow:d}}catch{}return{name:r,goal:s}}catch(o){return{error:`Item ${a+1}: ${o instanceof Error?o.message:String(o)}`}}})}function gd(e){try{let t=(0,P.parse)(e);if(!t||typeof t!="object")return{};let i={};return typeof t.test_case_id=="number"&&Number.isFinite(t.test_case_id)&&(i.test_case_id=t.test_case_id),typeof t.template_id=="number"&&Number.isFinite(t.template_id)&&(i.template_id=t.template_id),typeof t.name=="string"&&t.name.trim()&&(i.name=t.name.trim()),i}catch{return{}}}function Uo(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Uo);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]=Uo(o);return n}function Ze(e){if(e.length>rd)throw new Error(`YAML input too large (${e.length} bytes, max ${rd})`);let t=Uo((0,P.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return pp(t);let i={version:"1.3.0",goal:t.goal,url:t.url,baseURL:t.base_url,statements:ue(t.statements??[])};t.final_feedback&&(i.final_feedback=t.final_feedback),t.teardown&&Array.isArray(t.teardown)&&(i.teardown=ue(t.teardown));let n=ba.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return zo(e,a),a}function pp(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let a={tests:i.map(s=>{if(!s.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(s.statements)||s.statements.length===0)throw new Error(`Suite test "${s.name}" must have a non-empty "statements" array`);let l={name:s.name,statements:ue(s.statements)};return Array.isArray(s.teardown)&&s.teardown.length>0&&(l.teardown=ue(s.teardown)),s.skip!==void 0&&(l.skip=s.skip),typeof s.timeout=="number"&&(l.timeout=s.timeout),s.fail!==void 0&&(l.fail=s.fail),s.only===!0&&(l.only=!0),s.slow===!0&&(l.slow=!0),l})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=ue(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ue(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ue(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ue(t.afterEach));let o=Li.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 ue(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(gp)}function gp(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 fp(t);if("WHILE"in t)return wp(t);if("STEP"in t)return bp(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,ce.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:(0,ce.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,ce.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,ce.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,ce.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)){let i=t.js,n=typeof t.intent=="string"?t.intent:typeof t.desc=="string"?t.desc:"";return{uid:(0,ce.v4)(),type:"ACTION",description:n,action_entity:{action_description:n,action_data:{action_name:"js_action",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("call"in t&&typeof t.call=="string"){let{call:i,...n}=t;return sd({...n,action:"function",functionName:i})}if("action"in t)return sd(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,ce.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function fd(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 fp(e){let t=fd(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,ce.v4)(),type:"IF_ELSE",condition:t,then:ue(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ue(e.ELSE)),n}function wp(e){let t=fd(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,ce.v4)(),type:"WHILE_LOOP",condition:t,body:ue(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function bp(e){let t=typeof e.STEP=="string"?e.STEP:"";if(!Array.isArray(e.statements))throw new Error("STEP requires a statements array");let i={uid:(0,ce.v4)(),type:"STEP",description:t,statements:ue(e.statements)};return typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),i}function sd(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[d,c]of Object.entries(e))yp.has(d)||(r[d]=c);let s={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(s.locator=n),a&&(s.xpath=a);let l={uid:(0,ce.v4)(),type:"ACTION",description:i,action_entity:s};return o&&(l.use_pure_vision=!0),l}function zo(e,t){let i;try{i=(0,P.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,P.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let l=n.items?.[0];l?.key&&l.key.commentBefore&&(t.comment=l.key.commentBefore)}let a=n,o=a.get("statements",!0);(0,P.isSeq)(o)&&t.statements&&St(o,t.statements);let r=a.get("teardown",!0);(0,P.isSeq)(r)&&t.teardown&&St(r,t.teardown)}function St(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let a=t[i];if(a.type==="STEP"&&(0,P.isMap)(n)){let o=n.get("statements",!0);(0,P.isSeq)(o)&&St(o,a.statements)}else if(a.type==="IF_ELSE"&&(0,P.isMap)(n)){let o=n.get("THEN",!0);(0,P.isSeq)(o)&&St(o,a.then);let r=n.get("ELSE",!0);(0,P.isSeq)(r)&&a.else&&St(r,a.else)}else if(a.type==="WHILE_LOOP"&&(0,P.isMap)(n)){let o=n.get("DO",!0);(0,P.isSeq)(o)&&St(o,a.body)}}}var P,ce,Et,dp,rd,yp,ya=b(()=>{"use strict";Go();P=require("yaml"),ce=require("uuid");Et={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};dp=new Set(["intent","action","locator","xpath","frame_path","args"]);rd=1024*1024;yp=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});function Vo(e,t){let i=[];t.version!=="1.0"&&i.push(`Unsupported patch version: ${t.version}`),(!Array.isArray(t.operations)||t.operations.length===0)&&i.push("Patch must have at least one operation");for(let n=0;n<t.operations.length;n++){let a=t.operations[n],o=`operations[${n}]`;switch(a.reason||i.push(`${o}: missing reason`),a.op){case"remove":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`);break}case"modify":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}case"insert":{(typeof a.index!="number"||a.index<0||a.index>=e.length)&&i.push(`${o}: index ${a.index} out of bounds (0..${e.length-1})`),a.position!=="before"&&a.position!=="after"&&i.push(`${o}: position must be 'before' or 'after'`),(a.statement===void 0||a.statement===null)&&i.push(`${o}: missing statement`);break}default:i.push(`${o}: unknown operation type "${a.op}"`)}}return{valid:i.length===0,errors:i}}function Xo(e,t){let i=Vo(e,t);if(!i.valid)throw new Error(`Invalid patch: ${i.errors.join("; ")}`);let n=[...e],a=t.operations.map((s,l)=>({...s,originalOrder:l})),o={remove:0,modify:1,insert:2},r=[...a].sort((s,l)=>s.index!==l.index?l.index-s.index:o[s.op]-o[l.op]);for(let s of r)switch(s.op){case"remove":n.splice(s.index,1);break;case"modify":n[s.index]=s.statement;break;case"insert":s.position==="before"?n.splice(s.index,0,s.statement):n.splice(s.index+1,0,s.statement);break}return n}function wd(e,t){let i=(0,xa.parse)(e);if(!i||typeof i!="object")throw new Error("Invalid YAML: expected an object at root level");let n=i.statements;if(!Array.isArray(n))throw new Error('YAML must have a "statements" array');let a=Xo(n,t);i.statements=a;let o=(0,xa.stringify)(i,{lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"});return Ze(o),{modifiedYaml:o,modifiedStatements:a}}var xa,bd=b(()=>{"use strict";ya();xa=require("yaml")});function Yo(e){for(let t of e){if(t.type==="STEP"&&t.reference_id)return!0;let i=Ce(t);for(let n of i)if(Yo(n.statements))return!0}return!1}function vd(e){let t=new Set;function i(n){for(let a of n){a.type==="STEP"&&a.reference_id&&t.add(a.reference_id);let o=Ce(a);for(let r of o)i(r.statements)}}return i(e),Array.from(t)}function Sd(e){if(!e?.statements||!Array.isArray(e.statements))return{};let t={};return We(e.statements,"main",t),e.teardown&&Array.isArray(e.teardown)&&We(e.teardown,"teardown",t),t}function Ne(e,t,i){let n=e+".",a=t.filter(([c])=>c===e||c.startsWith(n));if(a.length===0)return[];let o=[],r=new Set;for(let[c]of a){let u=c===e?"":c.slice(n.length);if(!u)continue;let p=u.split(".")[0];r.has(p)||r.add(p)}let s=Array.from(r);s.sort((c,u)=>{let p=/^\d+$/.test(c)?parseInt(c,10):-1,g=/^\d+$/.test(u)?parseInt(u,10):-1;return p>=0&&g>=0?p-g:c==="then"&&u==="else"?-1:c==="else"&&u==="then"||c==="body"?1:u==="body"?-1:c.localeCompare(u)});function l(c){return i[c]}function d(c){let u=c.match(/^(IF|WHILE)\s+([\s\S]+)$/);return{type:"AI_MODE",expression:(u?u[2].trim():c)||"true"}}for(let c of s){let u=e?`${e}.${c}`:c,p=l(u),g=p?.description??"",w=u;if(c==="then"){let v=`${e}.then`,E=`${e}.else`,A=Ne(v,t,i),C=Ne(E,t,i),I=l(e),L=I?d(I.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"IF_ELSE",condition:L,then:A,...C.length>0?{else:C}:{}});continue}if(c==="else")continue;if(c==="body"){let v=`${e}.body`,E=Ne(v,t,i),A=l(e),C=A?d(A.description):{type:"JS_CODE",expression:"true"};o.push({uid:e,type:"WHILE_LOOP",condition:C,body:E});continue}let k=`${e}.${c}`,y=t.some(([v])=>v.startsWith(k+".then.")||v===k+".then"),m=t.some(([v])=>v.startsWith(k+".else.")||v===k+".else"),x=t.some(([v])=>v.startsWith(k+".body.")||v===k+".body"),T=t.filter(([v])=>{if(!v.startsWith(k+"."))return!1;let A=v.slice(k.length+1).split(".")[0];return/^\d+$/.test(A)&&A!=="then"&&A!=="else"&&A!=="body"});if(y||m){let v=k+".then",E=k+".else",A=Ne(v,t,i),C=Ne(E,t,i),I=p?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"IF_ELSE",condition:I,then:A,...C.length>0?{else:C}:{}})}else if(x){let v=k+".body",E=Ne(v,t,i),A=p?d(g):{type:"JS_CODE",expression:"true"};o.push({uid:u,type:"WHILE_LOOP",condition:A,body:E})}else if(T.length>0){let v=Ne(k,t,i);o.push({uid:u,type:"STEP",description:g||"Group",statements:v})}else o.push({uid:u,type:"ACTION",description:g||"Action",action_entity:p?.action_entity})}return o}function Ed(e){let t=Object.entries(e),i=n=>{let a=n+".";return t.some(([r])=>r===n||r.startsWith(a))?Ne(n,t,e):[]};return{before:i("before"),main:i("main"),teardown:i("teardown"),after:i("after")}}var Ce,re,Re,Fe,He,Ni,yd,xd,xp,vp,kd,_d,We,va=b(()=>{"use strict";Ce=e=>{let t=[];switch(e.type){case"STEP":e.statements&&t.push({key:"statements",statements:e.statements});break;case"IF_ELSE":e.then&&t.push({key:"then",statements:e.then}),e.else&&t.push({key:"else",statements:e.else});break;case"WHILE_LOOP":e.body&&t.push({key:"body",statements:e.body});break}return t},re=(e,t,i=void 0,n="root")=>{for(let a=0;a<e.length;a++){let o=e[a],r=o.uid;if(r===t)return{stableId:r,path:[a],statement:o,parent:i,containerKey:n,index:a};let s=Ce(o);for(let l of s){let d=re(l.statements,t,o,l.key);if(d)return{...d,path:[a,l.key,...d.path]}}}return null},Re=(e,t,i)=>{let n=re(e,t);if(!n)return null;let{statement:a,parent:o,containerKey:r,index:s}=n,l=null;switch(a.type){case"DRAFT":case"ACTION":l=Fe(e,n)||He(e,n);break;case"STEP":if(a.statements&&a.statements.length>0)return a.statements[0];l=Fe(e,n)||He(e,n);break;case"IF_ELSE":if(i===!0&&a.then&&a.then.length>0)return a.then[0];if(i===!1&&a.else&&a.else.length>0)return a.else[0];l=Fe(e,n)||He(e,n);break;case"WHILE_LOOP":if(i===!0&&a.body&&a.body.length>0)return a.body[0];l=Fe(e,n)||He(e,n);break;default:l=Fe(e,n)||He(e,n);break}if(o&&o.type==="WHILE_LOOP"&&r==="body"){if(!l)return o;let d=re(e,l.uid);if(!d||d.parent!==o)return o}return l},Fe=(e,t)=>{if(!t.parent)return e[t.index+1]||null;let n=Ce(t.parent).find(a=>a.key===t.containerKey);return n&&t.index+1<n.statements.length?n.statements[t.index+1]:null},He=(e,t)=>{if(!t.parent)return null;let i=t.parent.uid,n=re(e,i);return n?Fe(e,n)||He(e,n):null},Ni=e=>{let t=[],i=n=>{for(let a of n){t.push(a);let o=Ce(a);for(let r of o)i(r.statements)}};return i(e),t},yd=e=>{switch(e.type){case"DRAFT":case"ACTION":return!0;case"STEP":return!0;case"IF_ELSE":case"WHILE_LOOP":return!0;default:return!1}},xd=(e,t,i)=>{if(!re(e,t))return null;if(i===null){let s=[],l=t;for(;l!==null&&re(e,l);)if(s.push(l),l=Re(e,l)?.uid||null,s.length>1e3)return null;return s}if(!re(e,i))return null;if(t===i)return[];let o=[],r=t;for(;r&&r!==i;){let s=re(e,r);if(!s)break;if(o.push(r),s.statement.type==="IF_ELSE"){let l=xp(s.statement,i);l?r=Re(e,r,l==="then")?.uid||null:r=Re(e,r)?.uid||null}else s.statement.type==="WHILE_LOOP"?vp(s.statement,i)?r=Re(e,r,!0)?.uid||null:r=Re(e,r,!1)?.uid||null:r=Re(e,r)?.uid||null;if(o.length>1e3)return null}return r===i?o:null},xp=(e,t)=>{if(e.type!=="IF_ELSE")return null;let i=e;return i.then&&re(i.then,t)?"then":i.else&&re(i.else,t)?"else":null},vp=(e,t)=>{if(e.type!=="WHILE_LOOP")return!1;let i=e;return!!(i.body&&re(i.body,t))};kd=e=>e.startsWith("ai_")?!0:["js_code","function","assert","verify","wait_for_download_complete","extract_activation_code","extract_email_content"].includes(e),_d=e=>!["js_code","function","assert","ai_assert","verify","ai_extract","ai_wait_until","upload_file","login","extract_activation_code","extract_email_content","ai_step"].includes(e),We=(e,t,i)=>{e.forEach((n,a)=>{let o=`${t}.${a}`;n.type==="DRAFT"?i[o]={description:n.description||"Draft",action_entity:void 0}:n.type==="ACTION"?i[o]={description:n.description||"Action",action_entity:n.action_entity}:n.type==="STEP"&&n.statements?We(n.statements,o,i):n.type==="IF_ELSE"?(i[o]={description:"IF "+(n.condition?.expression||""),action_entity:void 0},n.then&&We(n.then,`${o}.then`,i),n.else&&We(n.else,`${o}.else`,i)):n.type==="WHILE_LOOP"&&(i[o]={description:"WHILE "+(n.condition?.expression||""),action_entity:void 0},n.body&&We(n.body,`${o}.body`,i))})}});function qo(e){let t=0,i=0;for(let n of e)if(n.type==="DRAFT")i++;else if(n.type==="ACTION"){let a=n.action_entity?.action_data?.action_name??"";Jo.has(a)||t++}return{action:t,draft:i}}function _p(e){try{return new Function(`return async function() { ${e} }`),null}catch(t){return t.message}}function Td(e){try{return new Function(`return async function() { return (${e}) }`),null}catch(t){return t.message}}function Ad(e,t){let i=t?.coverageThreshold??kp,n=[],a=[],o;try{o=Ze(e)}catch(p){return{valid:!1,errors:[`Invalid YAML: ${p.message}`],warnings:[],stats:{total:0,action:0,draft:0,coverage:0}}}o.goal||n.push('Missing required field: "goal"'),o.statements?.length||n.push('Missing required field: "statements"');let r=[...Ni(o.statements??[]),...o.teardown?Ni(o.teardown):[]],{action:s,draft:l}=qo(r),d="Hint: in YAML double-quoted strings, backslashes are escape characters \u2014 use \\\\/ instead of \\/ for regex, or use single quotes.";for(let p of r){if(p.type==="ACTION"){let g=p,w=g.action_entity?.action_data?.action_name??"";if(w==="js_code"||w==="js_action"||w==="verify"||w==="ai_assert"){let k=g.action_entity?.action_data?.kwargs?.code;if(typeof k=="string"){let y=_p(k);if(y){let m=g.description||w;n.push(`Invalid JS in "${m}": ${y}. ${d}`)}}}}if(p.type==="IF_ELSE"){let g=p;if(g.condition.type==="JS_CODE"){let w=Td(g.condition.expression);w&&n.push(`Invalid JS in IF condition "${g.condition.expression}": ${w}. ${d}`)}}if(p.type==="WHILE_LOOP"){let g=p;if(g.condition.type==="JS_CODE"){let w=Td(g.condition.expression);w&&n.push(`Invalid JS in WHILE condition "${g.condition.expression}": ${w}. ${d}`)}}}let c=s+l,u=c>0?Math.round(s/c*100):0;return c>0&&u/100<i&&a.push(`Low action coverage: ${s}/${c} statements (${u}%) are enriched with action/js. ${l} draft statement(s) still need enrichment. Use MCP tools (act, get_locators) to convert drafts to actions.`),{valid:n.length===0,errors:n,warnings:a,stats:{total:c,action:s,draft:l,coverage:u}}}var kp,Jo,Md=b(()=>{"use strict";ya();va();kp=.5,Jo=new Set(["verify","ai_assert","done","go_to_url","ai_wait_until","wait","js_code"])});function Id(e){return e?e.startsWith(pe)?"android":e.startsWith(ge)?"ios":"web":"web"}function Cd(e){return e?e.startsWith(pe)||e.startsWith(ge):!1}function $d(e){return!!e&&e.startsWith(pe)}function Pd(e){return!!e&&e.startsWith(ge)}function Dd(e){return e.startsWith(pe)?e.slice(pe.length):e.startsWith(ge)?e.slice(ge.length):e}function Ld(e){return`${pe}${e}`}function Od(e){return`${ge}${e}`}function ka(e){return e?e.startsWith("http://")||e.startsWith("https://"):!1}function Nd(e){return e?!ka(e):!1}function Zo(e){return e?ka(e)?["web"]:["android","ios"]:["web","android","ios"]}function Rd(e,t){if(!t)return!0;let i=Zo(t);return e==="desktop"||e==="mobile"?i.includes("web"):i.includes(e)}var pe,ge,_a=b(()=>{"use strict";pe="android:",ge="ios:"});function Fd(e){return e.startsWith(ge)?e:`${ge}${e}`}function Hd(e){let t=e.iosVersion?` (iOS ${e.iosVersion})`:"";return e.deviceType==="simulator"?`${e.name}${t} - Simulator`:`${e.name}${t}`}function Wd(e){return!!(/^[0-9a-fA-F]{40}$/.test(e)||/^[0-9a-fA-F]{8}-[0-9a-fA-F]{16}$/.test(e))}var Bd=b(()=>{"use strict";_a()});var Qo,Sa,er,tr,ir,nr,ar,or,rr,sr,Qe,lr,Ri,cr,dr,Tt,Gd,Fi,Ud,Kd,Ea,jd,zd,Vd,Xd,Yd=b(()=>{"use strict";Qo="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",Sa=112,er=1920,tr=1080,ir=1920,nr=1080-Sa,ar=1280,or=720,rr=500,sr=500,Qe="Desktop Chrome",lr=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(lr||{}),Ri={"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"}},cr=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(cr||{}),dr={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"]},Tt=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),dr[e].map(n=>Ri[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},Gd=()=>Object.keys(Ri),Fi=e=>Ri[e],Ud={desktop:{label:"Desktop",type:"desktop",devices:Tt("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Tt("mobile")}},Kd={desktop:{label:"Desktop",type:"desktop",devices:Tt("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Tt("mobile",!0)}},Ea=(e,t=!1)=>{let i={userAgent:Qo,viewport:{width:ir,height:nr},isMobile:!1,hasTouch:!1};if(!e||e===Qe)return i;let n=Fi(e);if(!n)return i;let{width:a,height:o}=n.viewport,r=Math.max(rr/a,1),s=Math.max(sr/o,1),l=Math.max(r,s),d={width:Math.round(a*l),height:Math.round(o*l)};return{userAgent:n.userAgent,viewport:t?d:n.viewport,isMobile:n.isMobile,hasTouch:n.hasTouch}},jd=e=>{let t={width:er,height:tr};if(!e||e===Qe)return t;let i=Ea(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height+Sa}:t},zd=e=>{let t={width:ar,height:or};if(!e||e===Qe)return t;let i=Ea(e);return i.viewport?{width:i.viewport.width,height:i.viewport.height}:t},Vd=e=>!e||e===Qe?void 0:Fi(e)?.channel,Xd=e=>!e||e===Qe?"chromium":Fi(e)?.defaultBrowserType??"chromium"});var ur,hr,Jd=b(()=>{"use strict";ur=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(ur||{}),hr=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(hr||{})});function qd(){return{version:"1.0",entries:{}}}function Zd(e,t){return{action_entity:e,updated_at:new Date().toISOString(),updated_by:{source:"runner",test_run_id:t}}}function Qd(e,t){let i=t?.entries[e.uid],n=i?.action_entity??e.action_entity;return e.locator&&n?{...n,locator:e.locator}:i?i.action_entity:e.action_entity?e.action_entity:null}function eu(e,t,i,n){return e.entries[t]={action_entity:i,updated_at:new Date().toISOString(),updated_by:n},e}function tu(e,t){let i=e??{version:"1.0",entries:{}};for(let[n,a]of t)i.entries[n]=a;return i}function iu(e){return e?Object.keys(e.entries).length===0:!0}function nu(e){return e?Object.keys(e.entries).length:0}function au(e,t){if(!t||Object.keys(t.entries).length===0)return e;let i=mr(e.statements??[],t),n=e.teardown?mr(e.teardown,t):void 0;return{...e,statements:i,teardown:n}}function mr(e,t){return e.map(i=>Sp(i,t))}function Sp(e,t){if(e.type==="ACTION"){let a=e,o=t.entries[a.uid];return o?{...a,action_entity:o.action_entity}:a}let i=Ce(e);if(i.length===0)return e;let n={};for(let a of i)n[a.key]=mr(a.statements,t);return{...e,...n}}var ou=b(()=>{"use strict";va()});var pr,gr,ru,su=b(()=>{"use strict";pr=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(pr||{}),gr=(e=>(e.JS_CODE="JS_CODE",e.AI_MODE="AI_MODE",e))(gr||{}),ru=18e4});var lu,du=b(()=>{"use strict";lu=class cu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new cu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[a,o]of Object.entries(t.data))i.set(a,o,n.has(a))}return i}}});function uu(e){return{copilot:e?.models?.copilot||fr,webagent:e?.models?.webagent||br,computer_use:e?.models?.computer_use||wr}}function hu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.ANTHROPIC_API_KEY)return yr;if(e.GOOGLE_API_KEY)return xr;if(e.OPENAI_API_KEY)return vr}}var fr,wr,br,yr,xr,vr,mu=b(()=>{"use strict";fr="claude-sonnet-4-6",wr="computer-use-preview",br="gemini-2.5-pro",yr="claude-haiku-4-5",xr="gemini-3.1-flash-lite-preview",vr="gpt-5.4-mini"});var kr,pu=b(()=>{"use strict";kr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(kr||{})});function gu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],a=i[1],o="usb";return n.startsWith("emulator-")?o="emulator":n.includes(":")&&(o="wifi"),{id:n,state:a,connectionType:o}}function fu(e){return e.startsWith(pe)?e:`${pe}${e}`}function wu(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var bu=b(()=>{"use strict";_a()});var _r={};Ue(_r,{ADDRESS_BAR_HEIGHT:()=>Sa,ANDROID_DEVICE_PREFIX:()=>pe,ActionEntitySchema:()=>Fo,ActionSchema:()=>Wo,AgentStatus:()=>kr,BaseStatementSchema:()=>qe,BrowserType:()=>lr,ConditionSchema:()=>wa,ConditionType:()=>gr,ConditionTypeSchema:()=>No,DEFAULT_ANTHROPIC_MODEL:()=>yr,DEFAULT_COMPUTER_USE_MODEL:()=>wr,DEFAULT_COPILOT_MODEL:()=>fr,DEFAULT_DEVICE_NAME:()=>Qe,DEFAULT_GOOGLE_MODEL:()=>xr,DEFAULT_OPENAI_MODEL:()=>vr,DEFAULT_WEBAGENT_MODEL:()=>br,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>ru,DEVICE_CATEGORIES:()=>dr,DeviceType:()=>cr,DraftSchema:()=>Ho,IOS_DEVICE_PREFIX:()=>ge,LoginType:()=>ur,MIN_WINDOW_HEIGHT:()=>sr,MIN_WINDOW_WIDTH:()=>rr,NON_INTENT_ACTIONS:()=>Jo,NodeJSCodeCommon:()=>Yc,PLAYWRIGHT_DEVICES:()=>Ri,RECORD_VIDEO_HEIGHT:()=>or,RECORD_VIDEO_WIDTH:()=>ar,StatementSchema:()=>ae,StatementType:()=>pr,StatementTypeSchema:()=>Ro,TestFlowSchema:()=>ba,TestGroupEntrySchema:()=>Bo,TestGroupSchema:()=>Li,TwoFactorAuthType:()=>hr,UI_DEVICE_CATEGORIES:()=>Ud,UI_DEVICE_CATEGORIES_ELECTRON:()=>Kd,USER_AGENT:()=>Qo,VIEWPORT_HEIGHT:()=>nr,VIEWPORT_WIDTH:()=>ir,VariableStore:()=>lu,WINDOW_HEIGHT:()=>tr,WINDOW_WIDTH:()=>er,actionEntityToYaml:()=>ud,actionStepsMapToTestFlowSections:()=>Ed,allowPureVisionAction:()=>_d,applyPatchToYaml:()=>Xo,applyPatchToYamlString:()=>wd,collectActionSteps:()=>We,convertPlaywrightActionToEntity:()=>nd,countIntentStatements:()=>qo,createAndroidDeviceName:()=>Ld,createEmptyStore:()=>qd,createIOSDeviceName:()=>Od,createRunnerStoreEntry:()=>Zd,extractActionStepsFromTestFlow:()=>Sd,extractAndAttachComments:()=>zo,extractDeviceIdentifier:()=>Dd,extractElementDescription:()=>Do,extractElementDescriptionFromAriaSnapshot:()=>Lo,extractLocatorFromCode:()=>Oo,extractYamlMetadata:()=>gd,findNextAfterContainer:()=>He,findNextSibling:()=>Fe,findNextStatement:()=>Re,findPathBetweenStatements:()=>xd,findStatementPathById:()=>re,generateUid:()=>id,getAllDeviceNames:()=>Gd,getAllReferenceIds:()=>vd,getAllStatementsInOrder:()=>Ni,getAndroidDeviceDisplayName:()=>wu,getBrowserWindowSize:()=>jd,getCompatiblePlatforms:()=>Zo,getDeviceBrowserType:()=>Xd,getDeviceByName:()=>Fi,getDeviceChannel:()=>Vd,getDeviceOptions:()=>Ea,getDevicesByCategory:()=>Tt,getIOSDeviceDisplayName:()=>Hd,getLoginConfigPlatform:()=>qc,getRecordVideoSize:()=>zd,getStatementContainers:()=>Ce,getStoreSize:()=>nu,getTestPlatformFromDeviceName:()=>Id,hasReferenceIds:()=>Yo,isAndroidDevice:()=>$d,isAppPackage:()=>Nd,isDynamicAction:()=>kd,isExecutableStatement:()=>yd,isIOSDevice:()=>Pd,isNativeDevice:()=>Cd,isPhysicalDeviceUDID:()=>Wd,isPlatformCompatibleWithUrl:()=>Rd,isStoreEmpty:()=>iu,isWebUrl:()=>ka,mergeActionEntitiesIntoTestFlow:()=>au,mergeStoreUpdates:()=>tu,parseAdbDeviceLine:()=>gu,parseYamlArrayItems:()=>pd,replaceVariables:()=>Qc,resolveActionEntity:()=>Qd,resolveModelFromEnv:()=>hu,resolveModels:()=>uu,suiteToYaml:()=>jo,testFlowToYaml:()=>ld,testFlowToYamlObject:()=>Ko,toAndroidDeviceName:()=>fu,toIOSDeviceName:()=>Fd,updateStoreEntry:()=>eu,validatePatch:()=>Vo,validateTestYaml:()=>Ad,yamlObjectsToString:()=>cd,yamlToActionEntity:()=>hd,yamlToTestFlow:()=>Ze});var Sr=b(()=>{"use strict";Jc();Zc();ed();ad();bd();Md();ya();Go();Bd();Yd();Jd();ou();va();su();du();mu();pu();bu();_a()});var Ap={};Ue(Ap,{createTestContext:()=>Eu,expect:()=>At.expect,resolveAuthState:()=>_u,test:()=>Tp});module.exports=$u(Ap);var Be=W(require("path"),1),ku=W(require("fs"),1),At=require("@playwright/test");var te=W(require("fs"),1),tt=W(require("path"),1),Aa=require("crypto"),Ma=require("os");function Mr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function Ir(e){if(!te.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(te.readFileSync(e,"utf-8"))}catch(o){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${o}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,a=i.cookies.filter(o=>o&&typeof o=="object"&&typeof o.name=="string"&&typeof o.domain=="string");return a.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-a.length} malformed cookies (missing name or domain)`),a.map(o=>({...o,expires:n}))}function Cr(e){if(e){let i=tt.resolve(process.cwd(),e),n=tt.join((0,Ma.tmpdir)(),`ext-profile-${(0,Aa.randomUUID)()}`);if(te.existsSync(i)){try{te.cpSync(i,n,{recursive:!0})}catch(o){try{te.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${o}`)}let a=tt.join(n,"SingletonLock");te.existsSync(a)&&te.rmSync(a,{force:!0})}else te.mkdirSync(n,{recursive:!0});return n}let t=tt.join((0,Ma.tmpdir)(),`ext-profile-${(0,Aa.randomUUID)()}`);return te.mkdirSync(t,{recursive:!0}),t}async function _u(e){let i=await import(Be.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let a=await n(e.args||{});if(typeof a!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof a})`);return a}function yu(e){return!(!e||e==="off")}function Su(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?Su(e.mode,t):!0}async function xu(e,t,i){let n=Su(t,i);for(let a of e)try{if(n){let o=await a.path();await i.attach("video",{path:o,contentType:"video/webm"})}else await a.delete()}catch(o){console.warn("[fixture] Failed to process video:",o)}}var Ta;async function vu(){return Ta||(Ta=await Promise.resolve().then(()=>(Xc(),Vc)),Ta)}var Ep=new Set(["get","set","getAll","has","__variableStore"]);function Eu(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,a=!1){e.set(i,n,a)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,a){if(n in i)return Reflect.get(i,n,a);if(typeof n=="string")return i.get(n)},set(i,n,a){return typeof n!="string"||Ep.has(n)?Reflect.set(i,n,a):(i.set(n,a),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var Tp=At.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:a},o,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=Cr(n),u=i?Mr(Be.resolve(process.cwd(),i)):[],p={...r.project.use},{storageState:g,account:w,extensionDir:k,userDataDir:y,extensionStorageState:m,autoDismissModal:x,video:T,...v}=p,E=yu(T)?{dir:r.outputDir}:void 0,A;try{if(A=await At.chromium.launchPersistentContext(c,{...v,headless:d,args:u,viewport:v.viewport??{width:1280,height:720},...E?{recordVideo:E}:{}}),a){let C=Be.resolve(process.cwd(),a),I=Ir(C);I&&await A.addCookies(I)}await o(A)}finally{let C=A?.pages().map(I=>I.video()).filter(I=>I!==null)??[];if(await A?.close().catch(I=>{console.warn("[fixture] Failed to close persistent context:",I)}),await xu(C,T,r),!n)try{ku.rmSync(c,{recursive:!0,force:!0})}catch(I){console.warn("[fixture] Failed to clean up temp profile dir:",c,I)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await _u(c)}let u=l.video;yu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let p=await e.newContext(l);try{await o(p)}finally{let g=p.pages().map(w=>w.video()).filter(w=>w!==null);await p.close(),await xu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await vu(),n=new i,a=t.project.use.variables;if(a)for(let[r,s]of Object.entries(a))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let o=Eu(n);global.testContext=o,global.$=o,global.ctx=o,await e(o),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,a)=>{let{WebAgent:o,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await vu(),d=l();s({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??"",OPENAI_API_KEY:process.env.OPENAI_API_KEY??""},...d!==void 0&&{logLevel:d}});let{resolveModelFromEnv:c}=await Promise.resolve().then(()=>(Sr(),_r)),u=c(process.env);if(!u)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let p=t.__variableStore,g=r({model:u,variableStore:p,autoDismissModal:i}),w=Be.join(a.outputDir,"artifacts");g.stepTracking={results:{},artifactsDir:w};let k=new o(g),y=e.context();k.agentServices.setupPageTracking(y),global.agent=k,await n(k),delete global.agent;try{let m=a.outputDir;await k.writeExecutionResults(m);let x=Be.join(m,"test-results.json");await(await import("fs/promises")).stat(x).catch(()=>null)&&await a.attach("shiplight-results",{path:x,contentType:"application/json"})}catch(m){console.error("[Shiplight] Failed to attach step results:",m)}try{let m=k.getNewActionEntities();if(m.size>0&&a.status==="passed"){let{createEmptyStore:x,createRunnerStoreEntry:T}=await Promise.resolve().then(()=>(Sr(),_r)),v=await import("fs/promises"),E=x();for(let[C,I]of m)E.entries[C]=T(I,0);let A=Be.join(a.outputDir,"new-action-entities.json");await v.writeFile(A,JSON.stringify(E,null,2)),await a.attach("shiplight-new-action-entities",{path:A,contentType:"application/json"}),console.log(`[Shiplight] ${m.size} healed action entit${m.size===1?"y":"ies"} saved`)}}catch(m){console.warn("[Shiplight] Failed to persist new action entities:",m)}}});0&&(module.exports={createTestContext,expect,resolveAuthState,test});
4543
+ `);for(let o of n)e+=` // ${o}
4544
+ `;return e}generatePostlude(){return""}}});function gu(e){if(!e)return"desktop";for(let t of Fp)if(t.test(e))return"mobile";return"desktop"}var Fp,fu=y(()=>{"use strict";Fp=[/iphone/i,/ipad/i,/android/i,/pixel/i,/galaxy/i,/mobile/i,/nexus/i,/blackberry/i,/kindle/i]});var wu,yu=y(()=>{"use strict";wu=class bu{data={};sensitive=new Set;get(t){return this.data[t]}set(t,i,n=!1){this.data[t]=i,n?this.sensitive.add(t):this.sensitive.has(t)&&this.sensitive.delete(t)}getAll(){return{...this.data}}isSensitive(t){return this.sensitive.has(t)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(t){return this.sensitive.delete(t),delete this.data[t]}clear(){this.data={},this.sensitive.clear()}has(t){return t in this.data}get size(){return Object.keys(this.data).length}merge(t){for(let[i,n]of Object.entries(t.getAll()))this.set(i,n,t.isSensitive(i))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(t){let i=new bu;if(t.data){let n=new Set(t.sensitiveKeys||[]);for(let[o,a]of Object.entries(t.data))i.set(o,a,n.has(o))}return i}}});function xu(e){return{copilot:e?.models?.copilot||xr,webagent:e?.models?.webagent||_r,computer_use:e?.models?.computer_use||kr}}function vu(e){if(e){if(e.WEB_AGENT_MODEL)return e.WEB_AGENT_MODEL;if(e.ANTHROPIC_API_KEY)return Sr;if(e.GOOGLE_API_KEY)return Er;if(e.OPENAI_API_KEY)return Tr}}function Ar(e){return e?e.COMPUTER_USE_MODEL?e.COMPUTER_USE_MODEL:e.GOOGLE_API_KEY?vr:Bi:Bi}function ku(e,t=typeof process<"u"?process.env:{}){return t.COMPUTER_USE_MODEL?t.COMPUTER_USE_MODEL:e?.models?.computer_use?e.models.computer_use:Ar(t)}var xr,Bi,vr,kr,_r,Sr,Er,Tr,_u=y(()=>{"use strict";xr="claude-sonnet-4-6",Bi="gpt-5.4",vr="gemini-3-flash-preview",kr=Bi,_r="gemini-2.5-pro",Sr="claude-haiku-4-5",Er="gemini-3.1-flash-lite-preview",Tr="gpt-5.4-mini"});var Mr,Su=y(()=>{"use strict";Mr=(e=>(e.INITIALIZING="initializing",e.READY="ready",e.PROCESSING="processing",e.STOPPING="stopping",e.WAITING_USER="waiting_user",e.COMPLETED="completed",e.FAILED="failed",e))(Mr||{})});function Eu(e){let t=e.trim();if(!t||t.startsWith("List of devices"))return null;let i=t.split(/\s+/);if(i.length<2)return null;let n=i[0],o=i[1],a="usb";return n.startsWith("emulator-")?a="emulator":n.includes(":")&&(a="wifi"),{id:n,state:o,connectionType:a}}function Tu(e){return e.startsWith(he)?e:`${he}${e}`}function Au(e){return e.model?`${e.model} (${e.id})`:e.connectionType==="emulator"?`Android Emulator (${e.id})`:e.id}var Mu=y(()=>{"use strict";Mo()});var Cr={};Ge(Cr,{ADDRESS_BAR_HEIGHT:()=>Co,ANDROID_DEVICE_PREFIX:()=>he,ActionEntitySchema:()=>Fa,ActionSchema:()=>Wa,AgentStatus:()=>Mr,BaseStatementSchema:()=>qe,BrowserType:()=>gr,ConditionSchema:()=>ko,ConditionType:()=>or,ConditionTypeSchema:()=>Na,DEFAULT_ANTHROPIC_MODEL:()=>Sr,DEFAULT_COMPUTER_USE_MODEL:()=>kr,DEFAULT_COPILOT_MODEL:()=>xr,DEFAULT_DEVICE_NAME:()=>Qe,DEFAULT_GEMINI_COMPUTER_USE_MODEL:()=>vr,DEFAULT_GOOGLE_MODEL:()=>Er,DEFAULT_OPENAI_COMPUTER_USE_MODEL:()=>Bi,DEFAULT_OPENAI_MODEL:()=>Tr,DEFAULT_WEBAGENT_MODEL:()=>_r,DEFAULT_WHILE_LOOP_TIMEOUT_MS:()=>Bd,DEVICE_CATEGORIES:()=>wr,DeviceType:()=>fr,DraftSchema:()=>Ha,IOS_DEVICE_PREFIX:()=>me,LoginType:()=>br,MIN_WINDOW_HEIGHT:()=>pr,MIN_WINDOW_WIDTH:()=>mr,NON_INTENT_ACTIONS:()=>Ja,NodeJSCodeCommon:()=>mu,PLAYWRIGHT_DEVICES:()=>Hi,RECORD_VIDEO_HEIGHT:()=>hr,RECORD_VIDEO_WIDTH:()=>ur,StatementSchema:()=>ne,StatementType:()=>nr,StatementTypeSchema:()=>Ra,TestFlowSchema:()=>_o,TestGroupEntrySchema:()=>Ba,TestGroupSchema:()=>Ni,TwoFactorAuthType:()=>yr,UI_DEVICE_CATEGORIES:()=>nu,UI_DEVICE_CATEGORIES_ELECTRON:()=>ou,USER_AGENT:()=>rr,VIEWPORT_HEIGHT:()=>dr,VIEWPORT_WIDTH:()=>cr,VariableStore:()=>wu,WINDOW_HEIGHT:()=>lr,WINDOW_WIDTH:()=>sr,actionEntityToYaml:()=>dd,actionStepsMapToTestFlowSections:()=>Sd,allowPureVisionAction:()=>kd,applyPatchToYaml:()=>Xa,applyPatchToYamlString:()=>fd,collectActionSteps:()=>We,convertPlaywrightActionToEntity:()=>Hd,countIntentStatements:()=>qa,createAndroidDeviceName:()=>Xd,createEmptyStore:()=>Md,createIOSDeviceName:()=>Yd,createRunnerStoreEntry:()=>Cd,extractActionStepsFromTestFlow:()=>_d,extractAndAttachComments:()=>za,extractDeviceIdentifier:()=>Vd,extractElementDescription:()=>er,extractElementDescriptionFromAriaSnapshot:()=>tr,extractLocatorFromCode:()=>ir,extractYamlMetadata:()=>pd,findNextAfterContainer:()=>He,findNextSibling:()=>Fe,findNextStatement:()=>Re,findPathBetweenStatements:()=>yd,findStatementPathById:()=>oe,generateUid:()=>Fd,getAllDeviceNames:()=>iu,getAllReferenceIds:()=>xd,getAllStatementsInOrder:()=>Fi,getAndroidDeviceDisplayName:()=>Au,getBrowserWindowSize:()=>au,getCompatiblePlatforms:()=>ar,getDeviceBrowserType:()=>lu,getDeviceByName:()=>Wi,getDeviceChannel:()=>su,getDeviceOptions:()=>Io,getDevicesByCategory:()=>At,getIOSDeviceDisplayName:()=>Qd,getLoginConfigPlatform:()=>gu,getRecordVideoSize:()=>ru,getStatementContainers:()=>Ie,getStoreSize:()=>Ld,getTestPlatformFromDeviceName:()=>Gd,hasReferenceIds:()=>Ya,isAndroidDevice:()=>jd,isAppPackage:()=>Jd,isDynamicAction:()=>vd,isExecutableStatement:()=>bd,isIOSDevice:()=>zd,isNativeDevice:()=>Kd,isPhysicalDeviceUDID:()=>eu,isPlatformCompatibleWithUrl:()=>qd,isStoreEmpty:()=>Dd,isWebUrl:()=>Ao,mergeActionEntitiesIntoTestFlow:()=>Od,mergeStoreUpdates:()=>$d,parseAdbDeviceLine:()=>Eu,parseYamlArrayItems:()=>md,replaceVariables:()=>uu,resolveActionEntity:()=>Id,resolveComputerUseModelFromEnv:()=>Ar,resolveCuaModel:()=>ku,resolveModelFromEnv:()=>vu,resolveModels:()=>xu,suiteToYaml:()=>ja,testFlowToYaml:()=>sd,testFlowToYamlObject:()=>Ka,toAndroidDeviceName:()=>Tu,toIOSDeviceName:()=>Zd,updateStoreEntry:()=>Pd,validatePatch:()=>Va,validateTestYaml:()=>Td,yamlObjectsToString:()=>ld,yamlToActionEntity:()=>ud,yamlToTestFlow:()=>Ze});var Ir=y(()=>{"use strict";wd();Ad();So();Ua();Nd();Wd();To();Ud();tu();cu();du();hu();pu();fu();yu();_u();Su();Mu();Mo()});var Bp={};Ge(Bp,{createTestContext:()=>Ou,expect:()=>Mt.expect,resolveAuthState:()=>Du,test:()=>Wp});module.exports=Bu(Bp);var Be=W(require("path"),1),$u=W(require("fs"),1),Mt=require("@playwright/test");var ee=W(require("fs"),1),tt=W(require("path"),1),$o=require("crypto"),Do=require("os");function Lr(e){return[`--disable-extensions-except=${e}`,`--load-extension=${e}`,"--no-first-run","--disable-default-apps"]}function Or(e){if(!ee.existsSync(e))return console.warn(`[fixture] extensionStorageState file not found: ${e}`),null;let t;try{t=JSON.parse(ee.readFileSync(e,"utf-8"))}catch(a){throw new Error(`[fixture] Failed to parse extensionStorageState at ${e}: ${a}`)}let i=t;if(!Array.isArray(i.cookies))return null;let n=(Date.now()+365*24*60*60*1e3)/1e3,o=i.cookies.filter(a=>a&&typeof a=="object"&&typeof a.name=="string"&&typeof a.domain=="string");return o.length<i.cookies.length&&console.warn(`[fixture] Skipped ${i.cookies.length-o.length} malformed cookies (missing name or domain)`),o.map(a=>({...a,expires:n}))}function Nr(e){if(e){let i=tt.resolve(process.cwd(),e),n=tt.join((0,Do.tmpdir)(),`ext-profile-${(0,$o.randomUUID)()}`);if(ee.existsSync(i)){try{ee.cpSync(i,n,{recursive:!0})}catch(a){try{ee.rmSync(n,{recursive:!0,force:!0})}catch(r){console.warn("[fixture] Failed to clean up partial profile copy:",n,r)}throw new Error(`[fixture] Failed to copy extension profile from ${i}: ${a}`)}let o=tt.join(n,"SingletonLock");ee.existsSync(o)&&ee.rmSync(o,{force:!0})}else ee.mkdirSync(n,{recursive:!0});return n}let t=tt.join((0,Do.tmpdir)(),`ext-profile-${(0,$o.randomUUID)()}`);return ee.mkdirSync(t,{recursive:!0}),t}async function Du(e){let i=await import(Be.resolve(process.cwd(),e.auth)),n=i.login||i.default;if(typeof n!="function")throw new Error(`auth module "${e.auth}" must export a login(args) function that returns a storageState file path`);let o=await n(e.args||{});if(typeof o!="string")throw new Error(`auth module "${e.auth}" login() must return a storageState file path (got ${typeof o})`);return o}function Cu(e){return!(!e||e==="off")}function Lu(e,t){return!e||e==="off"?!1:e==="on"?!0:e==="retain-on-failure"?t.status!==t.expectedStatus:e==="on-first-retry"?t.retry>0:typeof e=="object"&&e!==null&&"mode"in e?Lu(e.mode,t):!0}async function Iu(e,t,i){let n=Lu(t,i);for(let o of e)try{if(n){let a=await o.path();await i.attach("video",{path:a,contentType:"video/webm"})}else await o.delete()}catch(a){console.warn("[fixture] Failed to process video:",a)}}var Po;async function Pu(){return Po||(Po=await Promise.resolve().then(()=>(nd(),id)),Po)}var Hp=new Set(["get","set","getAll","has","__variableStore"]);function Ou(e){let t={__variableStore:e,get(i){return e.get(i)},set(i,n,o=!1){e.set(i,n,o)},getAll(){return e.getAll()}};return new Proxy(t,{get(i,n,o){if(n in i)return Reflect.get(i,n,o);if(typeof n=="string")return i.get(n)},set(i,n,o){return typeof n!="string"||Hp.has(n)?Reflect.set(i,n,o):(i.set(n,o),!0)},has(i,n){return n in i?!0:typeof n=="string"?e.has?.(n)??!1:!1}})}var Wp=Mt.test.extend({account:[void 0,{option:!0}],autoDismissModal:[!1,{option:!0}],extensionDir:[void 0,{option:!0}],userDataDir:[void 0,{option:!0}],extensionStorageState:[void 0,{option:!0}],context:async({browser:e,account:t,extensionDir:i,userDataDir:n,extensionStorageState:o},a,r)=>{if(i||n){if(t||r.project.use.auth)throw new Error('Cannot use both "extensionDir"/"userDataDir" and "auth" \u2014 persistent context tests manage their own context. Use extensionStorageState for authentication instead.');let l=r.project.use?.browserName;l&&l!=="chromium"&&console.warn(`[fixture] Persistent context requires Chromium but project is configured for "${l}". Forcing Chromium.`);let d=process.env.PLAYWRIGHT_HEADLESS==="true";i&&d&&console.warn("[fixture] PLAYWRIGHT_HEADLESS=true with extensionDir \u2014 Chrome extensions will not function in headless mode.");let c=Nr(n),u=i?Lr(Be.resolve(process.cwd(),i)):[],p={...r.project.use},{storageState:g,account:f,extensionDir:k,userDataDir:x,extensionStorageState:m,autoDismissModal:b,video:_,...v}=p,S=Cu(_)?{dir:r.outputDir}:void 0,A;try{if(A=await Mt.chromium.launchPersistentContext(c,{...v,headless:d,args:u,viewport:v.viewport??{width:1280,height:720},...S?{recordVideo:S}:{}}),o){let I=Be.resolve(process.cwd(),o),C=Or(I);C&&await A.addCookies(C)}await a(A)}finally{let I=A?.pages().map(C=>C.video()).filter(C=>C!==null)??[];if(await A?.close().catch(C=>{console.warn("[fixture] Failed to close persistent context:",C)}),await Iu(I,_,r),!n)try{$u.rmSync(c,{recursive:!0,force:!0})}catch(C){console.warn("[fixture] Failed to clean up temp profile dir:",c,C)}}}else{let l={...r.project.use},d=r.project.use,c=d.auth?{auth:d.auth,args:d.args}:t;if(c){if(!c.auth)throw new Error("Auth is declared but missing the script path. Provide auth in playwright.config.ts: use: { auth: './auth.login.ts' }");l.storageState=await Du(c)}let u=l.video;Cu(u)&&!l.recordVideo&&(l.recordVideo={dir:r.outputDir});let p=await e.newContext(l);try{await a(p)}finally{let g=p.pages().map(f=>f.video()).filter(f=>f!==null);await p.close(),await Iu(g,u,r)}}},page:async({context:e},t)=>{let i=await e.newPage();await t(i)},testContext:async({},e,t)=>{let{VariableStore:i}=await Pu(),n=new i,o=t.project.use.variables;if(o)for(let[r,s]of Object.entries(o))typeof s=="string"?n.set(r,s,!1):s&&typeof s=="object"&&"value"in s&&n.set(r,s.value,s.sensitive===!0);let a=Ou(n);global.testContext=a,global.$=a,global.ctx=a,await e(a),delete global.testContext,delete global.$,delete global.ctx},$:async({testContext:e},t)=>{await t(e)},ctx:async({testContext:e},t)=>{await t(e)},agent:async({page:e,testContext:t,autoDismissModal:i},n,o)=>{let{WebAgent:a,createAgentContext:r,configureSdk:s,parseSdkLogLevelFromEnv:l}=await Pu(),d=l();s({env:{GOOGLE_API_KEY:process.env.GOOGLE_API_KEY??"",ANTHROPIC_API_KEY:process.env.ANTHROPIC_API_KEY??"",OPENAI_API_KEY:process.env.OPENAI_API_KEY??""},...d!==void 0&&{logLevel:d}});let{resolveModelFromEnv:c,resolveComputerUseModelFromEnv:u}=await Promise.resolve().then(()=>(Ir(),Cr)),p=c(process.env);if(!p)throw new Error("No AI model configured. Set WEB_AGENT_MODEL, ANTHROPIC_API_KEY, or GOOGLE_API_KEY.");let g=u(process.env),f=t.__variableStore,k=r({model:p,computer_use_model:g,variableStore:f,autoDismissModal:i}),x=Be.join(o.outputDir,"artifacts");k.stepTracking={results:{},artifactsDir:x};let m=new a(k),b=e.context();m.agentServices.setupPageTracking(b),global.agent=m,await n(m),delete global.agent;try{let _=o.outputDir;await m.writeExecutionResults(_);let v=Be.join(_,"test-results.json");await(await import("fs/promises")).stat(v).catch(()=>null)&&await o.attach("shiplight-results",{path:v,contentType:"application/json"})}catch(_){console.error("[Shiplight] Failed to attach step results:",_)}try{let _=m.getNewActionEntities();if(_.size>0&&o.status==="passed"){let{createEmptyStore:v,createRunnerStoreEntry:S}=await Promise.resolve().then(()=>(Ir(),Cr)),A=await import("fs/promises"),I=v();for(let[D,K]of _)I.entries[D]=S(K,0);let C=Be.join(o.outputDir,"new-action-entities.json");await A.writeFile(C,JSON.stringify(I,null,2)),await o.attach("shiplight-new-action-entities",{path:C,contentType:"application/json"}),console.log(`[Shiplight] ${_.size} healed action entit${_.size===1?"y":"ies"} saved`)}}catch(_){console.warn("[Shiplight] Failed to persist new action entities:",_)}}});0&&(module.exports={createTestContext,expect,resolveAuthState,test});