shiplightai 0.1.61 → 0.1.63
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/debugger-manager.cjs +12 -12
- package/dist/cjs/debugger-pw.cjs +48 -48
- package/dist/cjs/fixture.cjs +81 -81
- package/dist/cjs/index.cjs +56 -56
- package/dist/cjs/reporter.cjs +2 -2
- package/dist/cli.js +100 -102
- package/dist/debugger-manager.d.ts +13 -0
- package/dist/debugger-manager.js +14 -14
- package/dist/debugger-pw.js +48 -48
- package/dist/fixture.js +80 -80
- package/dist/index.js +54 -54
- package/dist/reporter.js +2 -2
- package/dist/static/assets/index-CKKo90Kh.js +8027 -0
- package/dist/static/index.html +9 -5
- package/dist/{static/assets/index-BXd8kn7I.js → static-embedded/assets/index-BzKjxa3K.js} +2 -2
- package/dist/{static/assets/index-Bi1S98MP.js → static-embedded/assets/index-CVIbsKcG.js} +3707 -528
- package/dist/static-embedded/index.html +17 -0
- package/package.json +3 -3
- /package/dist/{static → static-embedded}/assets/index-B7_79VfZ.css +0 -0
package/dist/cjs/debugger-pw.cjs
CHANGED
|
@@ -11,11 +11,9 @@ ${e}`)}prompt(e,t){this.section("LLM Prompt"),this.log(`System Prompt:
|
|
|
11
11
|
${e}`),this.log(`
|
|
12
12
|
User Prompt:
|
|
13
13
|
${t}`)}response(e){this.log(`LLM Response:
|
|
14
|
-
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!K().agentLogPath}},S=new Ll});var Rn,Rl,Fl,Hl,Ga,xi,Ln,Ka,Fn,be=x(()=>{"use strict";Rn=Object.defineProperty,Rl=Object.getOwnPropertyDescriptor,Fl=Object.getOwnPropertyNames,Hl=Object.prototype.hasOwnProperty,Ga=(e,t)=>()=>(e&&(t=e(e=0)),t),xi=(e,t)=>{for(var i in t)Rn(e,i,{get:t[i],enumerable:!0})},Ln=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Fl(t))!Hl.call(e,a)&&a!==i&&Rn(e,a,{get:()=>t[a],enumerable:!(n=Rl(t,a))||n.enumerable});return e},Ka=(e,t,i)=>(Ln(e,t,"default"),i&&Ln(i,t,"default")),Fn=e=>Ln(Rn({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Wn}function Wl(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Ie(t);return i?new Function("page",`return ${i}`)(e):null}async function Hn(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 Ul(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 Bl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function jl(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 Ie(e){let t=Bl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=jl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var vi,ut,Wn,he,I,H=x(()=>{"use strict";be();vi={};xi(vi,{ACTION_TIMEOUT:()=>Wn,GOTO_TIMEOUT:()=>he,LOCATOR_TIMEOUT:()=>ut,getActionTimeoutMs:()=>P,getFrameContext:()=>Hn,getLocator:()=>O,getMinimalActionEntity:()=>Ul,getPageLocatorExpression:()=>Ie,sanitizeForComment:()=>Wl});I=Ga(()=>{ut=5e3,Wn=1e4,he=2e4})});async function Un(e,t,i=[],n=[]){try{let a=await Hn(e,i);if(!a)return w.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let l=n[0];if(!l)return w.warn(`Missing shadow host xpath for element: ${t}`),null;let s=a.locator(`xpath=${za(l)}`),c=Gl(t);if(o=await(c?s.locator(`css=${c}`):s.locator(`xpath=${za(t)}`)).elementHandle({timeout:ut}),!o)return w.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:ut}),!o)return w.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(l=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(l):null,o);return await o.dispose(),r?(w.debug(`Generated locator for ${t}: ${r}`),r):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return w.error(`Error in pickBestLocator: ${a}`),null}}async function Bn(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(w.debug(`Generated locator: ${i}`),i):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return w.error(`Error in pickBestLocator: ${i}`),null}}function za(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Gl(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),l=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${l}`)}return n.join(" > ")}var Le=x(()=>{"use strict";U();H();I()});async function ht(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(s=>s()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),{width:r=0,height:l=0}=await o.metadata();return S.log(`Screenshot actual: ${r}x${l}, viewport: ${t}x${i}`),(r!==t||l!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ye(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function _i(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let l=1,s=r.previousElementSibling;for(;s;)s.tagName===r.tagName&&l++,s=s.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${l}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Bn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ki(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var Ke=x(()=>{"use strict";ne();Le()});function jn(e,t){let i=t?.trim();return i?Xl(i):e.startsWith(Kl)?zl:Vl}function Va(e,t){return`${jn(e,t)}/llm/v1`}function Xa(e,t){return`${jn(e,t)}/llm/v1`}function Ya(e,t){return`${jn(e,t)}/llm/v1beta`}function Xl(e){return e.endsWith("/")?e.slice(0,-1):e}var Kl,zl,Vl,Re=x(()=>{"use strict";Kl="shp_",zl="https://nova-api.shiplight.ai",Vl="https://api.shiplight.ai"});function Si(){let e=(K().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Za(e){let t=K().env||{};if(Si()){let a=t.GOOGLE_CLOUD_PROJECT;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return w.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,qa.createVertex)({project:a,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return w.debug(`Using Google AI provider (API key): model=${e}`),(0,Gn.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let a=Ya(n,t.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${a}`),(0,Gn.createGoogleGenerativeAI)({apiKey:n,baseURL:a})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Qa(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ja.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Ja.MEDIA_RESOLUTION_HIGH)}return Si()?{vertex:a}:{google:a}}var Gn,qa,Ja,ze=x(()=>{"use strict";Re();U();ie();Gn=require("@ai-sdk/google"),qa=require("@ai-sdk/google-vertex"),Ja={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function me(e,t){return Math.round(e/1e3*t)}async function Jl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let l=me(i.x,n),s=me(i.y,a),c=me(i.destination_x,n),d=me(i.destination_y,a),u=await ye(e,l,s);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:c-l,delta_y:d-s}},r=u.element;break}default:S.log(`Unsupported Gemini function: ${t}`)}}catch(l){S.error(`Error mapping Gemini action "${t}"`,l)}return{action_data:o,locatorInfo:await _i(e,r)}}async function to(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,l=r||ql,s=K(),c;if(Si()){let y=s.env?.GOOGLE_CLOUD_PROJECT;if(!y)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let v=s.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:y,location:v}}else{let y=s.env?.GOOGLE_API_KEY;if(!y)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};c={apiKey:y}}let d=new Ei.GoogleGenAI(c);S.log(`Sending request to Gemini CUA (model=${l})...`);let u=await d.models.generateContent({model:l,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Ei.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Yl}],temperature:.1}});S.log("Received response from Gemini CUA");let p=u.candidates?.[0];if(!p)return{status:"error",error:"No candidates in Gemini response"};let h=p.content?.parts?.find(y=>y.functionCall);if(!h)return{status:"error",reasoning:p.content?.parts?.filter(y=>y.text).map(y=>y.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:g,args:f}=h.functionCall;S.log(`Generated function call: ${g} with args ${JSON.stringify(f)}`),w.debug(`Generated function call: ${g} with args ${JSON.stringify(f)}`);let{action_data:b,locatorInfo:m}=await Jl(i,g,f,a,o);return b?{status:"success",actionEntity:ki(t,b,m),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${g}`}}var Ei,eo,Yl,ql,Ti=x(()=>{"use strict";Ke();ne();ze();U();ie();Ei=require("@google/genai");eo={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"]},Yl=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:eo},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:eo}];ql="gemini-3-flash-preview"});function no(e){return e!=null&&typeof e=="object"}function Ve(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function io(e){return typeof e=="string"?e:void 0}function Zl(e){let t,i;return Array.isArray(e)?(t=Ve(e[0]),i=Ve(e[1])):no(e)&&(t=Ve(e.x),i=Ve(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function ao(e){if(!no(e))return{};let t=Array.isArray(e.path)?e.path.map(Zl).filter(i=>i!==null):void 0;return{type:io(e.type),x:Ve(e.x),y:Ve(e.y),button:io(e.button),path:t}}var Ai=x(()=>{"use strict"});async function Ql(e,t){let i=ao(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ye(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ye(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],l=await ye(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:l.relative_x,relative_y:l.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=l.element;break}}return{action_data:n,locatorInfo:await _i(e,a)}}async function so(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||ec,l=await ht(i,n,a),s=K(),c=s.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=s.env?.OPENAI_BASE_URL,u=new ro.default({apiKey:c,...d&&{baseURL:d}}),p=u.responses.create.bind(u.responses);S.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${l}`}]}];async function g(v,E){let A={model:r,tools:[tc],input:v,temperature:.1};return E&&(A.previous_response_id=E),p(A)}let f=await g(h,void 0),b;for(let v=0;v<oo;v++){S.log(`Received response from OpenAI CUA (turn ${v+1})`);let E=f.output.find(R=>R.type==="computer_call");if(!E)return{status:"error",reasoning:f.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&S.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;l=await ht(i,n,a);let M=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${l}`,detail:"original"}}];f=await g(M,f.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${oo} turns`};S.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:m,locatorInfo:y}=await Ql(i,b);return m?{status:"success",actionEntity:ki(t,m,y),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var ro,ec,tc,oo,$i=x(()=>{"use strict";Ke();Ai();ne();ie();ro=Q(require("openai"),1);ec="gpt-5.4",tc={type:"computer"},oo=4});function ic(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function nc(){return ic(K().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function co(e){let t=K();if(nc()){let a=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return w.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${a}, location=${o}`),(0,lo.createVertexAnthropic)({project:a,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return w.debug(`Using Anthropic provider: model=${e}`),(0,Kn.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Xa(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${a}`),(0,Kn.createAnthropic)({apiKey:n,baseURL:a})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function zn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Kn,lo,mt=x(()=>{"use strict";Re();U();ie();Kn=require("@ai-sdk/anthropic"),lo=require("@ai-sdk/google-vertex/anthropic")});function uo(e){let t=K(),i=t.env?.OPENAI_API_KEY;if(i){let a=t.env?.OPENAI_BASE_URL;return w.debug(`Using OpenAI provider: model=${e}${a?`, baseURL=${a}`:""}`),(0,Vn.createOpenAI)({apiKey:i,baseURL:a})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Va(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${a}`),(0,Vn.createOpenAI)({apiKey:n,baseURL:a})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function ho(e){return{}}var Vn,pt=x(()=>{"use strict";Re();U();ie();Vn=require("@ai-sdk/openai")});function po(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ac.test(e))return"openai"}function Mi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(oc.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function xe(e){let{provider:t,modelId:i}=Mi(e),n=t??po(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=mo[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(mo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function ve(e,t){let{provider:i,modelId:n}=Mi(e),a=i??po(n);return a==="anthropic"||a==="vertex"?zn(n):a==="openai"||a==="azure"?ho(n):a==="bedrock"?n.startsWith("anthropic.")?zn(n):{}:Qa(t,n)}var ac,oc,mo,_e=x(()=>{"use strict";mt();ze();pt();ac=/^(gpt-|o\d|chatgpt-)/;oc=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);mo={anthropic:co,google:Za,openai:uo}});function sc(e){return e.startsWith("gemini-")?"google":"openai"}async function Xe(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;S.log(`Viewport: ${o}x${r}`);let l=await ht(n,o,r),s=t.agentServices.getComputerUseModel();if(!s)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Mi(s),d=sc(c),u=rc[d];S.log(`Using CUA provider: ${d} (model: ${c})`);let p={statement:e,page:n,screenshotB64:l,viewportWidth:o,viewportHeight:r,modelId:c};try{return await u(p)}catch(h){return S.error(`CUA provider "${d}" threw an error`,h),{status:"error",error:h.message??"CUA provider failed"}}}var rc,Ye=x(()=>{"use strict";Ti();$i();Ke();ne();_e();rc={google:to,openai:so}});async function lc(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let l="(title unavailable)";try{l=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let s=`Tab ${o}: ${r.url()}`;l&&(s+=` - ${l.slice(0,50)}`),n.push(s)}let a=n.length>0?n.join(`
|
|
15
|
-
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
16
|
-
`:"",tabsText:a}}async function cc(e,t){let{currentTabText:i,tabsText:n}=await lc(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Ii(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),l=a.getIframeFallbackDomains(),{domState:s,screenshotBase64:c,slicedScreenshotsBase64:d}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:l,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=s.elementTree.clickableElementsToString(),p=await cc(i,u);return d&&(p.slicedScreenshotsBase64=d),{domTree:u,screenshotBase64:c,slicedScreenshotsBase64:d,domState:s,pageContext:p}}var gt=x(()=>{"use strict"});function Pi(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 ft=x(()=>{"use strict"});function dc(e,t){let i=new Map;for(let s of t)s.hash&&s.url?i.set(s.hash,s.url):s.uuid&&s.url&&i.set(s.uuid,s.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let s=e.slice(o,r.index);s&&a.push({type:"text",text:s});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let l=e.slice(o);return l&&a.push({type:"text",text:l}),a.length===0&&a.push({type:"text",text:e}),a}function uc(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=dc(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
14
|
+
${e}`)}error(e,t){this.log(`ERROR: ${e}`),t&&(this.log(`Error details: ${t.message}`),t.stack&&this.log(`Stack: ${t.stack}`))}isEnabled(){return!!K().agentLogPath}},S=new Ll});var Rn,Rl,Fl,Hl,Ga,xi,Ln,Ka,Fn,be=x(()=>{"use strict";Rn=Object.defineProperty,Rl=Object.getOwnPropertyDescriptor,Fl=Object.getOwnPropertyNames,Hl=Object.prototype.hasOwnProperty,Ga=(e,t)=>()=>(e&&(t=e(e=0)),t),xi=(e,t)=>{for(var i in t)Rn(e,i,{get:t[i],enumerable:!0})},Ln=(e,t,i,n)=>{if(t&&typeof t=="object"||typeof t=="function")for(let a of Fl(t))!Hl.call(e,a)&&a!==i&&Rn(e,a,{get:()=>t[a],enumerable:!(n=Rl(t,a))||n.enumerable});return e},Ka=(e,t,i)=>(Ln(e,t,"default"),i&&Ln(i,t,"default")),Fn=e=>Ln(Rn({},"__esModule",{value:!0}),e)});function P(e,t){return t??e?.getActionSettings()?.action_timeout_ms??Wn}function Wl(e){return e.replace(/\r\n/g," ").replace(/\n/g," ").replace(/\r/g," ").trim()}function O(e,t){let i=Ie(t);return i?new Function("page",`return ${i}`)(e):null}async function Hn(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 Ul(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 Bl(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function jl(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 Ie(e){let t=Bl(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=jl(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}var vi,ut,Wn,he,I,H=x(()=>{"use strict";be();vi={};xi(vi,{ACTION_TIMEOUT:()=>Wn,GOTO_TIMEOUT:()=>he,LOCATOR_TIMEOUT:()=>ut,getActionTimeoutMs:()=>P,getFrameContext:()=>Hn,getLocator:()=>O,getMinimalActionEntity:()=>Ul,getPageLocatorExpression:()=>Ie,sanitizeForComment:()=>Wl});I=Ga(()=>{ut=5e3,Wn=1e4,he=2e4})});async function Un(e,t,i=[],n=[]){try{let a=await Hn(e,i);if(!a)return w.warn(`Could not find frame context for xpath: ${t}`),null;let o=null;if(n.length>0){let l=n[0];if(!l)return w.warn(`Missing shadow host xpath for element: ${t}`),null;let s=a.locator(`xpath=${za(l)}`),c=Gl(t);if(o=await(c?s.locator(`css=${c}`):s.locator(`xpath=${za(t)}`)).elementHandle({timeout:ut}),!o)return w.warn(`Could not find shadow DOM element with xpath: ${t}`),null}else if(o=await a.locator(`xpath=${t}`).elementHandle({timeout:ut}),!o)return w.warn(`Could not find element with xpath: ${t}`),null;let r=await a.evaluate(l=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(l):null,o);return await o.dispose(),r?(w.debug(`Generated locator for ${t}: ${r}`),r):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(a){return w.error(`Error in pickBestLocator: ${a}`),null}}async function Bn(e,t){try{let i=await(await t.ownerFrame()??e).evaluate(n=>typeof playwright<"u"&&playwright.generateLocator?playwright.generateLocator(n):null,t);return await t.dispose(),i?(w.debug(`Generated locator: ${i}`),i):(w.debug("playwright.generateLocator is not available (PWDEBUG=console not set), using xpath fallback"),null)}catch(i){return w.error(`Error in pickBestLocator: ${i}`),null}}function za(e){let t=e.trim();return t.startsWith("/")||t.startsWith("(")||t.startsWith(".")?t:`//${t}`}function Gl(e){let t=e.trim().replace(/^\/+/,"");if(!t)return null;let i=t.split("/").filter(Boolean),n=[];for(let a of i){let o=a.match(/^([a-zA-Z][\w-]*)(?:\[(\d+)\])?$/);if(!o)return null;let r=o[1].toLowerCase(),l=o[2]?`:nth-of-type(${o[2]})`:"";n.push(`${r}${l}`)}return n.join(" > ")}var Le=x(()=>{"use strict";U();H();I()});async function ht(e,t,i){await e.evaluate(()=>{document.getElementById("playwright-highlight-container")?.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(s=>s()),window._highlightCleanupFunctions=[])});let n=await e.screenshot({type:"png",fullPage:!1}),{default:a}=await import("sharp"),o=a(n),{width:r=0,height:l=0}=await o.metadata();return S.log(`Screenshot actual: ${r}x${l}, viewport: ${t}x${i}`),(r!==t||l!==i?await o.resize(t,i).png().toBuffer():n).toString("base64")}async function ye(e,t,i){let n=await e.evaluateHandle(r=>document.elementFromPoint(r.x,r.y),{x:t,y:i}),a=n.asElement();if(!a)throw await n.dispose(),new Error(`No element found at (${t}, ${i})`);let o=await a.boundingBox();if(!o)throw await n.dispose(),new Error(`Element at (${t}, ${i}) has no bounding box`);return{relative_x:t-(o.x+o.width/2),relative_y:i-(o.y+o.height/2),element:a}}async function _i(e,t){if(!t)return{xpath:void 0,locator:void 0,frame_path:[]};let i=await t.evaluate(a=>{let o=[],r=a;for(;r&&r.nodeType===Node.ELEMENT_NODE;){let l=1,s=r.previousElementSibling;for(;s;)s.tagName===r.tagName&&l++,s=s.previousElementSibling;o.unshift(`${r.tagName.toLowerCase()}[${l}]`),r=r.parentElement}return o.length?`/${o.join("/")}`:null}).catch(()=>null),n=await Bn(e,t);return{xpath:i??void 0,locator:n??void 0,frame_path:[]}}function ki(e,t,i){return{action_description:e,action_data:t,locator:i.locator??void 0,xpath:i.xpath??void 0,frame_path:i.frame_path}}var Ke=x(()=>{"use strict";ne();Le()});function jn(e,t){let i=t?.trim();return i?Xl(i):e.startsWith(Kl)?zl:Vl}function Va(e,t){return`${jn(e,t)}/llm/v1`}function Xa(e,t){return`${jn(e,t)}/llm/v1`}function Ya(e,t){return`${jn(e,t)}/llm/v1beta`}function Xl(e){return e.endsWith("/")?e.slice(0,-1):e}var Kl,zl,Vl,Re=x(()=>{"use strict";Kl="shp_",zl="https://nova-api.shiplight.ai",Vl="https://api.shiplight.ai"});function Si(){let e=(K().env||{}).GOOGLE_GENAI_USE_VERTEXAI;return e==="True"||e==="true"}function Za(e){let t=K().env||{};if(Si()){let a=t.GOOGLE_CLOUD_PROJECT;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when using Vertex AI");let o=e.startsWith("gemini-3")?"global":t.GOOGLE_CLOUD_LOCATION;if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when using Vertex AI");return w.debug(`Using Vertex AI provider: model=${e}, location=${o}`),(0,qa.createVertex)({project:a,location:o})(e)}let i=t.GOOGLE_API_KEY;if(i)return w.debug(`Using Google AI provider (API key): model=${e}`),(0,Gn.createGoogleGenerativeAI)({apiKey:i})(e);let n=t.SHIPLIGHT_API_TOKEN;if(n){let a=Ya(n,t.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Google): model=${e}, baseURL=${a}`),(0,Gn.createGoogleGenerativeAI)({apiKey:n,baseURL:a})(e)}throw new Error("Google API key is missing. Set GOOGLE_API_KEY in SDK config or environment.")}function Qa(e,t){let i={thinkingConfig:{thinkingBudget:512,includeThoughts:!0}},n={thinkingConfig:{thinkingLevel:"minimal",includeThoughts:!0},mediaResolution:Ja.MEDIA_RESOLUTION_HIGH},a;switch(t){case"gemini-3-flash-preview":a={...n};break;default:a={...i},e===1&&(a.mediaResolution=Ja.MEDIA_RESOLUTION_HIGH)}return Si()?{vertex:a}:{google:a}}var Gn,qa,Ja,ze=x(()=>{"use strict";Re();U();ie();Gn=require("@ai-sdk/google"),qa=require("@ai-sdk/google-vertex"),Ja={MEDIA_RESOLUTION_HIGH:"MEDIA_RESOLUTION_HIGH",MEDIA_RESOLUTION_MEDIUM:"MEDIA_RESOLUTION_MEDIUM",MEDIA_RESOLUTION_LOW:"MEDIA_RESOLUTION_LOW"}});function me(e,t){return Math.round(e/1e3*t)}async function Jl(e,t,i,n,a){let o=null,r=null;try{switch(t){case"click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"right_click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"right_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"double_click_at":{let l=me(i.x,n),s=me(i.y,a),c=await ye(e,l,s);o={action_name:"double_click_by_coordinates",kwargs:{relative_x:c.relative_x,relative_y:c.relative_y}},r=c.element;break}case"drag_and_drop":{let l=me(i.x,n),s=me(i.y,a),c=me(i.destination_x,n),d=me(i.destination_y,a),u=await ye(e,l,s);o={action_name:"drag_drop",kwargs:{relative_x:u.relative_x,relative_y:u.relative_y,delta_x:c-l,delta_y:d-s}},r=u.element;break}default:S.log(`Unsupported Gemini function: ${t}`)}}catch(l){S.error(`Error mapping Gemini action "${t}"`,l)}return{action_data:o,locatorInfo:await _i(e,r)}}async function to(e){let{statement:t,page:i,screenshotB64:n,viewportWidth:a,viewportHeight:o,modelId:r}=e,l=r||ql,s=K(),c;if(Si()){let y=s.env?.GOOGLE_CLOUD_PROJECT;if(!y)return{status:"error",error:"GOOGLE_CLOUD_PROJECT is required when using Vertex AI."};let v=s.env?.GOOGLE_CLOUD_LOCATION??"global";c={vertexai:!0,project:y,location:v}}else{let y=s.env?.GOOGLE_API_KEY;if(!y)return{status:"error",error:"GOOGLE_API_KEY not found in SDK env config."};c={apiKey:y}}let d=new Ei.GoogleGenAI(c);S.log(`Sending request to Gemini CUA (model=${l})...`);let u=await d.models.generateContent({model:l,contents:[{role:"user",parts:[{text:`Execute this action: ${t}`},{inlineData:{mimeType:"image/png",data:n}}]}],config:{tools:[{computerUse:{environment:Ei.Environment.ENVIRONMENT_BROWSER,excludedPredefinedFunctions:["search","type_text_at","scroll_document","navigate","go_back","go_forward","key_combination","hover_at","scroll_at"]}},{functionDeclarations:Yl}],temperature:.1}});S.log("Received response from Gemini CUA");let m=u.candidates?.[0];if(!m)return{status:"error",error:"No candidates in Gemini response"};let h=m.content?.parts?.find(y=>y.functionCall);if(!h)return{status:"error",reasoning:m.content?.parts?.filter(y=>y.text).map(y=>y.text).join(" ")||"No action generated",error:"No function call in Gemini response"};let{name:g,args:f}=h.functionCall;S.log(`Generated function call: ${g} with args ${JSON.stringify(f)}`),w.debug(`Generated function call: ${g} with args ${JSON.stringify(f)}`);let{action_data:b,locatorInfo:p}=await Jl(i,g,f,a,o);return b?{status:"success",actionEntity:ki(t,b,p),reasoning:"Action generated successfully using Gemini computer use",goalAccomplished:!0}:{status:"error",error:`Unsupported or invalid Gemini action: ${g}`}}var Ei,eo,Yl,ql,Ti=x(()=>{"use strict";Ke();ne();ze();U();ie();Ei=require("@google/genai");eo={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"]},Yl=[{name:"right_click_at",description:"Right-click at the given normalized coordinate.",parameters:eo},{name:"double_click_at",description:"Double-click at the given normalized coordinate.",parameters:eo}];ql="gemini-3-flash-preview"});function no(e){return e!=null&&typeof e=="object"}function Ve(e){return typeof e=="number"&&Number.isFinite(e)?e:void 0}function io(e){return typeof e=="string"?e:void 0}function Zl(e){let t,i;return Array.isArray(e)?(t=Ve(e[0]),i=Ve(e[1])):no(e)&&(t=Ve(e.x),i=Ve(e.y)),t===void 0||i===void 0?null:{x:t,y:i}}function ao(e){if(!no(e))return{};let t=Array.isArray(e.path)?e.path.map(Zl).filter(i=>i!==null):void 0;return{type:io(e.type),x:Ve(e.x),y:Ve(e.y),button:io(e.button),path:t}}var Ai=x(()=>{"use strict"});async function Ql(e,t){let i=ao(t),n=null,a=null;switch(i.type){case"click":{if(i.x===void 0||i.y===void 0)break;let o=i.button==="right"?"right_click_by_coordinates":"click_by_coordinates",r=await ye(e,i.x,i.y);n={action_name:o,kwargs:{relative_x:r.relative_x,relative_y:r.relative_y}},a=r.element;break}case"double_click":{if(i.x===void 0||i.y===void 0)break;let o=await ye(e,i.x,i.y);n={action_name:"double_click_by_coordinates",kwargs:{relative_x:o.relative_x,relative_y:o.relative_y}},a=o.element;break}case"drag":{if(!i.path||i.path.length<2)break;let o=i.path[0],r=i.path[i.path.length-1],l=await ye(e,o.x,o.y);n={action_name:"drag_drop",kwargs:{relative_x:l.relative_x,relative_y:l.relative_y,delta_x:r.x-o.x,delta_y:r.y-o.y}},a=l.element;break}}return{action_data:n,locatorInfo:await _i(e,a)}}async function so(e){let{statement:t,page:i,viewportWidth:n,viewportHeight:a,modelId:o}=e,r=o||ec,l=await ht(i,n,a),s=K(),c=s.env?.OPENAI_API_KEY;if(!c)return{status:"error",error:"OPENAI_API_KEY not found in SDK env config."};let d=s.env?.OPENAI_BASE_URL,u=new ro.default({apiKey:c,...d&&{baseURL:d}}),m=u.responses.create.bind(u.responses);S.log(`Sending request to OpenAI CUA (model=${r})...`);let h=[{role:"user",content:[{type:"input_text",text:t},{type:"input_image",detail:"original",image_url:`data:image/png;base64,${l}`}]}];async function g(v,E){let A={model:r,tools:[tc],input:v,temperature:.1};return E&&(A.previous_response_id=E),m(A)}let f=await g(h,void 0),b;for(let v=0;v<oo;v++){S.log(`Received response from OpenAI CUA (turn ${v+1})`);let E=f.output.find(R=>R.type==="computer_call");if(!E)return{status:"error",reasoning:f.output_text||"Invalid action generation response",error:"No computer_call in OpenAI response"};let A=E.actions??[];if(A.length>1&&S.log(`[openai CUA] dropping ${A.length-1} batched action(s); only the first is executed`),b=A[0],!b)return{status:"error",error:"OpenAI CUA returned a computer_call with no actions"};if(b.type!=="screenshot")break;l=await ht(i,n,a);let M=[{type:"computer_call_output",call_id:E.call_id,output:{type:"computer_screenshot",image_url:`data:image/png;base64,${l}`,detail:"original"}}];f=await g(M,f.id)}if(!b)return{status:"error",error:"OpenAI CUA loop ended without an action"};if(b.type==="screenshot")return{status:"error",error:`OpenAI CUA kept requesting screenshots after ${oo} turns`};S.log(`Generated action: ${JSON.stringify(b)}`);let{action_data:p,locatorInfo:y}=await Ql(i,b);return p?{status:"success",actionEntity:ki(t,p,y),reasoning:"Action generated successfully using OpenAI computer use",goalAccomplished:!0}:{status:"error",error:`Failed to map OpenAI action: ${JSON.stringify(b)}`}}var ro,ec,tc,oo,$i=x(()=>{"use strict";Ke();Ai();ne();ie();ro=Q(require("openai"),1);ec="gpt-5.4",tc={type:"computer"},oo=4});function ic(e){if(!e)return!1;let t=e.trim().toLowerCase();return t==="1"||t==="true"||t==="yes"||t==="on"}function nc(){return ic(K().env?.ANTHROPIC_MODELS_USE_VERTEXAI)}function co(e){let t=K();if(nc()){let a=t.env?.GOOGLE_CLOUD_PROJECT,o=t.env?.GOOGLE_CLOUD_LOCATION;if(!a)throw new Error("GOOGLE_CLOUD_PROJECT is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");if(!o)throw new Error("GOOGLE_CLOUD_LOCATION is required when ANTHROPIC_MODELS_USE_VERTEXAI is enabled");return w.debug(`Using Anthropic via Vertex AI provider: model=${e}, project=${a}, location=${o}`),(0,lo.createVertexAnthropic)({project:a,location:o})(e)}let i=t.env?.ANTHROPIC_API_KEY;if(i)return w.debug(`Using Anthropic provider: model=${e}`),(0,Kn.createAnthropic)({apiKey:i})(e);let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Xa(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (Anthropic): model=${e}, baseURL=${a}`),(0,Kn.createAnthropic)({apiKey:n,baseURL:a})(e)}throw new Error("ANTHROPIC_API_KEY not configured in SDK config")}function zn(e){return{anthropic:{structuredOutputMode:"jsonTool"}}}var Kn,lo,mt=x(()=>{"use strict";Re();U();ie();Kn=require("@ai-sdk/anthropic"),lo=require("@ai-sdk/google-vertex/anthropic")});function uo(e){let t=K(),i=t.env?.OPENAI_API_KEY;if(i){let a=t.env?.OPENAI_BASE_URL;return w.debug(`Using OpenAI provider: model=${e}${a?`, baseURL=${a}`:""}`),(0,Vn.createOpenAI)({apiKey:i,baseURL:a})(e)}let n=t.env?.SHIPLIGHT_API_TOKEN;if(n){let a=Va(n,t.env?.SHIPLIGHT_API_URL);return w.debug(`Using Shiplight LLM proxy (OpenAI): model=${e}, baseURL=${a}`),(0,Vn.createOpenAI)({apiKey:n,baseURL:a})(e)}throw new Error("OPENAI_API_KEY not configured in SDK config")}function ho(e){return{}}var Vn,pt=x(()=>{"use strict";Re();U();ie();Vn=require("@ai-sdk/openai")});function po(e){if(e.startsWith("claude-"))return"anthropic";if(e.startsWith("gemini-"))return"google";if(ac.test(e))return"openai"}function Mi(e){let t=e.indexOf(":");if(t>0){let i=e.slice(0,t);if(oc.has(i))return{provider:i,modelId:e.slice(t+1)}}return{provider:void 0,modelId:e}}function xe(e){let{provider:t,modelId:i}=Mi(e),n=t??po(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=mo[n];if(!a)throw new Error(`Provider "${n}" is not yet implemented. Supported providers: ${Object.keys(mo).join(", ")}. See packages/sdk-core/src/agent/llm/DESIGN.md for the roadmap.`);return a(i)}function ve(e,t){let{provider:i,modelId:n}=Mi(e),a=i??po(n);return a==="anthropic"||a==="vertex"?zn(n):a==="openai"||a==="azure"?ho(n):a==="bedrock"?n.startsWith("anthropic.")?zn(n):{}:Qa(t,n)}var ac,oc,mo,_e=x(()=>{"use strict";mt();ze();pt();ac=/^(gpt-|o\d|chatgpt-)/;oc=new Set(["anthropic","google","openai","vertex","azure","bedrock"]);mo={anthropic:co,google:Za,openai:uo}});function sc(e){return e.startsWith("gemini-")?"google":"openai"}async function Xe(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;S.log(`Viewport: ${o}x${r}`);let l=await ht(n,o,r),s=t.agentServices.getComputerUseModel();if(!s)return{status:"error",error:"No computer use model configured"};let{modelId:c}=Mi(s),d=sc(c),u=rc[d];S.log(`Using CUA provider: ${d} (model: ${c})`);let m={statement:e,page:n,screenshotB64:l,viewportWidth:o,viewportHeight:r,modelId:c};try{return await u(m)}catch(h){return S.error(`CUA provider "${d}" threw an error`,h),{status:"error",error:h.message??"CUA provider failed"}}}var rc,Ye=x(()=>{"use strict";Ti();$i();Ke();ne();_e();rc={google:to,openai:so}});function lc(e,t){let i=new Map;for(let s of t)s.hash&&s.url?i.set(s.hash,s.url):s.uuid&&s.url&&i.set(s.uuid,s.url);let n=/!\[([^\]]*)\]\(image:([a-f0-9]{64}|[a-zA-Z0-9\-]+)\)/g,a=[],o=0,r;for(;(r=n.exec(e))!==null;){let s=e.slice(o,r.index);s&&a.push({type:"text",text:s});let c=r[2];i.has(c)?a.push({type:"image",image:new URL(i.get(c))}):a.push({type:"text",text:r[0]}),o=r.index+r[0].length}let l=e.slice(o);return l&&a.push({type:"text",text:l}),a.length===0&&a.push({type:"text",text:e}),a}function cc(e){let t=[];for(let i of e){let n=i.content||"",a=i.images||[],o=lc(n,a);t.length>0&&o.length>0&&t.push({type:"text",text:`
|
|
17
15
|
|
|
18
|
-
`}),t.push(...o)}return t}function
|
|
16
|
+
`}),t.push(...o)}return t}function Ii(e,t=go){if(t){let i=cc(e);if(i.length===0)return[];let n={type:"text",text:`
|
|
19
17
|
|
|
20
18
|
<retrieved_knowledge>
|
|
21
19
|
|
|
@@ -35,7 +33,7 @@ Below are expert curated knowledge that are retrieved from the knowledge base; A
|
|
|
35
33
|
|
|
36
34
|
</retrieved_knowledge>
|
|
37
35
|
|
|
38
|
-
`}]:[]}}function fo(e,t=go){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var go,
|
|
36
|
+
`}]:[]}}function fo(e,t=go){if(!t)return 0;let i=0;for(let n of e)n.images&&(i+=n.images.length);return i}var go,gt=x(()=>{"use strict";go=!1});function dc(){let e=new Date,t=new Intl.DateTimeFormat("en-US",{timeZone:"America/Los_Angeles",year:"numeric",month:"2-digit",day:"2-digit",hour:"2-digit",minute:"2-digit",second:"2-digit",hour12:!1,timeZoneName:"short"}).formatToParts(e),i=t.find(d=>d.type==="year").value,n=t.find(d=>d.type==="month").value,a=t.find(d=>d.type==="day").value,o=t.find(d=>d.type==="hour").value,r=t.find(d=>d.type==="minute").value,l=t.find(d=>d.type==="second").value,s=t.find(d=>d.type==="timeZoneName").value,c=String(e.getMilliseconds()).padStart(3,"0");return`${i}-${n}-${a} ${o}:${r}:${l}.${c} ${s}`}function wo(e){return`# Your Role
|
|
39
37
|
You are part of a end-to-end testing system that is designed to automate the testing of a website. Given an instruction in natural language, your job is to translate it into an action in the predefined actions. The instruction might not match any action in the predefined actions or might require to interact with an element that is not on the page. It's your job to detect these cases and return an empty action.
|
|
40
38
|
|
|
41
39
|
# Rules
|
|
@@ -95,11 +93,11 @@ Example of empty action when the target element is not on the page, or the instr
|
|
|
95
93
|
"action": {}, // empty action object to indicate the instruction cannot be completed
|
|
96
94
|
"completes_instruction": false
|
|
97
95
|
}
|
|
98
|
-
`}function
|
|
96
|
+
`}function uc(e){if(!e||e.length===0)return"";let t="";return e.forEach(([i,n],a)=>{t+=`(${a+1}) Description: ${i}
|
|
99
97
|
Feedback: ${n}
|
|
100
98
|
`}),`## Additional context
|
|
101
99
|
You just executed following steps in order:
|
|
102
|
-
${t}`}function bo(e,t,i,n,a,o,r=!1,l=
|
|
100
|
+
${t}`}function bo(e,t,i,n,a,o,r=!1,l=dc(),s=!1,c){let d=[],u=`
|
|
103
101
|
# Instruction
|
|
104
102
|
"${t}"
|
|
105
103
|
|
|
@@ -119,9 +117,9 @@ ${e.tabsText}
|
|
|
119
117
|
|
|
120
118
|
## Interactive elements from current page:
|
|
121
119
|
${e.elementsText}
|
|
122
|
-
`;if(d.push({type:"text",text:u}),r&&e.slicedScreenshotsBase64)for(let h of e.slicedScreenshotsBase64)d.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."}),d.push({type:"image",image:h});else o&&(d.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."}),d.push({type:"image",image:o}));if(a&&a.length>0){let h=
|
|
120
|
+
`;if(d.push({type:"text",text:u}),r&&e.slicedScreenshotsBase64)for(let h of e.slicedScreenshotsBase64)d.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."}),d.push({type:"image",image:h});else o&&(d.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."}),d.push({type:"image",image:o}));if(a&&a.length>0){let h=Ii(a,s);d.push(...h)}let m="";if(m+=`
|
|
123
121
|
Current local time is ${l}.
|
|
124
|
-
`,i&&Object.keys(i).length>0){let h=[];for(let g of Object.keys(i))if(c?.has(g))h.push(` - ${g}: [SENSITIVE - value hidden]`);else{let f=i[g],b=typeof f=="string"?f:JSON.stringify(f);h.push(` - ${g}: "${b}"`)}
|
|
122
|
+
`,i&&Object.keys(i).length>0){let h=[];for(let g of Object.keys(i))if(c?.has(g))h.push(` - ${g}: [SENSITIVE - value hidden]`);else{let f=i[g],b=typeof f=="string"?f:JSON.stringify(f);h.push(` - ${g}: "${b}"`)}m+=`
|
|
125
123
|
## Available Data Placeholders
|
|
126
124
|
The following placeholders are available for use in your actions:
|
|
127
125
|
${h.join(`
|
|
@@ -132,23 +130,25 @@ To use them, write Jinja-like template syntax: {{ placeholder_name }}
|
|
|
132
130
|
- Do NOT use the actual value directly
|
|
133
131
|
- The values shown are for context only to help you understand what data is available
|
|
134
132
|
- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")
|
|
135
|
-
`}if(n&&n.length>0){let h=
|
|
136
|
-
`+h}return
|
|
133
|
+
`}if(n&&n.length>0){let h=uc(n);m+=`
|
|
134
|
+
`+h}return m+=`
|
|
137
135
|
Based on the above information, please determine the right action to accomplish the task.
|
|
138
|
-
`,d.push({type:"text",text:
|
|
136
|
+
`,d.push({type:"text",text:m}),d}var Pi=x(()=>{"use strict";gt()});async function hc(e){let t=e.context().pages(),i=null,n=[];for(let o=0;o<t.length;o++){let r=t[o];r===e&&(i=o);let l="(title unavailable)";try{l=await Promise.race([r.title(),new Promise((c,d)=>setTimeout(()=>d(new Error("timeout")),1e3))])}catch{}let s=`Tab ${o}: ${r.url()}`;l&&(s+=` - ${l.slice(0,50)}`),n.push(s)}let a=n.length>0?n.join(`
|
|
137
|
+
`):"";return{currentTabText:i!==null?`Current tab: ${i}
|
|
138
|
+
`:"",tabsText:a}}async function mc(e,t){let{currentTabText:i,tabsText:n}=await hc(e);return{elementsText:t,currentUrl:e.url(),currentTitle:await e.title(),currentTabText:i,tabsText:n}}async function Ci(e,t){let{page:i,domService:n,agentServices:a}=e,o=typeof t=="boolean"?{useCleanScreenshot:t}:t||{},r=a.getInteractiveClassNames(),l=a.getIframeFallbackDomains(),{domState:s,screenshotBase64:c,slicedScreenshotsBase64:d}=await n.getClickableElementsWithScreenshot(i,{interactiveClassNames:r,playwrightFrameFallbackDomains:l,useCleanScreenshot:o.useCleanScreenshot,useSlicedScreenshots:o.useSlicedScreenshots,resizeSlicedScreenshots:o.resizeSlicedScreenshots,useAccessibilityTree:o.useAccessibilityTree,actionIntent:o.actionIntent}),u=s.elementTree.clickableElementsToString(),m=await mc(i,u);return d&&(m.slicedScreenshotsBase64=d),{domTree:u,screenshotBase64:c,slicedScreenshotsBase64:d,domState:s,pageContext:m}}var ft=x(()=>{"use strict"});function Ni(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 wt=x(()=>{"use strict"});var oe,Xn,B,ke=x(()=>{"use strict";oe=require("zod"),Xn=class{constructor(){this.tools=new Map}register(e){if(this.tools.has(e.name))throw new Error(`Tool '${e.name}' is already registered`);let t={name:e.name,description:e.description,schema:e.schema,execute:e.execute,usesElementIndex:e.usesElementIndex??!1,availability:{openai:e.availability?.openai??!0,mcp:e.availability?.mcp??!0}};this.tools.set(e.name,t)}get(e){return this.tools.get(e)}has(e){return this.tools.has(e)}getToolNames(){return Array.from(this.tools.keys())}getTools(){return Array.from(this.tools.values())}async execute(e,t,i){let n=this.tools.get(e);if(!n)throw new Error(`Tool not found: ${e}`);try{let a=t?.description,o={...t};delete o.description;let r=n.schema.parse(o),l={...i,actionDescription:a};return await n.execute(r,l)}catch(a){if(a instanceof oe.z.ZodError){let o=a.issues.map(r=>`${r.path.join(".")}: ${r.message}`).join(", ");return{success:!1,error:`Invalid arguments for tool '${e}': ${o}`,actionEntity:{action_description:t?.description||`${e} (validation failed)`,action_data:{action_name:e,kwargs:t},feedback:`Validation error: ${o}`}}}throw a}}clear(){this.tools.clear()}size(){return this.tools.size}buildActionUnionSchema(){let e=this.getTools().filter(t=>t.availability.openai);return this.buildUnionSchemaFromTools(e)}buildActionUnionSchemaForTools(e,t=!1){let i=new Set(e),n=this.getTools().filter(a=>i.has(a.name));return this.buildUnionSchemaFromTools(n,t)}buildUnionSchemaFromTools(e,t=!1){if(e.length===0)return oe.z.object({done:oe.z.any()});let i=e.map(r=>{let l=r.schema;if(t&&l instanceof oe.z.ZodObject){let s=l._def.shape();l=oe.z.object({...s,description:oe.z.string().describe("Semantic, human-readable description of the action")})}if(l instanceof oe.z.ZodObject){let s=l._def.shape();Object.keys(s).length===0&&(l=oe.z.object({_empty:oe.z.boolean().optional()}))}return oe.z.object({[r.name]:l})});if(i.length===1)return i[0];let[n,a,...o]=i;return oe.z.union([n,a,...o])}},B=new Xn});async function j(e,t){if(t<0)return;let{page:i,domService:n}=e;return(e.domState||await n.getClickableElements(i)).selectorMap.get(t)}function pc(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 gc(e,t=!0){try{let i=pc(e.xpath);if(e.attributes.class&&t){let a=/^[a-zA-Z_][a-zA-Z0-9_-]*$/,o=e.attributes.class.split(/\s+/);for(let r of o)r.trim()&&a.test(r)&&(i+=`.${r}`)}let n=new Set(["id","name","type","placeholder","aria-label","aria-labelledby","aria-describedby","role","for","autocomplete","required","readonly","alt","title","target"]);t&&["data-id","data-qa","data-cy","data-testid","data-handlepos"].forEach(a=>n.add(a));for(let[a,o]of Object.entries(e.attributes)){if(a==="class"||!a.trim()||!n.has(a))continue;let r=a.replace(/:/g,"\\:");if(o==="")i+=`[${r}]`;else if(/["'<>`\n\r\t]/.test(o)){let l=o;o.includes(`
|
|
139
139
|
`)&&(l=o.split(`
|
|
140
|
-
`)[0]),l=l.replace(/\s+/g," ").trim();let s=l.replace(/"/g,'\\"');i+=`[${r}*="${s}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function fc(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 gc(e,!1)}function yo(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=fc(o);w.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function F(e,t){let i=null,n=yo(t);return t.xpath&&(i=await Un(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var z=x(()=>{"use strict";Le();U()});function wc(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 bc(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 yc(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=bc(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 xo(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,l=a.retrieveKnowledges(e).catch(Y=>(S.log(`Failed to retrieve knowledges: ${Y.message}`),[])),s=a.isSlicedScreenshotsEnabled(),c=a.isResizeSlicedScreenshotsEnabled(),d=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),
|
|
140
|
+
`)[0]),l=l.replace(/\s+/g," ").trim();let s=l.replace(/"/g,'\\"');i+=`[${r}*="${s}"]`}else i+=`[${r}="${o}"]`}return i}catch{return`${e.tagName||"*"}[highlight_index='${e.highlightIndex}']`}}function fc(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 gc(e,!1)}function yo(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=fc(o);w.debug("[frame-path] iframe attrs:",JSON.stringify(o.attributes),"\u2192",r),n.push(r)}return n}async function F(e,t){let i=null,n=yo(t);return t.xpath&&(i=await Un(e,t.xpath,n,t.shadowHostXPaths??[])),{locator:i||void 0,xpath:i?void 0:t.xpath,frame_path:n}}var z=x(()=>{"use strict";Le();U()});function wc(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 bc(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 yc(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=bc(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 xo(e,t,i={}){let{page:n,agentServices:a}=t,o=a.getModel(),r=i.temperature??0,l=a.retrieveKnowledges(e).catch(Y=>(S.log(`Failed to retrieve knowledges: ${Y.message}`),[])),s=a.isSlicedScreenshotsEnabled(),c=a.isResizeSlicedScreenshotsEnabled(),d=a.isKnowledgeImagesEnabled(),u=a.isAccessibilityTreeEnabled(),m=a.isActionIntentFilteringEnabled(),h=m?wc(e):"all";m&&h!=="all"&&S.log(`Action intent filtering: detected '${h}' intent from statement`);let{screenshotBase64:g,domState:f,pageContext:b}=await Ci(t,{useSlicedScreenshots:s,resizeSlicedScreenshots:c,useAccessibilityTree:u,actionIntent:h});t.domState=f;let p=new On(B).getToolDefinitions().map(Y=>{let je=Y.function;return`${je.name}: ${je.description}
|
|
141
141
|
Parameters: ${JSON.stringify(je.parameters,null,2)}`}).join(`
|
|
142
142
|
|
|
143
|
-
`),y=wo(
|
|
143
|
+
`),y=wo(p),v=await l,E=bo(b,e,t.variables,t.executionHistory,v.length>0?v:void 0,g,s,void 0,d,t.sensitiveKeys),A=[];i.chatHistory&&i.chatHistory.length>0&&i.chatHistory.forEach(Y=>{Y.role==="user"?A.push({role:"user",content:Y.content}):Y.role==="assistant"&&A.push({role:"assistant",content:Y.content})}),A.push({role:"user",content:E});let M=yc(A),R=B.buildActionUnionSchema(),W=bt.z.object({thought:bt.z.string().describe("Step by step reasoning of your decision making process").optional().default(""),description:bt.z.string().describe("Detailed description of the action to be performed").optional().default(""),action:R,completes_instruction:bt.z.boolean().describe("Whether this action completes the given instruction").optional().default(!0)}),D=Array.isArray(E)?E.filter(Y=>Y.type==="image").length:0,X=ve(o,D),ee=await(0,Oi.generateText)({model:xe(o),system:y,messages:A,temperature:r,output:Oi.Output.object({schema:W}),providerOptions:X}),fe=ee.reasoningText;w.info(`Action Generation Reasoning: ${fe}`);let V=ee.output,J=JSON.stringify(V,null,2);w.info(`Generate Action Raw Output: ${J}`);let we=[],De=Ni(ee.usage,o);De&&we.push(De);let Ae={systemPrompt:y,userPrompt:M,rawLlmResponse:J,tokenUsages:we},$e=V.thought||"",Me=V.description||"",G=V.action||{},q=V.completes_instruction||!1;if(!G||Object.keys(G).length===0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let Z=Object.keys(G)[0];if(Z==="done")return{status:"error",reasoning:$e||Me||"Task marked as done",goalAccomplished:q,error:"Agent indicated task is done without generating an action",debugInfo:Ae};if(Z==="perform_accurate_operation")return await Xe(e,t,i);if(!q){let Y="Can't complete the instruction in one action";return{status:"error",reasoning:$e||Me||Y,goalAccomplished:!1,error:Y,debugInfo:Ae}}let de=G[Z]||{},Ha={};if(typeof de.element_index=="number"){let Y=de.element_index;if(Y<0)return{status:"error",reasoning:$e||Me||"No action generated",goalAccomplished:q,error:"Agent did not generate any action",debugInfo:Ae};let je=f.selectorMap.get(Y);je&&(Ha=await F(n,je))}let Wa=Me;return Z==="verify"&&(Wa=e,de.statement=e),{status:"success",actionEntity:{...Ha,action_description:Wa||$e||`${Z}(${JSON.stringify(de)})`,action_data:{action_name:Z,kwargs:de}},reasoning:$e||Me,goalAccomplished:q,debugInfo:Ae}}var Oi,bt,Di=x(()=>{"use strict";yi();Ye();Pi();ft();wt();ke();ne();_e();z();U();Oi=require("ai"),bt=require("zod")});function xc(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 Yn(e,t,i={}){return i.usePureVision?Xe(e,t,i):xo(e,t,i)}function _c(){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 kc(){return`# Role
|
|
144
144
|
You are an experienced QA person for web applications.
|
|
145
145
|
You are tasked to verify the validity of a given statement based on the screenshot and element tree of a web page.
|
|
146
|
-
`}async function vo(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),l=t.agentServices.isResizeSlicedScreenshotsEnabled(),s=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:u,slicedScreenshotsBase64:
|
|
146
|
+
`}async function vo(e,t,i={}){let{page:n,executionHistory:a}=t,o=t.agentServices.getModel();try{let r=t.agentServices.isSlicedScreenshotsEnabled(),l=t.agentServices.isResizeSlicedScreenshotsEnabled(),s=t.agentServices.isKnowledgeImagesEnabled(),c=t.agentServices.isAccessibilityTreeEnabled(),{domTree:d,screenshotBase64:u,slicedScreenshotsBase64:m,domState:h,pageContext:g}=await Ci(t,{useCleanScreenshot:i.useCleanScreenshotForAssertion,useSlicedScreenshots:r,resizeSlicedScreenshots:l,useAccessibilityTree:c});t.domState=h;let f="";a&&a.length>0&&(f=`
|
|
147
147
|
# Previous actions in this session:
|
|
148
148
|
${a.map(([G,q],Z)=>`${Z+1}. Action: ${G}
|
|
149
149
|
Result: ${q}`).join(`
|
|
150
150
|
`)}
|
|
151
|
-
`);let{dateString:b,timeString:
|
|
151
|
+
`);let{dateString:b,timeString:p}=_c(),y=`
|
|
152
152
|
# User statement
|
|
153
153
|
"${e}"
|
|
154
154
|
|
|
@@ -166,7 +166,7 @@ ${g.tabsText}
|
|
|
166
166
|
${d}
|
|
167
167
|
|
|
168
168
|
## Screenshot
|
|
169
|
-
${r&&
|
|
169
|
+
${r&&m?"The following images are sliced screenshots of the current webpage (left, middle, right sections).":"The image provided is a screenshot of the current webpage."}
|
|
170
170
|
`,v="";if(t.variables&&Object.keys(t.variables).length>0){let G=[];for(let q of Object.keys(t.variables))if(!t.sensitiveKeys?.has(q)){let Z=t.variables[q],de=typeof Z=="string"?Z:JSON.stringify(Z);G.push(` - ${q}: "${de}"`)}G.length>0&&(v=`
|
|
171
171
|
## Available Variables
|
|
172
172
|
The following non-sensitive variables are available:
|
|
@@ -175,13 +175,13 @@ ${G.join(`
|
|
|
175
175
|
${v}
|
|
176
176
|
${f}
|
|
177
177
|
|
|
178
|
-
Today is ${b}. Current local time is ${
|
|
178
|
+
Today is ${b}. Current local time is ${p}.
|
|
179
179
|
Based on the above information, please determine if the statement is true.
|
|
180
|
-
`,A=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:y}],R=0;if(r&&
|
|
180
|
+
`,A=await t.agentServices.retrieveKnowledges(e),M=[{type:"text",text:y}],R=0;if(r&&m&&m.length>0)for(let G of m)M.push({type:"image",image:G}),R++;else M.push({type:"image",image:u}),R=1;if(A&&A.length>0){let G=Ii(A,s);M.push(...G)}M.push({type:"text",text:E});let W=A?fo(A,s):0,D=R+W,X=ve(o,D),ee=kc(),fe=await(0,Li.generateText)({model:xe(o),system:ee,messages:[{role:"user",content:M}],output:Li.Output.object({schema:vc}),temperature:0,providerOptions:X}),{conclusion:V,explanation:J}=fe.output,we=JSON.stringify(fe.output,null,2),De=[],Ae=Ni(fe.usage,o);Ae&&De.push(Ae);let $e=[{role:"user",content:M.map(G=>{if(G.type==="text")return{type:"text",text:G.text};if(G.type==="image"){let q=G.image,Z=xc(q);if(Z)return{type:"image",file:Z};let de=typeof q=="string"?q:"";return{type:"image",file:de.startsWith("data:")?de:`data:image/png;base64,${de}`}}return{type:"text",text:"[unknown content type]"}})}],Me={systemPrompt:ee,userPrompt:$e,rawLlmResponse:we,screenshotWithSom:u,tokenUsages:De,retrievedKnowledges:A&&A.length>0?A:void 0,elementTree:d};return{success:V==="true",explanation:J,debugInfo:Me}}catch(r){return{success:!1,error:r.message}}}var Li,yt,vc,Ri=x(()=>{"use strict";Di();Ye();ft();wt();gt();_e();Li=require("ai"),yt=require("zod");vc=yt.z.object({screenshotDescription:yt.z.string().describe(`Description of the screenshot content, listing out key elements along with their Set of Mark indices,
|
|
181
181
|
and a description of their location: formatting example: [12] A red button with text "Submit", next to [11]
|
|
182
182
|
[45] A modal dialog titled "Confirmation",
|
|
183
|
-
in the center of the screen`),explanation:yt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:yt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function ko(){let{default:e}=await import("sharp");return e}async function Jn(e,t){let i=await ko(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,l=0,s=Math.floor((a-r)/2),c=Math.max(0,a-r),d=(g,f)=>{let b=i(e).extract({left:g,top:0,width:f,height:r});return t?.resize&&(b=b.resize(_o,_o)),b.png().toBuffer()},[u,
|
|
184
|
-
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??To,n=t?.includeClassesWithRename??Ao,a=[],o=(r,l)=>{let s=l,c=" ".repeat(l);if(r instanceof Fi){if(r.highlightIndex!==null){s+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let
|
|
183
|
+
in the center of the screen`),explanation:yt.z.string().describe("Step by step reasoning explaining your conclusion about the statement"),conclusion:yt.z.enum(["true","false","unknown"]).describe("Whether the statement is true, false, or unknown if you cannot make a conclusion")})});async function ko(){let{default:e}=await import("sharp");return e}async function Jn(e,t){let i=await ko(),n=await i(e).metadata(),a=n.width||0,o=n.height||0;if(a===0||o===0)throw new Error("Invalid image dimensions");let r=o,l=0,s=Math.floor((a-r)/2),c=Math.max(0,a-r),d=(g,f)=>{let b=i(e).extract({left:g,top:0,width:f,height:r});return t?.resize&&(b=b.resize(_o,_o)),b.png().toBuffer()},[u,m,h]=await Promise.all([d(l,Math.min(r,a)),d(s,Math.min(r,a-s)),d(c,Math.min(r,a-c))]);return[u,m,h]}async function So(e){let t=(await ko())(e),i=await t.metadata(),n=i.width||0,a=i.height||0;if(n===0||a===0)throw new Error("Invalid image dimensions");let{data:o}=await t.grayscale().raw().toBuffer({resolveWithObject:!0}),r=[];for(let l=0;l<a;l++){r[l]=[];for(let s=0;s<n;s++)r[l][s]=o[l*n+s]}return{pixels:r,width:n,height:a}}var _o,xt=x(()=>{"use strict";_o=768});var qn,Zn,Qn,ea,vt=x(()=>{"use strict";qn=new Set(["button","link","textbox","checkbox","radio","combobox","listbox","menuitem","menuitemcheckbox","menuitemradio","option","tab","switch","slider","spinbutton","searchbox","scrollbar","treeitem","gridcell"]),Zn=new Set(["click","mousedown","mouseup","dblclick","pointerdown","pointerup","touchstart","touchend"]),Qn=["[onclick]","[onmousedown]","[ontouchstart]","div","span","li","tr","td","[role]",'[class*="btn"]','[class*="button"]','[class*="click"]',"[data-action]","[data-click]"],ea=500});function Eo(e,t){return e.length>t?e.slice(0,t)+"...":e}var _t=x(()=>{"use strict"});var To,Ao,kt=x(()=>{"use strict";To=["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"],Ao={"react-flow__(\\S+)":"$1"}});var $o,St,Se,Je=x(()=>{"use strict";_t();kt();$o=class{constructor(e,t=null){this.isVisible=e,this.parent=t}},St=class extends $o{constructor(e,t,i=null){super(t,i),this.text=e,this.type="TEXT_NODE"}hasParentWithHighlightIndex(){let e=this.parent;for(;e!==null;){if(e.highlightIndex!==null)return!0;e=e.parent}return!1}isParentInViewport(){return this.parent===null?!1:this.parent.isInViewport}isParentTopElement(){return this.parent===null?!1:this.parent.isTopElement}},Se=class Fi extends $o{constructor(t,i,n,a,o,r=!1,l=!1,s=!1,c=!1,d=!1,u=!1,m=null,h=null,g=null,f=null,b=[],p=null){super(o,p),this.tagName=t,this.xpath=i,this.attributes=n,this.children=a,this.isInteractive=r,this.isScrollable=l,this.markAsClickable=s,this.isTopElement=c,this.isInViewport=d,this.shadowRoot=u,this.highlightIndex=m,this.viewportCoordinates=h,this.pageCoordinates=g,this.viewportInfo=f,this.isNew=null,this.shadowHostXPaths=b}getAllTextTillNextClickableElement(t=-1){let i=[],n=(a,o)=>{if(!(t!==-1&&o>t)&&!(a instanceof Fi&&a!==this&&a.highlightIndex!==null)){if(a instanceof St)i.push(a.text);else if(a instanceof Fi)for(let r of a.children)n(r,o+1)}};return n(this,0),i.join(`
|
|
184
|
+
`).trim()}clickableElementsToString(t){let i=t?.includeAttributes??To,n=t?.includeClassesWithRename??Ao,a=[],o=(r,l)=>{let s=l,c=" ".repeat(l);if(r instanceof Fi){if(r.highlightIndex!==null){s+=1;let d=r.isScrollable?"":r.getAllTextTillNextClickableElement(),u=null;if(i.length>0){let p={};for(let E of Object.keys(r.attributes))if(i.includes(E)){let A=r.attributes[E].trim();A!==""&&(p[E]=A)}let y=i.filter(E=>E in p);if(y.length>1){let E=new Set,A={};for(let M of y){let R=p[M];R.length>5&&(R in A?E.add(M):A[R]=M)}for(let M of E)delete p[M]}r.tagName===p.role&&delete p.role;let v=["aria-label","placeholder","title"];for(let E of v)p[E]&&p[E].trim().toLowerCase()===d.trim().toLowerCase()&&delete p[E];Object.keys(p).length>0&&(u=Object.entries(p).map(([E,A])=>`${E}=${Eo(A,200)}`).join(" "))}let m=r.isNew?`*[${r.highlightIndex}]`:`[${r.highlightIndex}]`,h=[];if(Object.keys(n).length>0&&r.attributes.class){let p=r.attributes.class.split(/\s+/);for(let y of p)for(let[v,E]of Object.entries(n))try{let A=new RegExp(`^${v}$`);if(y.match(A)){let M=y.replace(A,E);M&&h.push(M);break}}catch{continue}}let g=r.isScrollable?" (SCROLLABLE)":"",f=r.markAsClickable?" (CLICKABLE)":"",b=`${c}${m}${g}${f}<${r.tagName}`;if(h.length>0&&(b+=` ${h.join(" ")}`),u&&(b+=` ${u}`),d){let p=d.trim();u||(b+=" "),b+=`>${p}`}else u||(b+=" ");b+=" />",a.push(b)}else{let d=["data-testid","data-test-id"].filter(u=>r.attributes[u]);d.length>0&&(s+=1,a.push(`${c}<${r.tagName} ${d.map(u=>`${u}="${r.attributes[u]}"`).join(" ")} />`))}for(let d of r.children)o(d,s)}else if(r instanceof St){if(r.hasParentWithHighlightIndex())return;r.parent&&r.parent.isVisible&&r.parent.isTopElement&&a.push(`${c}${r.text}`)}};return o(this,0),a.join(`
|
|
185
185
|
`)}}});function Tc(e){return e==="about:blank"||e==="chrome://newtab/"||e==="edge://newtab/"||e==="about:newtab"}var Sc,Ec,Pe,Fe=x(()=>{"use strict";xt();vt();Je();U();Sc=`(
|
|
186
186
|
args = {
|
|
187
187
|
doHighlightElements: true,
|
|
@@ -3998,7 +3998,7 @@ Based on the above information, please determine if the statement is true.
|
|
|
3998
3998
|
// Return element data from boxes phase for use in labels phase
|
|
3999
3999
|
elementData: phase === 'boxes' ? collectedElementData : undefined,
|
|
4000
4000
|
};
|
|
4001
|
-
})`;Pe=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let a=this.normalizeDomain(n);if(a&&(i===a||i.endsWith(`.${a}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){w.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Ec:Sc}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:l=!1,sameRectIoUThreshold:s,actionIntent:c="all"}=t,[d,u]=await this.buildDomTree(e,i,n,a,o,r,l,s,c);return{elementTree:d,selectorMap:u}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let a=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await Jn(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){w.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){w.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:a}=await n.send("Accessibility.getFullAXTree",{depth:-1});w.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(
|
|
4001
|
+
})`;Pe=class{normalizeDomain(e){let t=e.trim().toLowerCase();if(!t)return"";try{if(t.includes("://"))return new URL(t).hostname.toLowerCase()}catch{return""}return t.split("/")[0].split(":")[0]}isConfiguredIframeFallbackDomain(e,t){let i;try{i=new URL(e).hostname.toLowerCase()}catch{return!1}for(let n of t){let a=this.normalizeDomain(n);if(a&&(i===a||i.endsWith(`.${a}`)))return!0}return!1}shouldProcessWithPlaywrightFrameFallback(e,t){if(!e.inaccessibleFrame)return!1;let i=e.attributes?.src;return i?i.startsWith("chrome-extension://")?!0:this.isConfiguredIframeFallbackDomain(i,t):!1}constructor(e={}){w.debug("\u{1F333} Initializing DomService with options:",e),this.useDomTreeTs=e.useDomTreeTs??!1,this.domTreeRoot=e.domTreeRoot??"body",this.jsCode=this.useDomTreeTs?Ec:Sc}async getClickableElements(e,t={}){let{highlightElements:i=!0,focusElement:n=-1,viewportExpansion:a=0,interactiveClassNames:o=[],playwrightFrameFallbackDomains:r=[],alwaysHighlightFileInput:l=!1,sameRectIoUThreshold:s,actionIntent:c="all"}=t,[d,u]=await this.buildDomTree(e,i,n,a,o,r,l,s,c);return{elementTree:d,selectorMap:u}}async getClickableElementsWithScreenshot(e,t={}){if(t.useAccessibilityTree)return this.getClickableElementsWithAXTree(e,t);let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await this.getClickableElements(e,t);if(await e.waitForTimeout(100),t.useCleanScreenshot||(i=await e.screenshot({type:"png",fullPage:!1})),await this.removeHighlights(e,t.playwrightFrameFallbackDomains||[]),!i)throw new Error("Failed to capture screenshot: screenshot buffer is undefined");let a=i.toString("base64"),o;if(t.useSlicedScreenshots)try{o=(await Jn(i,{resize:t.resizeSlicedScreenshots})).map(r=>r.toString("base64"))}catch(r){w.warn("Failed to slice screenshot:",r)}return{domState:n,screenshotBase64:a,screenshot:i,slicedScreenshotsBase64:o}}async getClickableElementsWithAXTree(e,t={}){w.debug("\u{1F333} Using CDP Accessibility Tree for element detection");let i;t.useCleanScreenshot&&(i=await e.screenshot({type:"png",fullPage:!1}));let n=await e.context().newCDPSession(e),{nodes:a}=await n.send("Accessibility.getFullAXTree",{depth:-1});w.debug(`\u{1F4CA} Got ${a.length} AXNodes from accessibility tree`);let o=a.filter(p=>{if(p.ignored)return!1;let y=p.role?.value;return!(!y||!qn.has(y)||p.properties?.find(v=>v.name==="disabled")?.value?.value||!p.backendDOMNodeId)});w.debug(`\u2705 Found ${o.length} interactive elements from AXTree`);let r=a.filter(p=>p.role?.value==="button");w.debug(`\u{1F518} Total buttons in AXTree: ${r.length}`);for(let p of r){let y=[];p.ignored&&y.push("ignored"),p.backendDOMNodeId||y.push("no-backendDOMNodeId"),p.properties?.find(v=>v.name==="disabled")?.value?.value&&y.push("disabled"),w.debug(` - "${p.name?.value||"(no name)"}" ${y.length>0?`[SKIPPED: ${y.join(", ")}]`:"[INCLUDED]"}`)}let l=new Set(o.map(p=>p.backendDOMNodeId)),s=await this.getElementsWithEventListeners(n,t.eventListenerLimit??500),c=0;for(let p of s)l.has(p.backendNodeId)||(o.push({nodeId:`synthetic-${p.backendNodeId}`,ignored:!1,backendDOMNodeId:p.backendNodeId,role:{type:"role",value:"generic"},name:{type:"string",value:""},properties:[{name:"eventListeners",value:{type:"string",value:p.eventTypes.join(",")}}]}),l.add(p.backendNodeId),c++);w.debug(`\u{1F3AF} Added ${c} elements from event listeners (total: ${o.length})`);let d=await this.resolveAXNodesToDOM(n,o),u=d.filter(p=>p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect),m=d.filter(p=>!(p.isVisible&&p.isInViewport&&p.isTopElement&&p.boundingRect));if(m.length>0){w.debug(`\u{1F6AB} Filtered out ${m.length} elements:`);for(let p of m){let y=[];p.isVisible||y.push("not-visible"),p.isInViewport||y.push("not-in-viewport"),p.isTopElement||y.push("not-top-element"),p.boundingRect||y.push("no-bounding-rect"),w.debug(` - <${p.tagName}> "${p.axNode.name?.value||""}" [${y.join(", ")}]`)}}w.debug(`\u{1F441}\uFE0F ${u.length} elements are visible and in viewport`);let{domState:h,highlightIndex:g}=await this.buildDomStateFromAXTree(u);t.highlightElements!==!1&&g>0&&(await this.renderHighlightsForAXElements(e,u.slice(0,g)),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 f=i.toString("base64"),b;if(t.useSlicedScreenshots)try{b=(await Jn(i,{resize:t.resizeSlicedScreenshots})).map(p=>p.toString("base64"))}catch(p){w.warn("Failed to slice screenshot:",p)}return{domState:h,screenshotBase64:f,screenshot:i,slicedScreenshotsBase64:b}}async resolveAXNodesToDOM(e,t){let i=[],n=t.map(o=>o.backendDOMNodeId).filter(o=>o!==void 0);if(n.length===0)return i;let a=[];for(let o of n)try{let{object:r}=await e.send("DOM.resolveNode",{backendNodeId:o});a.push(r.objectId||null)}catch{a.push(null)}for(let o=0;o<t.length;o++){let r=t[o],l=a[o];if(l)try{let{result:s}=await e.send("Runtime.callFunctionOn",{objectId:l,functionDeclaration:`function() {
|
|
4002
4002
|
const el = this;
|
|
4003
4003
|
const rect = el.getBoundingClientRect();
|
|
4004
4004
|
const rects = el.getClientRects();
|
|
@@ -4082,36 +4082,36 @@ Based on the above information, please determine if the statement is true.
|
|
|
4082
4082
|
} : null,
|
|
4083
4083
|
clientRects: clientRectsArray
|
|
4084
4084
|
};
|
|
4085
|
-
}`,returnByValue:!0});s.value&&i.push({axNode:r,...s.value})}catch(s){w.debug(`Failed to resolve element: ${s}`)}}return i}async getElementsWithEventListeners(e,t=ea){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Qn.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});w.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:l}=await e.send("DOM.resolveNode",{nodeId:r});if(!l.objectId)continue;let{listeners:s}=await e.send("DOMDebugger.getEventListeners",{objectId:l.objectId}),c=s.filter(d=>Zn.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:l.objectId})}catch{}w.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){w.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Se("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",l=["button","link","menuitem","tab","switch"].includes(o),s=new Se(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",l,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let c=new St(r,!0,s);s.children.push(c)}i.children.push(s),t.set(n,s),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((l,s)=>{if(!l.boundingRect)return;let c=a[s%a.length],d=l.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${c}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${d.y}px`,u.style.left=`${d.x}px`,u.style.width=`${d.width}px`,u.style.height=`${d.height}px`,r.appendChild(u);let p=document.createElement("div");p.style.position="fixed",p.style.background=c,p.style.color="white",p.style.padding="1px 4px",p.style.borderRadius="4px",p.style.fontSize=s>=100?"8px":"12px",p.textContent=String(s);let h=Math.max(0,d.y-16),g=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));p.style.top=`${h}px`,p.style.left=`${g}px`,r.appendChild(p)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),w.debug("\u2705 Highlights removed from page")}catch(n){w.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(l=>l.map(s=>s.src)),i=l=>{try{let s=new URL(l);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>s.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let l of o){let s=l.url();try{let c=new URL(s).hostname;c&&c!==a&&!t.includes(s)&&!i(s)&&r.push(s)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,l,s="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Tc(e.url()))return[new Se("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:l,actionIntent:s,domTreeRoot:this.domTreeRoot};w.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,u=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},m=await e.evaluate(({code:R,argsObj:W})=>new Function("return "+R)()(W),{code:this.jsCode,argsObj:b});w.debug(`\u{1F4E6} Phase 1: Drew ${m.elementData?.length||0} bounding boxes`);let y=await e.screenshot({type:"png",fullPage:!1});w.debug("\u{1F4F8} Captured screenshot with bounding boxes");let v=performance.now(),E=await So(y);u=E.pixels;let A=Math.round(performance.now()-v);w.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:u,elementData:m.elementData};d=await e.evaluate(({code:R,argsObj:W})=>new Function("return "+R)()(W),{code:this.jsCode,argsObj:M}),d.map=m.map,d.rootId=m.rootId,d.highlightCount=m.highlightCount,d.perfMetrics=m.perfMetrics,w.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){w.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),u=null;let m={...c,grayscaleImage:null};d=await e.evaluate(({code:y,argsObj:v})=>new Function("return "+y)()(v),{code:this.jsCode,argsObj:m}),w.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:m})=>new Function("return "+b)()(m),{code:this.jsCode,argsObj:c}),w.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw w.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw w.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw w.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(s!=="all"&&d.highlightCount===0){w.debug(`\u26A0\uFE0F No elements matched intent '${s}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:m,argsObj:y})=>new Function("return "+m)()(y),{code:this.jsCode,argsObj:b})}let p=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");w.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${p.length}`);for(let[b,m]of p){let y=m;w.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${y.attributes?.src} inaccessibleFrame=${y.inaccessibleFrame}`)}let h=e.frames();w.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${h.length}`);for(let b of h)w.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let g=[];for(let[b,m]of Object.entries(d.map)){let y=m;this.shouldProcessWithPlaywrightFrameFallback(y,o)&&g.push({nodeId:b,src:y.attributes.src})}if(w.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${g.length}`),g.length>0){w.debug(`\u{1F50C} Found ${g.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let m of Object.values(d.map)){let y=m;y.highlightIndex!=null&&(b=Math.max(b,y.highlightIndex))}w.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let m=0;m<g.length;m++){let{nodeId:y,src:v}=g[m];w.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${m}]: ${v}`);let E=W=>{try{let D=new URL(W);if(D.protocol==="chrome-extension:"&&D.hostname)return`chrome-extension://${D.hostname}`;let X=D.origin;return X==="null"?null:X}catch{return null}},A=E(v);w.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,R=e.frames().find(W=>{let D=W.url();if(D===v)return M="exact",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${D}`),!0;let X=E(D);return w.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${D} origin=${X??"null"} vs srcOrigin=${A??"null"}`),A&&X===A?(M="origin",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${D}`),!0):!1});if(!R){w.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${v}`),w.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(W=>W.url()).join(", ")}`);continue}w.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${v} (frame url: ${R.url()})`);try{let W={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};w.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${W.initialHighlightIndex}`);let D=await R.evaluate(({code:V,argsObj:J})=>new Function("return "+V)()(J),{code:this.jsCode,argsObj:W});if(w.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(D?.map??{}).length} rootId=${D?.rootId}`),!D?.map||!D.rootId){w.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let X=Object.values(D.map).filter(V=>V.highlightIndex!=null);w.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${X.length}`);for(let V of X){let J=V;w.debug(`\u{1F50D} [ext-iframe] - <${J.tagName}> highlightIndex=${J.highlightIndex} text="${J.children?.length?"...":""}"`)}for(let V of Object.values(D.map)){let J=V;J.highlightIndex!=null&&(b=Math.max(b,J.highlightIndex))}let ee=`ext_${m}_`;for(let[V,J]of Object.entries(D.map)){let we={...J};we.children&&(we.children=we.children.map(De=>`${ee}${De}`)),d.map[`${ee}${V}`]=we}let fe=d.map[y];fe?(fe.children=[...fe.children||[],`${ee}${D.rootId}`],w.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${y}`)):w.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${y} not found in map`),w.debug(`\u2705 Merged fallback iframe content from: ${v}`)}catch(W){w.warn(`Failed to process fallback iframe ${v}:`,W)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,m=0;if(d.map)for(let v of Object.values(d.map))typeof v=="object"&&v!==null&&v.isInteractive&&m++;let y=e.url().length>50?e.url().slice(0,50)+"...":e.url();w.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${y} interactive=${m}/${b}`)}w.debug("\u{1F504} Starting TypeScript DOM tree construction...");let f=await this.constructDomTree(d);return w.debug("\u2705 TypeScript DOM tree construction completed"),f}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[l,s]of Object.entries(t)){let[c,d]=this.parseNode(s);c!==null&&(a.set(l,c),o.set(l,d),c instanceof Se&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[l,s]of o){let c=a.get(l);if(c instanceof Se)for(let d of s){let u=a.get(d);u&&(u.parent=c,c.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof Se))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new St(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new Se(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),a=e.children||[];return[n,a]}}});var Mo,Io,Dm,Hi=x(()=>{"use strict";Mo=require("zod"),Io=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Dm=Mo.z.object({})});var Po,Wi=x(()=>{"use strict";H();I();Po=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Co,Ui=x(()=>{"use strict";H();I();Co=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=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Ie(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var No,Bi=x(()=>{"use strict";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.code;if(!a)throw new Error("Missing code for js_action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_action requires an agent reference");await new Function("page","agent",`
|
|
4085
|
+
}`,returnByValue:!0});s.value&&i.push({axNode:r,...s.value})}catch(s){w.debug(`Failed to resolve element: ${s}`)}}return i}async getElementsWithEventListeners(e,t=ea){let i=[];try{let{root:n}=await e.send("DOM.getDocument",{depth:0}),a=Qn.join(","),{nodeIds:o}=await e.send("DOM.querySelectorAll",{nodeId:n.nodeId,selector:a});w.debug(`\u{1F50D} Checking ${Math.min(o.length,t)} elements for event listeners`);for(let r of o.slice(0,t))try{let{object:l}=await e.send("DOM.resolveNode",{nodeId:r});if(!l.objectId)continue;let{listeners:s}=await e.send("DOMDebugger.getEventListeners",{objectId:l.objectId}),c=s.filter(d=>Zn.has(d.type));if(c.length>0){let{node:d}=await e.send("DOM.describeNode",{nodeId:r});i.push({backendNodeId:d.backendNodeId,eventTypes:c.map(u=>u.type)})}await e.send("Runtime.releaseObject",{objectId:l.objectId})}catch{}w.debug(`\u2705 Found ${i.length} elements with interaction event listeners`)}catch(n){w.warn("Failed to get elements with event listeners:",n)}return i}async buildDomStateFromAXTree(e){let t=new Map,i=new Se("body","/body",{},[],!0,!1,!1,!1,!0,!0,!1,null),n=0;for(let a of e){let o=a.axNode.role?.value||"",r=a.axNode.name?.value||"",l=["button","link","menuitem","tab","switch"].includes(o),s=new Se(a.tagName,a.xpath,a.attributes,[],a.isVisible,!0,o==="scrollbar",l,a.isTopElement,a.isInViewport,!1,n,a.boundingRect?{topLeft:{x:a.boundingRect.x,y:a.boundingRect.y},topRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y},bottomLeft:{x:a.boundingRect.x,y:a.boundingRect.y+a.boundingRect.height},bottomRight:{x:a.boundingRect.x+a.boundingRect.width,y:a.boundingRect.y+a.boundingRect.height},center:{x:a.boundingRect.x+a.boundingRect.width/2,y:a.boundingRect.y+a.boundingRect.height/2},width:a.boundingRect.width,height:a.boundingRect.height}:null,null,null,[],i);if(r){let c=new St(r,!0,s);s.children.push(c)}i.children.push(s),t.set(n,s),n++}return{domState:{elementTree:i,selectorMap:t},highlightIndex:n}}async renderHighlightsForAXElements(e,t){let i=["#FF0000","#00FF00","#0000FF","#FFA500","#800080","#008080","#FF69B4","#4B0082","#FF4500","#2E8B57","#DC143C","#4682B4"];await e.evaluate(({elements:n,colors:a})=>{let o="playwright-highlight-container",r=document.getElementById(o);r||(r=document.createElement("div"),r.id=o,r.style.position="fixed",r.style.pointerEvents="none",r.style.top="0",r.style.left="0",r.style.width="100%",r.style.height="100%",r.style.zIndex="2147483647",r.style.backgroundColor="transparent",document.body.appendChild(r)),n.forEach((l,s)=>{if(!l.boundingRect)return;let c=a[s%a.length],d=l.boundingRect,u=document.createElement("div");u.style.position="fixed",u.style.border=`1px solid ${c}`,u.style.backgroundColor="transparent",u.style.pointerEvents="none",u.style.boxSizing="border-box",u.style.top=`${d.y}px`,u.style.left=`${d.x}px`,u.style.width=`${d.width}px`,u.style.height=`${d.height}px`,r.appendChild(u);let m=document.createElement("div");m.style.position="fixed",m.style.background=c,m.style.color="white",m.style.padding="1px 4px",m.style.borderRadius="4px",m.style.fontSize=s>=100?"8px":"12px",m.textContent=String(s);let h=Math.max(0,d.y-16),g=Math.max(0,Math.min(d.x+d.width-20,window.innerWidth-25));m.style.top=`${h}px`,m.style.left=`${g}px`,r.appendChild(m)})},{elements:t,colors:i})}async removeHighlights(e,t=[]){let i=()=>{let n=document.getElementById("playwright-highlight-container");n&&n.remove(),window._highlightCleanupFunctions&&(window._highlightCleanupFunctions.forEach(a=>a()),window._highlightCleanupFunctions=[])};try{await e.evaluate(i),w.debug("\u2705 Highlights removed from page")}catch(n){w.warn("Failed to remove highlights:",n.message)}for(let n of e.frames()){let a=n.url();if(!(!a.startsWith("chrome-extension://")&&!this.isConfiguredIframeFallbackDomain(a,t)))try{await n.evaluate(i)}catch{}}}async getCrossOriginIframes(e){let t=await e.locator("iframe").filter({hasNot:e.locator(":visible")}).evaluateAll(l=>l.map(s=>s.src)),i=l=>{try{let s=new URL(l);return["doubleclick.net","adroll.com","googletagmanager.com"].some(c=>s.hostname.includes(c))}catch{return!1}},n=e.url(),a=new URL(n).hostname,o=e.frames(),r=[];for(let l of o){let s=l.url();try{let c=new URL(s).hostname;c&&c!==a&&!t.includes(s)&&!i(s)&&r.push(s)}catch{continue}}return r}async buildDomTree(e,t,i,n,a,o,r,l,s="all"){if(await e.evaluate("1+1")!==2)throw new Error("The page cannot evaluate javascript code properly");if(Tc(e.url()))return[new Se("body","",{},[],!1,!1,!1,!1,!1,!1,!1,null),new Map];let c={doHighlightElements:t,focusHighlightIndex:i,viewportExpansion:n,debugMode:!1,interactiveClassNames:a,alwaysHighlightFileInput:r,sameRectIoUThreshold:l,actionIntent:s,domTreeRoot:this.domTreeRoot};w.debug(`\u{1F527} Starting JavaScript DOM analysis for ${e.url().slice(0,50)}...`);let d,u=null;if(this.useDomTreeTs&&t)try{let b={...c,phase:"boxes",grayscaleImage:null},p=await e.evaluate(({code:R,argsObj:W})=>new Function("return "+R)()(W),{code:this.jsCode,argsObj:b});w.debug(`\u{1F4E6} Phase 1: Drew ${p.elementData?.length||0} bounding boxes`);let y=await e.screenshot({type:"png",fullPage:!1});w.debug("\u{1F4F8} Captured screenshot with bounding boxes");let v=performance.now(),E=await So(y);u=E.pixels;let A=Math.round(performance.now()-v);w.debug(`\u{1F5BC}\uFE0F Generated grayscale image (${E.width}x${E.height}) in ${A}ms`);let M={...c,phase:"labels",grayscaleImage:u,elementData:p.elementData};d=await e.evaluate(({code:R,argsObj:W})=>new Function("return "+R)()(W),{code:this.jsCode,argsObj:M}),d.map=p.map,d.rootId=p.rootId,d.highlightCount=p.highlightCount,d.perfMetrics=p.perfMetrics,w.debug("\u2705 Phase 2: Labels placed using grayscale-based positioning")}catch(b){w.warn("Two-phase rendering failed, falling back to legacy mode:",b.message),u=null;let p={...c,grayscaleImage:null};d=await e.evaluate(({code:y,argsObj:v})=>new Function("return "+y)()(v),{code:this.jsCode,argsObj:p}),w.debug("\u2705 JavaScript DOM analysis completed (legacy mode)")}else try{d=await e.evaluate(({code:b,argsObj:p})=>new Function("return "+b)()(p),{code:this.jsCode,argsObj:c}),w.debug("\u2705 JavaScript DOM analysis completed")}catch(b){throw w.error("Error evaluating JavaScript:",b.message),b}if(!d||typeof d!="object")throw w.error("JavaScript returned invalid result:",d),new Error("JavaScript DOM analysis returned invalid result");if(!d.map||!d.rootId)throw w.error("JavaScript result missing map or rootId:",JSON.stringify(d,null,2)),new Error("JavaScript result missing required fields (map or rootId)");if(s!=="all"&&d.highlightCount===0){w.debug(`\u26A0\uFE0F No elements matched intent '${s}', falling back to 'all'`);let b={...c,actionIntent:"all"};d=await e.evaluate(({code:p,argsObj:y})=>new Function("return "+p)()(y),{code:this.jsCode,argsObj:b})}let m=Object.entries(d.map).filter(([,b])=>b.tagName==="iframe");w.debug(`\u{1F50D} [ext-iframe] Total iframe nodes in map: ${m.length}`);for(let[b,p]of m){let y=p;w.debug(`\u{1F50D} [ext-iframe] iframe node id=${b} src=${y.attributes?.src} inaccessibleFrame=${y.inaccessibleFrame}`)}let h=e.frames();w.debug(`\u{1F50D} [ext-iframe] Playwright frames count: ${h.length}`);for(let b of h)w.debug(`\u{1F50D} [ext-iframe] Playwright frame url=${b.url()}`);let g=[];for(let[b,p]of Object.entries(d.map)){let y=p;this.shouldProcessWithPlaywrightFrameFallback(y,o)&&g.push({nodeId:b,src:y.attributes.src})}if(w.debug(`\u{1F50D} [ext-iframe] Inaccessible fallback iframes found: ${g.length}`),g.length>0){w.debug(`\u{1F50C} Found ${g.length} inaccessible iframe(s) for Playwright fallback, processing`);let b=-1;for(let p of Object.values(d.map)){let y=p;y.highlightIndex!=null&&(b=Math.max(b,y.highlightIndex))}w.debug(`\u{1F50D} [ext-iframe] Main page max highlight index: ${b}`);for(let p=0;p<g.length;p++){let{nodeId:y,src:v}=g[p];w.debug(`\u{1F50D} [ext-iframe] Processing fallback iframe [${p}]: ${v}`);let E=W=>{try{let D=new URL(W);if(D.protocol==="chrome-extension:"&&D.hostname)return`chrome-extension://${D.hostname}`;let X=D.origin;return X==="null"?null:X}catch{return null}},A=E(v);w.debug(`\u{1F50D} [ext-iframe] iframe src origin=${A??"null"}`);let M=null,R=e.frames().find(W=>{let D=W.url();if(D===v)return M="exact",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by exact URL: ${D}`),!0;let X=E(D);return w.debug(`\u{1F50D} [ext-iframe] Candidate frame compare url=${D} origin=${X??"null"} vs srcOrigin=${A??"null"}`),A&&X===A?(M="origin",w.debug(`\u{1F50D} [ext-iframe] Candidate frame matched by origin: ${D}`),!0):!1});if(!R){w.debug(`\u26A0\uFE0F [ext-iframe] No Playwright frame found for fallback iframe: ${v}`),w.debug(`\u26A0\uFE0F [ext-iframe] Available frame URLs: ${e.frames().map(W=>W.url()).join(", ")}`);continue}w.debug(`\u{1F50D} [ext-iframe] Found matching Playwright frame for: ${v} (frame url: ${R.url()})`);try{let W={...c,initialHighlightIndex:b+1,domTreeRoot:"body"};w.debug(`\u{1F50D} [ext-iframe] Running dom-tree in extension frame with initialHighlightIndex=${W.initialHighlightIndex}`);let D=await R.evaluate(({code:V,argsObj:J})=>new Function("return "+V)()(J),{code:this.jsCode,argsObj:W});if(w.debug(`\u{1F50D} [ext-iframe] frameEval result: map size=${Object.keys(D?.map??{}).length} rootId=${D?.rootId}`),!D?.map||!D.rootId){w.debug("\u26A0\uFE0F [ext-iframe] frameEval missing map or rootId, skipping");continue}let X=Object.values(D.map).filter(V=>V.highlightIndex!=null);w.debug(`\u{1F50D} [ext-iframe] Interactive elements in extension frame: ${X.length}`);for(let V of X){let J=V;w.debug(`\u{1F50D} [ext-iframe] - <${J.tagName}> highlightIndex=${J.highlightIndex} text="${J.children?.length?"...":""}"`)}for(let V of Object.values(D.map)){let J=V;J.highlightIndex!=null&&(b=Math.max(b,J.highlightIndex))}let ee=`ext_${p}_`;for(let[V,J]of Object.entries(D.map)){let we={...J};we.children&&(we.children=we.children.map(De=>`${ee}${De}`)),d.map[`${ee}${V}`]=we}let fe=d.map[y];fe?(fe.children=[...fe.children||[],`${ee}${D.rootId}`],w.debug(`\u{1F50D} [ext-iframe] Attached frame root to iframe node ${y}`)):w.debug(`\u26A0\uFE0F [ext-iframe] iframe node ${y} not found in map`),w.debug(`\u2705 Merged fallback iframe content from: ${v}`)}catch(W){w.warn(`Failed to process fallback iframe ${v}:`,W)}}}if(d&&d.perfMetrics){let b=d.perfMetrics.nodeMetrics?.totalNodes??0,p=0;if(d.map)for(let v of Object.values(d.map))typeof v=="object"&&v!==null&&v.isInteractive&&p++;let y=e.url().length>50?e.url().slice(0,50)+"...":e.url();w.debug(`\u{1F50E} Ran buildDOMTree.js interactive element detection on: ${y} interactive=${p}/${b}`)}w.debug("\u{1F504} Starting TypeScript DOM tree construction...");let f=await this.constructDomTree(d);return w.debug("\u2705 TypeScript DOM tree construction completed"),f}async constructDomTree(e){let t=e.map,i=e.rootId,n=new Map,a=new Map,o=new Map;for(let[l,s]of Object.entries(t)){let[c,d]=this.parseNode(s);c!==null&&(a.set(l,c),o.set(l,d),c instanceof Se&&c.highlightIndex!==null&&n.set(c.highlightIndex,c))}for(let[l,s]of o){let c=a.get(l);if(c instanceof Se)for(let d of s){let u=a.get(d);u&&(u.parent=c,c.children.push(u))}}let r=a.get(i);if(!r||!(r instanceof Se))throw new Error("Failed to parse HTML to dictionary");return[r,n]}parseNode(e){if(!e)return[null,[]];if(e.type==="TEXT_NODE")return[new St(e.text,e.isVisible,null),[]];let t=null;e.viewport&&(t={width:e.viewport.width,height:e.viewport.height,scrollX:e.viewport.scrollX,scrollY:e.viewport.scrollY});let i=e.shadowHostXPaths??[],n=new Se(e.tagName,e.xpath,e.attributes||{},[],e.isVisible??!1,e.isInteractive??!1,e.isScrollable??!1,e.markAsClickable??!1,e.isTopElement??!1,e.isInViewport??!1,e.shadowRoot??!1,e.highlightIndex??null,e.viewportCoordinates??null,e.pageCoordinates??null,t,i,null),a=e.children||[];return[n,a]}}});var Mo,Io,Dm,Hi=x(()=>{"use strict";Mo=require("zod"),Io=class{async execute(e,t){await e.waitForLoadState("networkidle",{timeout:5e3}).catch(()=>{}),await e.waitForLoadState("domcontentloaded")}transpile(e){return["await page.waitForLoadState('domcontentloaded');"]}},Dm=Mo.z.object({})});var Po,Wi=x(()=>{"use strict";H();I();Po=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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=P(i,t.action_data?.kwargs?.timeout_ms);if(o)await o.press(a,{timeout:r}),await e.waitForTimeout(500);else throw new Error("No locator found for send keys on element action")}transpile(e){let t=Ie(e);if(!t){let a=e.action_data?.kwargs?.keys||"";return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(a)} } },`,"});"]}let i=e.action_data?.kwargs?.keys||"",n=P();return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]}}});var Ac,Co,qe,Et=x(()=>{"use strict";be();Ac=Q(require("playwright/test"),1),Co=Q(require("playwright/test"),1),qe={};xi(qe,{default:()=>Co.default});Ka(qe,Ac)});var ta,No,Gm,Ui=x(()=>{"use strict";Et();ta=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.code;if(!a)throw new Error("Missing code for js_code action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 js_code requires an agent reference");await new Function("page","expect","agent",`
|
|
4086
4086
|
return (async () => {
|
|
4087
4087
|
${a}
|
|
4088
4088
|
})();
|
|
4089
|
-
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t
|
|
4090
|
-
`):
|
|
4089
|
+
`)(e,qe.expect,o)}transpile(e){let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4090
|
+
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Gm=ta.z.object({code:ta.z.string().describe("JavaScript code to execute in the browser context")})});var Oo,Bi=x(()=>{"use strict";H();I();Oo=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:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l,{button:"right",delay:100}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y,{button:"right"}),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("right_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Do,ji=x(()=>{"use strict";Do=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",`
|
|
4091
4091
|
return (async () => {
|
|
4092
4092
|
${a}
|
|
4093
4093
|
})();
|
|
4094
|
-
`)(e,
|
|
4095
|
-
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i}},Ym=ta.z.object({code:ta.z.string().describe("JavaScript code to execute in the browser context")})});var Lo,Gi=x(()=>{"use strict";H();I();Lo=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:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,l,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Ro,Ki=x(()=>{"use strict";H();I();Ro=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],l=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let s=O(e,t);if(!s)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await s.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await s).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,u=c.y+o.relative_y+c.height/2,p=d+o.delta_x,h=u+o.delta_y;await e.mouse.move(d,u),await e.mouse.down(),n>0?await e.mouse.move(p,h,{steps:n}):await e.mouse.move(p,h),await e.mouse.up()}else if(r.every(s=>typeof s=="number")&&l.every(s=>typeof s=="number")){let[s,c]=r,[d,u]=l;await e.mouse.move(s,c),await e.mouse.down(),n>0?await e.mouse.move(d,u,{steps:n}):await e.mouse.move(d,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(a=>` ${a},`),"});"]}}});var Fo,zi=x(()=>{"use strict";Fo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.generateFunctionCallCode(n.kwargs);if(!a)throw new Error("Missing function name for function action");let o=i.agent;if(!o)throw new Error("Agent not initialized on AgentServices \u2014 FunctionAction requires an agent reference");await new Function("page","agent",`
|
|
4094
|
+
`)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((l,s)=>s<r.length?String(r[s]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var Lo,Gi=x(()=>{"use strict";Lo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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",`
|
|
4096
4095
|
return (async () => {
|
|
4097
4096
|
${a}
|
|
4098
4097
|
})();
|
|
4099
|
-
`)(e,o)}transpile(e){let t=this.generateFunctionCallCode(e.action_data?.kwargs||{});return t?[t.endsWith(";")?t:`${t};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(e){let t=e.functionName;if(!t)return null;let i;if(Array.isArray(e.args))i=e.args.map(String);else if(Array.isArray(e.parameterNames)){let r=e.parameterValues||[];i=e.parameterNames.map((l,s)=>s<r.length?String(r[s]):"undefined")}else return`await ${t}()`;if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}}});var Vi=x(()=>{"use strict";Je()});var Ho,Tt=x(()=>{"use strict";Ho=(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))(Ho||{})});var Ze={};Ge(Ze,{evaluateStatement:()=>Ji,executeAction:()=>At,executeStep:()=>Yi,generateActionStep:()=>Xi,runTask:()=>qi});var Qe=x(()=>{"use strict";$t();Ri();Di();yi();Ye();Ti();$i();Ke();Ai();gt();ft();Ni();wt();ke();dt();Vi();Fe();xt();vt();Je();_t();kt();ne();_e();mt();ze();pt();Re();z();Le();U();ie();Tt();H();be()});var ia,Wo,Gp,Zi=x(()=>{"use strict";ia=require("zod"),Wo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(Qe(),Ze)),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"]}},Gp=ia.z.object({statement:ia.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});var Uo,Qi=x(()=>{"use strict";H();I();Uo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");if(typeof n.kwargs.relative_x=="number"&&typeof n.kwargs.relative_y=="number"){let a=O(e,t);if(a){await a.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var na,Bo,Jp,en=x(()=>{"use strict";na=require("zod"),Bo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(Qe(),Ze)),l=await r(a,e,i,{usePureVision:o});if(l.status!=="success")throw new Error(l.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},Jp=na.z.object({statement:na.z.string().describe('The action to perform (e.g., "click the submit button")')})});function Go(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:$c,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Switched to tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:s.message}}}}})}var aa,jo,$c,Mt=x(()=>{"use strict";aa=require("zod"),jo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let l=await i.switchTab(r);await l.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await l.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},$c=aa.z.object({tab_index:aa.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 zo(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){w.info("Using mockShowOpenFilePicker approach");let l=i.map(s=>({path:s,buffer:new Uint8Array(Ko.default.readFileSync(s))}));await e.evaluate(s=>{window.__pw_showOpenFilePicker_mock_files=s},l),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)w.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{w.info("Using file chooser approach");let l=e.waitForEvent("filechooser",{timeout:o});l.catch(()=>{}),await t.click({timeout:o}),await(await l).setFiles(i),await e.waitForTimeout(3e3)}w.info(`Successfully uploaded ${i.length} file(s)`)}var Ko,It=x(()=>{"use strict";U();Ko=Q(require("fs"),1)});async function Mc(e,t,i={},n){return{...await F(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function Vo(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 Yo(e,t){e.register({name:"upload_file",description:'Click on target element (usually contains hints like "Upload file" or "Choose file" etc.) to trigger the file upload dialog, and choose the files to upload',schema:Ic,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:Vo(s||`Upload file to element ${a}`,{index:a,paths:o})};let d=await Mc(c,r,{paths:o},s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Vo(s||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Ee,Xo,Ic,rg,Pt=x(()=>{"use strict";It();z();H();Ee=require("zod");I();Xo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(c=>i.getTestDataFilePath(c)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let l=n.kwargs.use_file_input||!1,s=i.getActionSettings().mock_show_open_file_picker??!1;await zo(e,r,o,{useFileInput:l,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:s})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]}};Ic=Ee.z.object({element_index:Ee.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ee.z.string().describe("Paths to the files to upload"),timeout_ms:Ee.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});rg=Ee.z.object({element_index:Ee.z.number().int().describe("Index of the file input element"),paths:Ee.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ee.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function qo(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Pc,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Waited ${a} seconds`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:s.message}}}}})}var oa,Jo,Pc,Ct=x(()=>{"use strict";oa=require("zod"),Jo=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.seconds||1;await e.waitForTimeout(n*1e3)}transpile(e){return[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]}},Pc=oa.z.object({seconds:oa.z.number().positive().describe("Number of seconds to wait")})});function Qo(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:Cc,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let l={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:"Download completed"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:l.message}}}}})}var ra,Zo,Cc,Nt=x(()=>{"use strict";ra=require("zod"),Zo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},Cc=ra.z.object({timeout_seconds:ra.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function tr(e,t){e.register({name:"ai_wait_until",description:'Wait until a specific condition is met on the page (e.g., "page loads", "spinner disappears", "button becomes enabled"). Use this instead of wait when the goal is to wait for something to happen rather than waiting a fixed duration.',schema:Nc,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Condition met: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:s.message}}}}})}var tn,er,Nc,Ot=x(()=>{"use strict";tn=require("zod"),er=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,l=Date.now(),{evaluateStatement:s}=await Promise.resolve().then(()=>(Qe(),Ze));for(;Date.now()-l<o;){if((await s(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},Nc=tn.z.object({condition:tn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:tn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});function nr(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Oc,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Saved variable "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:s.message}}}}})}var nn,ir,Oc,Dt=x(()=>{"use strict";nn=require("zod"),ir=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.name,o=n.kwargs.value;if(!a||o===void 0)throw new Error("Missing variable name or value for save_variable");a.startsWith("$")&&(a=a.slice(1)),i.saveVariable(a,o)}transpile(e){let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]}},Oc=nn.z.object({name:nn.z.string().describe("Variable name to save"),value:nn.z.string().describe("Value to save in the variable")})});async function Dc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Lc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function ar(e,t){e.register({name:"scroll",description:"Scroll the page by specified number of pages (set down=True to scroll down, down=False to scroll up, num_pages=number of pages to scroll like 0.5 for half page, 1.0 for one page, etc.). ",schema:Rc,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=s||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await Dc("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:Lc(s||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var an,Lt,Rc,Rt=x(()=>{"use strict";an=require("zod"),Lt=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.down??!0,a=i.kwargs.num_pages??1,o=n?1:-1;await e.evaluate(`window.scrollBy(0, window.innerHeight * ${a} * ${o})`)}transpile(e){let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]}};Rc=an.z.object({down:an.z.boolean().describe("True to scroll down, False to scroll up"),num_pages:an.z.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")})});async function Fc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function or(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function sr(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Hc,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:l,agentServices:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:or(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await Fc("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,l,{delta_x:o,delta_y:r});return await t.execute(l,d,s),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:or(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var et,rr,Hc,Ft=x(()=>{"use strict";z();H();et=require("zod");I();rr=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),l=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:l}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Ie(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Hc=et.z.object({element_index:et.z.number().int().describe("Index of the scrollable element"),delta_x:et.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:et.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:et.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function cr(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Wc,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Scrolled to text "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:s.message}}}}})}var sa,lr,Wc,Ht=x(()=>{"use strict";sa=require("zod"),lr=class{async execute(e,t){let i=t.action_data;if(!i)throw new Error("Action data not found");let n=i.kwargs.text;if(n)await e.getByText(n,{exact:!1}).first().scrollIntoViewIfNeeded(),await e.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(e){let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},Wc=sa.z.object({text:sa.z.string().describe("Text to scroll to on the page")})});async function Uc(e,t,i,n){return{...await F(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function dr(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 hr(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Bc,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:dr(s||`Select option in dropdown ${a}`,{index:a,option:o})};let d=await Uc(c,r,o,s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:dr(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Wt,ur,Bc,Ut=x(()=>{"use strict";z();H();Wt=require("zod");I();ur=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};Bc=Wt.z.object({element_index:Wt.z.number().int().describe("Index of the dropdown/select element"),option:Wt.z.string().describe("Option value, label, or index to select"),timeout_ms:Wt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function jc(e,t,i,n){return{...await F(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function la(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 pr(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">).
|
|
4098
|
+
`)(e,o)}transpile(e){let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4099
|
+
`):["// Skipping js_action: missing code"]}}});var Ro,Ki=x(()=>{"use strict";H();I();Ro=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:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.move(r,l),await e.waitForTimeout(200),await e.mouse.click(r,l),await e.waitForTimeout(500)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.move(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200),await e.mouse.click(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(500);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Fo,zi=x(()=>{"use strict";H();I();Fo=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:P(i,t.action_data?.kwargs?.timeout_ms)});let o=await a.boundingBox();if(o){let r=o.x+n.kwargs.relative_x+o.width/2,l=o.y+n.kwargs.relative_y+o.height/2;await e.mouse.dblclick(r,l,{delay:50}),await e.waitForTimeout(200)}}else throw new Error("Element-anchored coordinates provided but no locator found")}else if(typeof n.kwargs.x=="number"&&typeof n.kwargs.y=="number")await e.mouse.dblclick(n.kwargs.x,n.kwargs.y),await e.waitForTimeout(200);else throw new Error("Missing or invalid coordinates")}transpile(e){let t=e.action_data?.kwargs||{},i=[];return typeof t.relative_x=="number"&&typeof t.relative_y=="number"?(i.push(`action_data: { kwargs: { relative_x: ${t.relative_x}, relative_y: ${t.relative_y} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`)):typeof t.x=="number"&&typeof t.y=="number"&&i.push(`action_data: { kwargs: { x: ${t.x}, y: ${t.y} } }`),['await agent.execAction("double_click_by_coordinates", page, {',...i.map(n=>` ${n},`),"});"]}}});var Ho,Vi=x(()=>{"use strict";H();I();Ho=class{async execute(e,t,i){let n=i.getActionSettings().drag_drop_steps??10,a=t.action_data;if(!a)throw new Error("Action data not found");let o=a.kwargs,r=[o.coord_source_x,o.coord_source_y],l=[o.coord_target_x,o.coord_target_y];if(typeof o.relative_x=="number"&&typeof o.relative_y=="number"&&typeof o.delta_x=="number"&&typeof o.delta_y=="number"){let s=O(e,t);if(!s)throw new Error("No locator found for drag_drop action with element-anchored coordinates");await s.waitFor({state:"attached",timeout:P(i,t.action_data?.kwargs?.timeout_ms)});let c=await(await s).boundingBox();if(!c)throw new Error("Could not get bounding box for drag_drop element");let d=c.x+o.relative_x+c.width/2,u=c.y+o.relative_y+c.height/2,m=d+o.delta_x,h=u+o.delta_y;await e.mouse.move(d,u),await e.mouse.down(),n>0?await e.mouse.move(m,h,{steps:n}):await e.mouse.move(m,h),await e.mouse.up()}else if(r.every(s=>typeof s=="number")&&l.every(s=>typeof s=="number")){let[s,c]=r,[d,u]=l;await e.mouse.move(s,c),await e.mouse.down(),n>0?await e.mouse.move(d,u,{steps:n}):await e.mouse.move(d,u),await e.mouse.up()}else throw new Error("Missing coordinates for drag_drop action: requires either element-anchored coordinates with delta, or full absolute coordinates");await e.waitForTimeout(500)}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return typeof t.relative_x=="number"&&(n.relative_x=t.relative_x),typeof t.relative_y=="number"&&(n.relative_y=t.relative_y),typeof t.delta_x=="number"&&(n.delta_x=t.delta_x),typeof t.delta_y=="number"&&(n.delta_y=t.delta_y),typeof t.coord_source_x=="number"&&(n.coord_source_x=t.coord_source_x),typeof t.coord_source_y=="number"&&(n.coord_source_y=t.coord_source_y),typeof t.coord_target_x=="number"&&(n.coord_target_x=t.coord_target_x),typeof t.coord_target_y=="number"&&(n.coord_target_y=t.coord_target_y),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("drag_drop", page, {',...i.map(a=>` ${a},`),"});"]}}});var Xi=x(()=>{"use strict";Je()});var Wo,Tt=x(()=>{"use strict";Wo=(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))(Wo||{})});var Ze={};Ge(Ze,{evaluateStatement:()=>qi,executeAction:()=>At,executeStep:()=>Ji,generateActionStep:()=>Yi,runTask:()=>Zi});var Qe=x(()=>{"use strict";$t();Ri();Di();yi();Ye();Ti();$i();Ke();Ai();Pi();ft();wt();ke();dt();gt();Xi();Fe();xt();vt();Je();_t();kt();ne();_e();mt();ze();pt();Re();z();Le();U();ie();Tt();H();be()});var ia,Uo,Vp,Qi=x(()=>{"use strict";ia=require("zod"),Uo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_action");let o=n.kwargs.use_pure_vision,{executeStep:r}=await Promise.resolve().then(()=>(Qe(),Ze)),l=await r(a,e,i,{usePureVision:o});if(l.status!=="success")throw new Error(l.error||"Action execution failed")}transpile(e,t){let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]}},Vp=ia.z.object({statement:ia.z.string().describe('The action to perform (e.g., "click the submit button")')})});var na,Bo,Jp,en=x(()=>{"use strict";na=require("zod"),Bo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.statement;if(!a)throw new Error("Missing statement for ai_step");let{runTask:o}=await Promise.resolve().then(()=>(Qe(),Ze)),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"]}},Jp=na.z.object({statement:na.z.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')})});function Go(e,t){e.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:$c,async execute(i,n){let{timeout_seconds:a=10}=i,{page:o,agentServices:r}=n;try{let l={action_description:`Wait for download to complete (timeout: ${a}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:"Download completed"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:a}},feedback:l.message}}}}})}var aa,jo,$c,Mt=x(()=>{"use strict";aa=require("zod"),jo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.timeout_seconds||10;await i.waitForDownloadComplete(e,a)}transpile(e){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},$c=aa.z.object({timeout_seconds:aa.z.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")})});function zo(e,t){e.register({name:"ai_wait_until",description:'Wait until a specific condition is met on the page (e.g., "page loads", "spinner disappears", "button becomes enabled"). Use this instead of wait when the goal is to wait for something to happen rather than waiting a fixed duration.',schema:Mc,async execute(i,n){let{condition:a,timeout_seconds:o=60}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Wait until: ${a}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Condition met: ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Wait until: ${a} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:a,timeout_seconds:o}},feedback:s.message}}}}})}var tn,Ko,Mc,It=x(()=>{"use strict";tn=require("zod"),Ko=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.condition;if(!a)throw new Error("Missing condition for ai_wait_until");let o=(n.kwargs.timeout_seconds||60)*1e3,r=5e3,l=Date.now(),{evaluateStatement:s}=await Promise.resolve().then(()=>(Qe(),Ze));for(;Date.now()-l<o;){if((await s(a,e,i,{})).success)return;await e.waitForTimeout(r)}throw new Error(`Timeout waiting for condition: ${a}`)}transpile(e,t){let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t}');`]:["// Skipping ai_wait_until: missing condition"]}},Mc=tn.z.object({condition:tn.z.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:tn.z.number().positive().optional().describe("Timeout in seconds (default: 60)")})});async function Ic(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Vo(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Yo(e,t){e.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:Pc,usesElementIndex:!0,async execute(i,n){let{element_index:a,delta_x:o,delta_y:r}=i,{page:l,agentServices:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Element with index ${a} not found`,actionEntity:Vo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})};let d=await Ic("scroll_on_element",`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,c,l,{delta_x:o,delta_y:r});return await t.execute(l,d,s),{success:!0,actionEntity:d,message:`Scrolled on element ${a} horizontally: ${o}px, vertically: ${r}px`}}catch(c){return{success:!1,error:c.message,actionEntity:Vo(`Scroll on element ${a} horizontally: ${o}px, vertically: ${r}px`,"scroll_on_element",{index:a,delta_x:o,delta_y:r})}}}})}var et,Xo,Pc,Pt=x(()=>{"use strict";z();H();et=require("zod");I();Xo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.delta_x||0,o=n.kwargs.delta_y||0,r=O(e,t),l=P(i,t.action_data?.kwargs?.timeout_ms);if(r)await r.hover({timeout:l}),await e.mouse.wheel(a,o);else throw new Error("No locator found for scroll_on_element action")}transpile(e){let t=Ie(e);if(!t){let a=e.action_data?.kwargs?.delta_x||0,o=e.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${a}, delta_y: ${o} } },`,"});"]}let i=e.action_data?.kwargs?.delta_x||0,n=e.action_data?.kwargs?.delta_y||0;return[`await ${t}.hover({ timeout: ${P()} });`,`await page.mouse.wheel(${i}, ${n});`]}};Pc=et.z.object({element_index:et.z.number().int().describe("Index of the scrollable element"),delta_x:et.z.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:et.z.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:et.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function qo(e,t){e.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Cc,async execute(i,n){let{text:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Scroll to text "${a}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Scrolled to text "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Scroll to text "${a}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:a}},feedback:s.message}}}}})}var oa,Jo,Cc,Ct=x(()=>{"use strict";oa=require("zod"),Jo=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();`]}},Cc=oa.z.object({text:oa.z.string().describe("Text to scroll to on the page")})});async function Nc(e,t,i,n){return{...await F(t,e),action_description:n||`Select option "${i}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:i}}}}function Zo(e,t){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:"select_dropdown_option",kwargs:t},feedback:"Element not found in DOM"}}function er(e,t){e.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:Oc,usesElementIndex:!0,async execute(i,n){let{element_index:a,option:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Zo(s||`Select option in dropdown ${a}`,{index:a,option:o})};let d=await Nc(c,r,o,s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Selected option "${o}" in dropdown ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Zo(`Select option in dropdown ${a}`,{index:a,option:o})}}}})}var Nt,Qo,Oc,Ot=x(()=>{"use strict";z();H();Nt=require("zod");I();Qo=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text||n.kwargs.option,o=O(e,t),r=P(i,t.action_data?.kwargs?.timeout_ms);if(o&&a)await o.selectOption(a,{timeout:r});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(e){let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...i.map(n=>` ${n},`),"});"]}};Oc=Nt.z.object({element_index:Nt.z.number().int().describe("Index of the dropdown/select element"),option:Nt.z.string().describe("Option value, label, or index to select"),timeout_ms:Nt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Dc(e,t,i,n){return{...await F(i,t),action_description:e,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:n}}}}function ra(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 ir(e,t){e.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
|
|
4100
4100
|
|
|
4101
4101
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
4102
4102
|
Do NOT use it for custom/non-native date pickers
|
|
4103
4103
|
|
|
4104
|
-
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Gc,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:la(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=s.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:la(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await jc(`Set date to ${o} on element ${a}`,s,r,o);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:la(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Bt,mr,Gc,jt=x(()=>{"use strict";z();H();Bt=require("zod");I();mr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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 l=await r.getAttribute("type").catch(()=>null);if(l&&l!=="date")throw new Error(`Element is not a native date picker (type="${l}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Gc=Bt.z.object({element_index:Bt.z.number().int().describe("Index of the native date picker input element"),date:Bt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Bt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Kc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function gr(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 fr(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:zc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:gr(`Hover element ${a}`,"hover",{index:a})};let c=l||`Hover over element ${a}`,d=await Kc("hover",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:gr(`Hover element ${a}`,"hover",{index:a})}}}})}var on,ca,zc,Gt=x(()=>{"use strict";z();H();on=require("zod");I();ca=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let l=r.x+r.width/2,s=r.y+r.height/2;await e.mouse.move(l,s)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};zc=on.z.object({element_index:on.z.number().int().describe("Index of the element to hover over"),timeout_ms:on.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Vc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function wr(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 br(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:Xc,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:wr(s||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=s||`Input text to element ${a}`,u=await Vc("input_text",d,c,r,{text:o});return await t.execute(r,u,l),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:wr(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Kt,da,Xc,zt=x(()=>{"use strict";z();H();Kt=require("zod");I();da=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),l=P(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:l}),await r.click({timeout:l}),await e.waitForTimeout(200);let s=i.getActionSettings().type_delay;s!==void 0?await e.keyboard.type(o,{delay:s}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};Xc=Kt.z.object({element_index:Kt.z.number().int().describe("Index of the input element"),text:Kt.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:Kt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function yr(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:Yc,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Pressed keys "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:s.message}}}}})}var ua,ha,Yc,Vt=x(()=>{"use strict";ua=require("zod"),ha=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)});`]}},Yc=ua.z.object({keys:ua.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 _r(e,t){e.register({name:"reload_page",description:"Reload the current page. WARNING: This will reset any in-progress forms or multi-step flows (like login). Only use when you need to refresh stale data or clear a stuck state. Do NOT use during login, checkout, or form submission flows.",schema:Jc,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:`Reloaded ${a.url()}`}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:r.message}}}}})}var xr,vr,Jc,Xt=x(()=>{"use strict";H();xr=require("zod");I();vr=class{async execute(e,t){await e.reload({timeout:he}),await e.waitForLoadState("load",{timeout:he}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Jc=xr.z.object({})});async function qc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function kr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Sr(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Zc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:kr(`Right-click element ${a}`,"right_click",{index:a})};let c=l||`Right-click element ${a}`,d=await qc("right_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:kr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var rn,ma,Zc,Yt=x(()=>{"use strict";z();H();rn=require("zod");I();ma=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Zc=rn.z.object({element_index:rn.z.number().int().describe("Index of the element to right-click"),timeout_ms:rn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function Qc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Er(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Tr(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:ed,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Er(`Double-click element ${a}`,"double_click",{index:a})};let c=l||`Double-click element ${a}`,d=await Qc("double_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Er(`Double-click element ${a}`,"double_click",{index:a})}}}})}var sn,pa,ed,Jt=x(()=>{"use strict";z();H();sn=require("zod");I();pa=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};ed=sn.z.object({element_index:sn.z.number().int().describe("Index of the element to double-click"),timeout_ms:sn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function $r(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:td,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:l.message}}}}})}var ga,Ar,td,qt=x(()=>{"use strict";ga=require("zod"),Ar=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.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)} } },`,"});"]}},td=ga.z.object({otp_secret_key:ga.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function id(e,t,i){return{...await F(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function Mr(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 Pr(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:nd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:Mr(l||`Get options from dropdown ${a}`,{index:a})};let c=await id(s,o,l);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(s){return{success:!1,error:s.message,actionEntity:Mr(l||`Get options from dropdown ${a}`,{index:a})}}}})}var fa,Ir,nd,Zt=x(()=>{"use strict";z();fa=require("zod"),Ir=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.evaluate(r=>{let l=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return l?{options:Array.from(l.options).map(s=>({text:s.text,value:s.value,index:s.index})),id:l.id,name:l.name}:null},t.xpath);if(o){let r=[];for(let l of o.options){let s=JSON.stringify(l.text);r.push(`${l.index}: text=${s}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
|
|
4104
|
+
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:Lc,usesElementIndex:!0,async execute(i,n){let{element_index:a,date:o}=i,{page:r,agentServices:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Date picker element with index ${a} not found`,actionEntity:ra(`Set date to ${o} on element ${a}`,{index:a,date:o})};let c=s.attributes.type;if(c!=="date")return{success:!1,error:`Element ${a} is not a native date picker (type="${c}"). This action only works with <input type="date">.`,actionEntity:ra(`Set date to ${o} on element ${a}`,{index:a,date:o})};let d=await Dc(`Set date to ${o} on element ${a}`,s,r,o);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Set date to ${o} on element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:ra(`Set date to ${o} on element ${a}`,{index:a,date:o})}}}})}var Dt,tr,Lc,Lt=x(()=>{"use strict";z();H();Dt=require("zod");I();tr=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 l=await r.getAttribute("type").catch(()=>null);if(l&&l!=="date")throw new Error(`Element is not a native date picker (type="${l}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await r.fill(o,{timeout:P(i,t.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(e){let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]}};Lc=Dt.z.object({element_index:Dt.z.number().int().describe("Index of the native date picker input element"),date:Dt.z.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Dt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ar(e,t){e.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:Rc,async execute(i,n){let a=i.tab_index,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Switch to tab ${a}`,action_data:{action_name:"switch_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Switched to tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Switch to tab ${a}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:a}},feedback:s.message}}}}})}var sa,nr,Rc,Rt=x(()=>{"use strict";sa=require("zod"),nr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.tab_index??0;if(typeof a=="number"){let o=e.context().pages(),r=a===-1?o.length-1:a;if(i){let l=await i.switchTab(r);await l.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await l.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(e){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]}},Rc=sa.z.object({tab_index:sa.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 rr(e,t,i,n){let{useFileInput:a,timeout:o,mockShowOpenFilePicker:r}=n;if(r){w.info("Using mockShowOpenFilePicker approach");let l=i.map(s=>({path:s,buffer:new Uint8Array(or.default.readFileSync(s))}));await e.evaluate(s=>{window.__pw_showOpenFilePicker_mock_files=s},l),await t.click({timeout:o}),await e.waitForTimeout(3e3),await e.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(a)w.info("Using direct file input approach"),await t.setInputFiles(i,{timeout:o}),await e.waitForTimeout(3e3);else{w.info("Using file chooser approach");let l=e.waitForEvent("filechooser",{timeout:o});l.catch(()=>{}),await t.click({timeout:o}),await(await l).setFiles(i),await e.waitForTimeout(3e3)}w.info(`Successfully uploaded ${i.length} file(s)`)}var or,Ft=x(()=>{"use strict";U();or=Q(require("fs"),1)});async function Fc(e,t,i={},n){return{...await F(t,e),action_description:n||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...i}}}}function sr(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 cr(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:Hc,usesElementIndex:!0,async execute(i,n){let{element_index:a,paths:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`File input element with index ${a} not found`,actionEntity:sr(s||`Upload file to element ${a}`,{index:a,paths:o})};let d=await Fc(c,r,{paths:o},s);return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Uploaded file to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:sr(s||`Upload file to element ${a}`,{index:a,paths:o})}}}})}var Ee,lr,Hc,Sg,Ht=x(()=>{"use strict";Ft();z();H();Ee=require("zod");I();lr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=[];if(n.kwargs.paths?a=Array.isArray(n.kwargs.paths)?n.kwargs.paths:[n.kwargs.paths]:n.kwargs.path&&(a=Array.isArray(n.kwargs.path)?n.kwargs.path:[n.kwargs.path]),a.length===0)throw new Error("No file paths provided for upload_file action");await i.downloadTestDataFiles(a);let o=a.map(c=>i.getTestDataFilePath(c)),r=O(e,t);if(!r)throw new Error("Missing locator for upload_file action");let l=n.kwargs.use_file_input||!1,s=i.getActionSettings().mock_show_open_file_picker??!1;await rr(e,r,o,{useFileInput:l,timeout:P(i,t.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:s})}transpile(e){let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]}};Hc=Ee.z.object({element_index:Ee.z.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:Ee.z.string().describe("Paths to the files to upload"),timeout_ms:Ee.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});Sg=Ee.z.object({element_index:Ee.z.number().int().describe("Index of the file input element"),paths:Ee.z.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:Ee.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function ur(e,t){e.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:Wc,async execute(i,n){let{seconds:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Wait ${a} seconds`,action_data:{action_name:"wait",kwargs:{seconds:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Waited ${a} seconds`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Wait ${a} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:a}},feedback:s.message}}}}})}var la,dr,Wc,Wt=x(()=>{"use strict";la=require("zod"),dr=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});`]}},Wc=la.z.object({seconds:la.z.number().positive().describe("Number of seconds to wait")})});function hr(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:Uc,async execute(i,n){let{keys:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Press keys "${a}"`,action_data:{action_name:"press",kwargs:{keys:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Pressed keys "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||`Press keys "${a}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:a}},feedback:s.message}}}}})}var ca,da,Uc,Ut=x(()=>{"use strict";ca=require("zod"),da=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)});`]}},Uc=ca.z.object({keys:ca.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 gr(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:Bc,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 mr,pr,Bc,Bt=x(()=>{"use strict";H();mr=require("zod");I();pr=class{async execute(e,t){await e.reload({timeout:he}),await e.waitForLoadState("load",{timeout:he}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("reload_page", page, {});']}},Bc=mr.z.object({})});async function jc(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function fr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function wr(e,t){e.register({name:"right_click",description:"Right-click an interactive element.",schema:Gc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:fr(`Right-click element ${a}`,"right_click",{index:a})};let c=l||`Right-click element ${a}`,d=await jc("right_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Right-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:fr(`Right-click element ${a}`,"right_click",{index:a})}}}})}var nn,ua,Gc,jt=x(()=>{"use strict";z();H();nn=require("zod");I();ua=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({button:"right",timeout:a});else throw new Error("No locator found for right_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...t.map(i=>` ${i},`),"});"]}};Gc=nn.z.object({element_index:nn.z.number().int().describe("Index of the element to right-click"),timeout_ms:nn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function yr(e,t){e.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:Kc,async execute(i,n){let{name:a,value:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Save variable "${a}" = "${o}"`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Saved variable "${a}"`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Save variable "${a}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:a,value:o}},feedback:s.message}}}}})}var an,br,Kc,Gt=x(()=>{"use strict";an=require("zod"),br=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)} } },`,"});"]}},Kc=an.z.object({name:an.z.string().describe("Variable name to save"),value:an.z.string().describe("Value to save in the variable")})});async function zc(e,t,i={}){return{action_description:t,action_data:{action_name:e,kwargs:{...i}}}}function Vc(e,t,i){return{action_description:`${e} (failed)`,action_data:{action_name:t,kwargs:i},feedback:"Scroll failed!"}}function xr(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:Xc,async execute(i,n){let{down:a,num_pages:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=s||`Scroll ${a?"down":"up"} ${o} page(s)`,d=await zc("scroll",c,{down:a,num_pages:o});return await t.execute(r,d,l),{success:!0,actionEntity:d,message:`Scrolled ${a?"down":"up"} ${o} page(s)`}}catch(c){return{success:!1,error:c.message,actionEntity:Vc(s||`Scroll ${a?"down":"up"} ${o} page(s)`,"scroll",{down:a,num_pages:o})}}}})}var on,Kt,Xc,zt=x(()=>{"use strict";on=require("zod"),Kt=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)})');`]}};Xc=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.)")})});function _r(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:Yc,async execute(i,n){let{otp_secret_key:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:a}},feedback:l.message}}}}})}var ha,vr,Yc,Vt=x(()=>{"use strict";ha=require("zod"),vr=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)} } },`,"});"]}},Yc=ha.z.object({otp_secret_key:ha.z.string().describe("The OTP secret key to generate the 2FA code from")})});async function Jc(e,t,i){return{...await F(t,e),action_description:i||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function kr(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 Er(e,t){e.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:qc,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Dropdown element with index ${a} not found`,actionEntity:kr(l||`Get options from dropdown ${a}`,{index:a})};let c=await Jc(s,o,l);return await t.execute(o,c,r),{success:!0,actionEntity:c,message:c.feedback||"No options found"}}catch(s){return{success:!1,error:s.message,actionEntity:kr(l||`Get options from dropdown ${a}`,{index:a})}}}})}var ma,Sr,qc,Xt=x(()=>{"use strict";z();ma=require("zod"),Sr=class{async execute(e,t,i){if(!t.xpath)throw new Error("XPath not found in action entity");let n=[];for(let a of e.frames())try{let o=await a.evaluate(r=>{let l=document.evaluate(r,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return l?{options:Array.from(l.options).map(s=>({text:s.text,value:s.value,index:s.index})),id:l.id,name:l.name}:null},t.xpath);if(o){let r=[];for(let l of o.options){let s=JSON.stringify(l.text);r.push(`${l.index}: text=${s}`)}n.push(...r)}}catch{}if(n.length>0){let a=n.join(`
|
|
4105
4105
|
`);a+=`
|
|
4106
|
-
Use the exact text string in select_dropdown_option`,i.addNote(a)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};nd=fa.z.object({element_index:fa.z.number().int().describe("Index of the dropdown/select element")})});function Or(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:ad,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let l={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,l,o),{success:!0,actionEntity:l,message:"Navigated back"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:l.message}}}}})}var Cr,Nr,ad,Qt=x(()=>{"use strict";H();Cr=require("zod");I();Nr=class{async execute(e,t){await e.goBack({timeout:he}),await e.waitForLoadState("load",{timeout:he}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},ad=Cr.z.object({})});function Dr(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:od,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:l,agentServices:s,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let p=o?`Open ${a} in new tab`:`Navigate to ${a}`,h={action_description:c||p,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(l,h,s),{success:!0,actionEntity:h,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(p){let h=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:p.message,actionEntity:{action_description:(c||h)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:p.message}}}}})}var ei,wa,od,ti=x(()=>{"use strict";H();ei=require("zod");I();wa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let c=e.url(),d=null;try{let u=new URL(c);u.origin&&u.origin!=="null"&&(d=u.origin)}catch{}d&&(r=d+r)}let l=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:he,s=e;o&&(s=await e.context().newPage(),i.setPage(s)),await s.goto(r,{timeout:l})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},od=ei.z.object({url:ei.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:ei.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:ei.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});function Rr(e){if(!e.trim())return!1;try{return(0,Lr.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Lr,ln=x(()=>{"use strict";Lr=require("@babel/parser")});function Fr(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:rd,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Assertion verified: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:l.message}}}},availability:{openai:!0,mcp:!0}})}var ba,cn,rd,ii=x(()=>{"use strict";Et();ln();U();ba=require("zod"),cn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let d=Date.now();try{await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let p=((Date.now()-d)/1e3).toFixed(1);w.info(`[VERIFY:JS\u2192AI] JS failed ${p}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();w.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:l}=await Promise.resolve().then(()=>(Qe(),Ze)),s=await l(o,e,i,{useCleanScreenshotForAssertion:!0}),c=s.explanation||s.error||(s.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!s.success)throw w.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(s.error||s.explanation||"Assertion failed");w.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4106
|
+
Use the exact text string in select_dropdown_option`,i.addNote(a)}else i.addNote("No options found in any frame for dropdown")}transpile(e){let t=[];return e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...t.map(i=>` ${i},`),"});"]}};qc=ma.z.object({element_index:ma.z.number().int().describe("Index of the dropdown/select element")})});function $r(e,t){e.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Zc,async execute(i,n){let{page:a,agentServices:o,actionDescription:r}=n;try{let l={action_description:r||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await t.execute(a,l,o),{success:!0,actionEntity:l,message:"Navigated back"}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:(r||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:l.message}}}}})}var Tr,Ar,Zc,Yt=x(()=>{"use strict";H();Tr=require("zod");I();Ar=class{async execute(e,t){await e.goBack({timeout:he}),await e.waitForLoadState("load",{timeout:he}),await e.waitForTimeout(1e3)}transpile(e){return['await agent.execAction("go_back", page, {});']}},Zc=Tr.z.object({})});function Mr(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:Qc,async execute(i,n){let{url:a,new_tab:o,timeout_seconds:r}=i,{page:l,agentServices:s,actionDescription:c}=n,d={url:a,new_tab:o??!1};r!==void 0&&(d.timeout_seconds=r);let u=r?` (timeout: ${r}s)`:"";try{let m=o?`Open ${a} in new tab`:`Navigate to ${a}`,h={action_description:c||m,action_data:{action_name:"go_to_url",kwargs:d}};return await t.execute(l,h,s),{success:!0,actionEntity:h,message:(o?`Opened ${a} in new tab`:`Navigated to ${a}`)+u}}catch(m){let h=o?`Open ${a} in new tab`:`Navigate to ${a}`;return{success:!1,error:m.message,actionEntity:{action_description:(c||h)+" (failed)",action_data:{action_name:"go_to_url",kwargs:d},feedback:m.message}}}}})}var Jt,pa,Qc,qt=x(()=>{"use strict";H();Jt=require("zod");I();pa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.url;if(!a)throw new Error("Missing URL for go_to_url action");let o=n.kwargs.new_tab===!0,r=i.replaceVariables(String(a));if(r.startsWith("/")){let c=e.url(),d=null;try{let u=new URL(c);u.origin&&u.origin!=="null"&&(d=u.origin)}catch{}d&&(r=d+r)}let l=n.kwargs.timeout_seconds?n.kwargs.timeout_seconds*1e3:he,s=e;o&&(s=await e.context().newPage(),i.setPage(s)),await s.goto(r,{timeout:l})}transpile(e){let t=e.action_data?.kwargs?.url||"",i=e.action_data?.kwargs?.new_tab===!0,n=e.action_data?.kwargs?.timeout_seconds,a=[`url: ${JSON.stringify(t)}`];return i&&a.push("new_tab: true"),n&&a.push(`timeout_seconds: ${n}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${a.join(", ")} } },`,"});"]}},Qc=Jt.z.object({url:Jt.z.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Jt.z.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Jt.z.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")})});async function ed(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ir(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Pr(e,t){e.register({name:"hover",description:"Hover over an interactive element.",schema:td,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Ir(`Hover element ${a}`,"hover",{index:a})};let c=l||`Hover over element ${a}`,d=await ed("hover",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Hovered over element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Ir(`Hover element ${a}`,"hover",{index:a})}}}})}var rn,ga,td,Zt=x(()=>{"use strict";z();H();rn=require("zod");I();ga=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n){await n.waitFor({state:"attached",timeout:a});let o=await n.elementHandle();if(!o)throw new Error("Unable to obtain element handle for hover action");let r=await o.boundingBox();if(!r)throw new Error("Unable to determine bounding box for hover action");let l=r.x+r.width/2,s=r.y+r.height/2;await e.mouse.move(l,s)}else throw new Error("No locator found for hover action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...t.map(i=>` ${i},`),"});"]}};td=rn.z.object({element_index:rn.z.number().int().describe("Index of the element to hover over"),timeout_ms:rn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function id(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Cr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Nr(e,t){e.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:nd,usesElementIndex:!0,async execute(i,n){let{element_index:a,text:o}=i,{page:r,agentServices:l,actionDescription:s}=n;try{let c=await j(n,a);if(!c)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Cr(s||`Input text to element ${a}`,"input_text",{index:a,text:o})};let d=s||`Input text to element ${a}`,u=await id("input_text",d,c,r,{text:o});return await t.execute(r,u,l),{success:!0,actionEntity:u,message:`Input text to element ${a}`}}catch(c){return{success:!1,error:c.message,actionEntity:Cr(`Input text to element ${a}`,"input_text",{index:a,text:o})}}}})}var Qt,fa,nd,ei=x(()=>{"use strict";z();H();Qt=require("zod");I();fa=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.text??n.kwargs.value??"",o=i.replaceVariables(String(a)),r=O(e,t),l=P(i,t.action_data?.kwargs?.timeout_ms);if(r){await r.evaluate(c=>{c.value&&(c.value="")},null,{timeout:l}),await r.click({timeout:l}),await e.waitForTimeout(200);let s=i.getActionSettings().type_delay;s!==void 0?await e.keyboard.type(o,{delay:s}):await e.keyboard.type(o)}else throw new Error("No locator found for input_text action")}transpile(e){let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"",i=[];return i.push(`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("input_text", page, {',...i.map(n=>` ${n},`),"});"]}};nd=Qt.z.object({element_index:Qt.z.number().int().describe("Index of the input element"),text:Qt.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:Qt.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function ad(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Or(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Lr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:od,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Or(l||`Clear element ${a}`,"clear_input",{index:a})};let c=l||`Clear element ${a}`,d=await ad("clear_input",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Or(`Clear element ${a}`,"clear_input",{index:a})}}}})}var sn,Dr,od,ti=x(()=>{"use strict";z();H();sn=require("zod");I();Dr=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};od=sn.z.object({element_index:sn.z.number().int().describe("Index of the input element to clear"),timeout_ms:sn.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});async function rd(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Rr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Fr(e,t){e.register({name:"click",description:"Click an interactive element.",schema:sd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Rr(`Click element ${a}`,"click",{index:a})};let c=l||`Click element ${a}`,d=await rd("click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Rr(`Click element ${a}`,"click",{index:a})}}}})}var ln,cn,sd,ii=x(()=>{"use strict";z();H();ln=require("zod");I();cn=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Ie(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};sd=ln.z.object({element_index:ln.z.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:ln.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function Wr(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:ld,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Closed tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:s.message}}}}})}var wa,Hr,ld,ni=x(()=>{"use strict";wa=require("zod"),Hr=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} } },`,"});"]}},ld=wa.z.object({index:wa.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function Br(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:cd,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,Ur,cd,ai=x(()=>{"use strict";dn=require("zod"),Ur=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},cd=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 dd(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function jr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Gr(e,t){e.register({name:"double_click",description:"Double-click an interactive element.",schema:ud,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:jr(`Double-click element ${a}`,"double_click",{index:a})};let c=l||`Double-click element ${a}`,d=await dd("double_click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Double-clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:jr(`Double-click element ${a}`,"double_click",{index:a})}}}})}var un,ba,ud,oi=x(()=>{"use strict";z();H();un=require("zod");I();ba=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.dblclick({timeout:a});else throw new Error("No locator found for double_click action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...t.map(i=>` ${i},`),"});"]}};ud=un.z.object({element_index:un.z.number().int().describe("Index of the element to double-click"),timeout_ms:un.z.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")})});function zr(e){if(!e.trim())return!1;try{return(0,Kr.parse)(e,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var Kr,hn=x(()=>{"use strict";Kr=require("@babel/parser")});function Vr(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:hd,async execute(i,n){let{statement:a}=i,{page:o,agentServices:r}=n;try{let l={action_description:`${a}`,action_data:{action_name:"verify",kwargs:{statement:a}}};return await t.execute(o,l,r),{success:!0,actionEntity:l,message:`Assertion verified: ${a}`}}catch(l){return{success:!1,error:l.message,actionEntity:{action_description:`Verify: ${a} (failed)`,action_data:{action_name:"verify",kwargs:{statement:a}},feedback:l.message}}}},availability:{openai:!0,mcp:!0}})}var ya,mn,hd,ri=x(()=>{"use strict";Et();hn();U();ya=require("zod"),mn=class{async execute(e,t,i){let n=t.action_data?.kwargs,a=typeof n?.code=="string",o=a?n?.statement||t.action_description:t.action_description||n?.statement;if(a&&o){let d=Date.now();try{await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o}`),i.addNote(`Assertion passed: ${o}`);return}catch(u){let m=((Date.now()-d)/1e3).toFixed(1);w.info(`[VERIFY:JS\u2192AI] JS failed ${m}s (${u instanceof Error?u.message:String(u)}), falling back to AI: ${o}`)}}else if(a){let d=Date.now();await this.executeJSAssertion(e,n.code,i),w.info(`[VERIFY:JS] \u2713 ${((Date.now()-d)/1e3).toFixed(1)}s: ${o||"js-only"}`),i.addNote(`Assertion passed: ${o||"js-only"}`);return}if(!o)throw new Error("Missing statement or code for verify action");let r=Date.now();w.info(`[VERIFY:AI] Evaluating: ${o}`);let{evaluateStatement:l}=await Promise.resolve().then(()=>(Qe(),Ze)),s=await l(o,e,i,{useCleanScreenshotForAssertion:!0}),c=s.explanation||s.error||(s.success?`Assertion passed: ${o}`:"Assertion failed");if(i.addNote(c),!s.success)throw w.info(`[VERIFY:AI] \u2717 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`),new Error(s.error||s.explanation||"Assertion failed");w.info(`[VERIFY:AI] \u2713 ${((Date.now()-r)/1e3).toFixed(1)}s: ${o}`)}async executeJSAssertion(e,t,i){let n=i.agent;if(!n)throw new Error("Agent not initialized on AgentServices \u2014 ai_assert requires an agent reference");try{await new Function("page","expect","agent",`
|
|
4107
4107
|
return (async () => {
|
|
4108
4108
|
${t}
|
|
4109
4109
|
})();
|
|
4110
|
-
`)(e,qe.expect,n)}catch(a){throw new Error(`Assertion failed: ${a instanceof Error?a.message:String(a)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(n){let r=i.code;if(!
|
|
4110
|
+
`)(e,qe.expect,n)}catch(a){throw new Error(`Assertion failed: ${a instanceof Error?a.message:String(a)}`)}}transpile(e,t){let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement,o=JSON.stringify(t||"");if(n){let r=i.code;if(!zr(r))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(r)});`];if(a){let l=r.split(`
|
|
4111
4111
|
`),s=JSON.stringify(a);return["{ const _t = Date.now(); try {",...l.map(c=>` ${c}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${s}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${s}\`);`,` await agent.assert(page, ${s}, ${o});`,"} }"]}return r.split(`
|
|
4112
|
-
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},rd=ba.z.object({statement:ba.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function Wr(e,t){e.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:sd,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Extracted ${a} to ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:s.message}}}},availability:{openai:!1,mcp:!0}})}var dn,Hr,sd,ni=x(()=>{"use strict";dn=require("zod"),Hr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:l}=await Promise.resolve().then(()=>(Qe(),Ze)),s=await l(r,e,i);if(s.status!=="success")throw new Error(s.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},sd=dn.z.object({element_description:dn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:dn.z.string().describe("Name of the variable to store the extracted value")})});async function ld(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Ur(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 jr(e,t){e.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:cd,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Input element with index ${a} not found`,actionEntity:Ur(l||`Clear element ${a}`,"clear_input",{index:a})};let c=l||`Clear element ${a}`,d=await ld("clear_input",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Cleared element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Ur(`Clear element ${a}`,"clear_input",{index:a})}}}})}var un,Br,cd,ai=x(()=>{"use strict";z();H();un=require("zod");I();Br=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a}),await e.keyboard.press("ControlOrMeta+a"),await e.waitForTimeout(200),await e.keyboard.press("Backspace"),await e.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(e){let t=[];return e.locator?t.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&t.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&t.push(`frame_path: ${JSON.stringify(e.frame_path)}`),t.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...t.map(i=>` ${i},`),"});"]}};cd=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 dd(e,t,i,n,a={}){return{...await F(n,i),action_description:t,action_data:{action_name:e,kwargs:{...a}}}}function Gr(e,t,i){return{action_description:`${e} (failed - element not found)`,action_data:{action_name:t,kwargs:i},feedback:"Element not found in DOM"}}function Kr(e,t){e.register({name:"click",description:"Click an interactive element.",schema:ud,usesElementIndex:!0,async execute(i,n){let{element_index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s=await j(n,a);if(!s)return{success:!1,error:`Element with index ${a} not found.`,actionEntity:Gr(`Click element ${a}`,"click",{index:a})};let c=l||`Click element ${a}`,d=await dd("click",c,s,o);return await t.execute(o,d,r),{success:!0,actionEntity:d,message:`Clicked element ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:Gr(`Click element ${a}`,"click",{index:a})}}}})}var hn,mn,ud,oi=x(()=>{"use strict";z();H();hn=require("zod");I();mn=class{async execute(e,t,i){let n=O(e,t),a=P(i,t.action_data?.kwargs?.timeout_ms);if(n)await n.click({timeout:a});else throw new Error("No locator found for click action")}transpile(e){let t=Ie(e);if(!t)return['await agent.execAction("click", page, {});'];let i=P();return[`await ${t}.click({ timeout: ${i} });`]}};ud=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.")})});function Vr(e,t){e.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:hd,async execute(i,n){let{index:a}=i,{page:o,agentServices:r,actionDescription:l}=n;try{let s={action_description:l||`Close tab ${a}`,action_data:{action_name:"close_tab",kwargs:{page_id:a}}};return await t.execute(o,s,r),{success:!0,actionEntity:s,message:`Closed tab ${a}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:(l||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:s.message}}}}})}var ya,zr,hd,ri=x(()=>{"use strict";ya=require("zod"),zr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.page_id??n.kwargs.index;if(a===void 0&&(a=e.context().pages().indexOf(e)),typeof a=="number"){if(a===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");i&&await i.closeTab(a)}else throw new Error("Missing page_id for close_tab action")}transpile(e){let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]}},hd=ya.z.object({index:ya.z.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")})});function Yr(e,t){e.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:md,async execute(i,n){let{page:a,agentServices:o}=n;try{let r={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await t.execute(a,r,o),{success:!0,actionEntity:r,message:"Task marked as complete"}}catch(r){return{success:!1,error:r.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:r.message}}}}})}var pn,Xr,md,si=x(()=>{"use strict";pn=require("zod"),Xr=class{async execute(e,t){}transpile(e){return["// Done - no action needed"]}},md=pn.z.object({success:pn.z.boolean().describe("Whether the task was completed successfully"),summary:pn.z.string().describe("Summary of what was accomplished or why it failed")})});var pd,gd,He,gn=x(()=>{"use strict";pd=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],gd=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],He=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:pd.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:!gd.includes(t)}}});var xa,va,_a,ka=x(()=>{"use strict";Hi();Wi();Ui();Bi();ji();Gi();Ki();zi();Zi();Qi();en();Mt();Pt();Ct();Nt();Ot();Dt();Rt();Ft();Ht();Ut();jt();Gt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ii();ni();ai();oi();ri();si();gn();H();be();xa=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new wa),T.registerAction("go_back",new Nr),T.registerAction("reload_page",new vr),T.registerAction("close_tab",new zr),T.registerAction("switch_tab",new jo),T.registerAction("click",new mn),T.registerAction("hover",new ca),T.registerAction("right_click",new ma),T.registerAction("double_click",new pa),T.registerAction("click_by_coordinates",new Uo),T.registerAction("right_click_by_coordinates",new Po),T.registerAction("double_click_by_coordinates",new Lo),T.registerAction("drag_drop",new Ro),T.registerAction("input_text",new da),T.registerAction("clear_input",new Br),T.registerAction("press",new ha),T.registerAction("send_keys_on_element",new Co),T.registerAction("scroll_on_element",new rr),T.registerAction("scroll_to_text",new lr),T.registerAction("scroll",new Lt),T.registerAction("upload_file",new Xo),T.registerAction("wait_for_download_complete",new Zo),T.registerAction("get_dropdown_options",new Ir),T.registerAction("select_dropdown_option",new ur),T.registerAction("set_date_for_native_date_picker",new mr),T.registerAction("verify",new cn),T.registerAction("ai_action",new Bo),T.registerAction("ai_extract",new Hr),T.registerAction("ai_step",new Wo),T.registerAction("ai_wait_until",new er),T.registerAction("generate_2fa_code",new Ar),T.registerAction("wait",new Jo),T.registerAction("wait_for_page_ready",new Io),T.registerAction("save_variable",new ir),T.registerAction("js_code",new Do),T.registerAction("js_action",new No),T.registerAction("function",new Fo),T.registerAction("done",new Xr),T.registerAction("click_element",new mn),T.registerAction("click_element_by_index",new mn),T.registerAction("hover_element_by_index",new ca),T.registerAction("right_click_on_element",new ma),T.registerAction("double_click_on_element",new pa),T.registerAction("scroll_down",new Lt),T.registerAction("scroll_up",new Lt),T.registerAction("scroll_element",new Lt),T.registerAction("send_keys",new ha),T.registerAction("open_tab",new wa),T.registerAction("fill",new da),T.registerAction("ai_assert",new cn),T.registerAction("assert",new cn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(I(),Fn(vi)),o=t.action_description||"",r=t.action_data?.action_name||"",l=this.getAction(r);if(!l)return[`// ${i}: Unknown action: ${r}`];let s=l.transpile(t,i);if(He.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...s];let c=JSON.stringify(o),d=s.map(h=>` ${h}`),u=He.canSelfHeal(t),p=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${p}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Fn(vi));if(!t)return[`// ${i}: Skipping - no description`];let l=JSON.stringify(t);if(a){let s=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${l}, '${i}'${s});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${l}, '${i}', ${n});`]}};xa.actions=new Map,xa.initialized=!1;va=xa,_a=va});var fn={};Ge(fn,{ActionHandler:()=>va,default:()=>_a});var wn=x(()=>{"use strict";ka();Hi();Wi();Ui();Bi();ji();Gi();Ki();zi();Zi();Qi();en();Mt();Pt();Ct();Nt();Ot();Dt();Rt();Ft();Ht();Ut();jt();Gt();zt();Vt();Xt();Yt();Jt();qt();Zt();Qt();ti();ii();Et();ni();ai();oi();ri();si();ln();It();z();Le();U();ie();Tt();gn();H();be()});function bn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4113
|
-
${e.stepHistory.slice(-3).map(s=>{let c=`${s.outcome.success?"\u2713":"\u2717"} Step ${s.stepNumber}: ${s.goal}`;if(s.actions.length>1)s.actions.forEach((d,u)=>{let
|
|
4114
|
-
\u2192 Action ${u+1}: ${
|
|
4112
|
+
`)}return a?[`await agent.assert(page, ${JSON.stringify(a)}, ${o});`]:["// Skipping verify: missing statement or code"]}},hd=ya.z.object({statement:ya.z.string().describe('The nature language statement to verify (e.g., "The login was successful")')})});function Yr(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:md,async execute(i,n){let{element_description:a,variable_name:o}=i,{page:r,agentServices:l}=n;try{let s={action_description:`Extract ${a} to ${o}`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}}};return await t.execute(r,s,l),{success:!0,actionEntity:s,message:`Extracted ${a} to ${o}`}}catch(s){return{success:!1,error:s.message,actionEntity:{action_description:`Extract ${a} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:a,variable_name:o}},feedback:s.message}}}},availability:{openai:!1,mcp:!0}})}var pn,Xr,md,si=x(()=>{"use strict";pn=require("zod"),Xr=class{async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=n.kwargs.element_description,o=n.kwargs.variable_name;if(!a||!o)throw new Error("Missing element_description or variable_name for ai_extract");let r=`Extract ${a} and save to ${o}`,{executeStep:l}=await Promise.resolve().then(()=>(Qe(),Ze)),s=await l(r,e,i);if(s.status!=="success")throw new Error(s.error||"Extraction failed")}transpile(e,t){let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]}},md=pn.z.object({element_description:pn.z.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:pn.z.string().describe("Name of the variable to store the extracted value")})});var pd,gd,He,gn=x(()=>{"use strict";pd=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],gd=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],He=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:pd.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:!gd.includes(t)}}});var xa,va,_a,ka=x(()=>{"use strict";Hi();Wi();Ui();Bi();ji();Gi();Ki();zi();Vi();Qi();en();Mt();It();Pt();Ct();Ot();Lt();Rt();Ht();Wt();Ut();Bt();jt();Gt();zt();Vt();Xt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();si();gn();H();be();xa=class T{static registerAction(t,i){T.actions.set(t,i)}constructor(){T.initialized||(this.registerBuiltinActions(),T.initialized=!0)}registerBuiltinActions(){T.registerAction("go_to_url",new pa),T.registerAction("go_back",new Ar),T.registerAction("reload_page",new pr),T.registerAction("close_tab",new Hr),T.registerAction("switch_tab",new nr),T.registerAction("click",new cn),T.registerAction("hover",new ga),T.registerAction("right_click",new ua),T.registerAction("double_click",new ba),T.registerAction("click_by_coordinates",new Ro),T.registerAction("right_click_by_coordinates",new Oo),T.registerAction("double_click_by_coordinates",new Fo),T.registerAction("drag_drop",new Ho),T.registerAction("input_text",new fa),T.registerAction("clear_input",new Dr),T.registerAction("press",new da),T.registerAction("send_keys_on_element",new Po),T.registerAction("scroll_on_element",new Xo),T.registerAction("scroll_to_text",new Jo),T.registerAction("scroll",new Kt),T.registerAction("upload_file",new lr),T.registerAction("wait_for_download_complete",new jo),T.registerAction("get_dropdown_options",new Sr),T.registerAction("select_dropdown_option",new Qo),T.registerAction("set_date_for_native_date_picker",new tr),T.registerAction("verify",new mn),T.registerAction("ai_action",new Uo),T.registerAction("ai_extract",new Xr),T.registerAction("ai_step",new Bo),T.registerAction("ai_wait_until",new Ko),T.registerAction("generate_2fa_code",new vr),T.registerAction("wait",new dr),T.registerAction("wait_for_page_ready",new Io),T.registerAction("save_variable",new br),T.registerAction("js_code",new No),T.registerAction("js_action",new Lo),T.registerAction("function",new Do),T.registerAction("done",new Ur),T.registerAction("click_element",new cn),T.registerAction("click_element_by_index",new cn),T.registerAction("hover_element_by_index",new ga),T.registerAction("right_click_on_element",new ua),T.registerAction("double_click_on_element",new ba),T.registerAction("scroll_down",new Kt),T.registerAction("scroll_up",new Kt),T.registerAction("scroll_element",new Kt),T.registerAction("send_keys",new da),T.registerAction("open_tab",new pa),T.registerAction("fill",new fa),T.registerAction("ai_assert",new mn),T.registerAction("assert",new mn)}getAction(t){return T.actions.get(t)}hasAction(t){return T.actions.has(t)}getActionNames(){return Array.from(T.actions.keys())}async execute(t,i,n){if(!n)throw new Error("AgentServices not found");let a=i.action_data?.action_name;if(!a)throw new Error("Action name not found in action_data");let o=this.getAction(a);if(!o)throw new Error(`Unknown action: ${a}`);await o.execute(t,i,n)}transpile(t,i,n){let{sanitizeForComment:a}=(I(),Fn(vi)),o=t.action_description||"",r=t.action_data?.action_name||"",l=this.getAction(r);if(!l)return[`// ${i}: Unknown action: ${r}`];let s=l.transpile(t,i);if(He.isAiAction(t))return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);",...s];let c=JSON.stringify(o),d=s.map(h=>` ${h}`),u=He.canSelfHeal(t),m=n?JSON.stringify(n):"undefined";return[`// ${i}: ${a(o)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...d,`}, ${c}, '${i}', ${m}, ${u});`]}transpileUncachedAction(t,i,n=!1,a=!1,o){let{sanitizeForComment:r}=(I(),Fn(vi));if(!t)return[`// ${i}: Skipping - no description`];let l=JSON.stringify(t);if(a){let s=o?`, { stmtUid: ${JSON.stringify(o)} }`:"";return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${l}, '${i}'${s});`]}return[`// ${i}: ${r(t)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${l}, '${i}', ${n});`]}};xa.actions=new Map,xa.initialized=!1;va=xa,_a=va});var fn={};Ge(fn,{ActionHandler:()=>va,default:()=>_a});var wn=x(()=>{"use strict";ka();Hi();Wi();Ui();Bi();ji();Gi();Ki();zi();Vi();Qi();en();Mt();It();Pt();Ct();Ot();Lt();Rt();Ht();Wt();Ut();Bt();jt();Gt();zt();Vt();Xt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();Et();si();hn();Ft();z();Le();U();ie();Tt();gn();H();be()});function bn(e,t,i){let n=()=>e.stepHistory.length===0?"":`**Recent Steps**:
|
|
4113
|
+
${e.stepHistory.slice(-3).map(s=>{let c=`${s.outcome.success?"\u2713":"\u2717"} Step ${s.stepNumber}: ${s.goal}`;if(s.actions.length>1)s.actions.forEach((d,u)=>{let m=d.action_description||"Unknown action";c+=`
|
|
4114
|
+
\u2192 Action ${u+1}: ${m}`});else if(s.actions.length===1){let d=s.actions[0]?.action_description||"Unknown action";c+=`
|
|
4115
4115
|
\u2192 ${d}`}if(!s.outcome.success&&s.outcome.error){let d=s.outcome.error.substring(0,100);c+=`
|
|
4116
4116
|
Error: ${d}${s.outcome.error.length>100?"...":""}`}return s.evaluation&&(c+=`
|
|
4117
4117
|
Eval: ${s.evaluation}`),c}).join(`
|
|
@@ -4161,7 +4161,7 @@ This is your last step. You MUST use the "done" action now.
|
|
|
4161
4161
|
`:"",c=i?` "thinking": "<your internal reasoning about current state and next action>", // Optional
|
|
4162
4162
|
`:"",d=a?` "evaluation_previous_goal": "success: <reason>" | "partial: <reason>" | "failure: <reason>" | "", // Empty on first step
|
|
4163
4163
|
`:"",u=n?` "memory": "<important facts to remember>", // Update only when learning something new
|
|
4164
|
-
`:"",
|
|
4164
|
+
`:"",m=o?` "actions": [ // Can be single action or multiple actions in sequence
|
|
4165
4165
|
{
|
|
4166
4166
|
"description": "<human readable description WITHOUT element index, e.g. 'Click the Submit button'>",
|
|
4167
4167
|
"action_name": "<name of action to execute>",
|
|
@@ -4264,7 +4264,7 @@ You must ALWAYS respond with a valid JSON in this exact format:
|
|
|
4264
4264
|
\`\`\`json
|
|
4265
4265
|
{
|
|
4266
4266
|
${c}${d}${u} "current_goal": "State the current goal. Include only what to achieve, not how to achieve it.",
|
|
4267
|
-
${
|
|
4267
|
+
${m}
|
|
4268
4268
|
"completes_instruction": true | false // Is the entire task complete?
|
|
4269
4269
|
}
|
|
4270
4270
|
\`\`\`
|
|
@@ -4282,7 +4282,7 @@ ${p}
|
|
|
4282
4282
|
**Current Goal Examples:**
|
|
4283
4283
|
- "Add the product to the cart"
|
|
4284
4284
|
- "Find more product listings and extract details from the next 5 items on the page"
|
|
4285
|
-
${h}`.trim()}var tt,xn=x(()=>{"use strict";ke();tt=require("zod")});var vn,Sa=x(()=>{"use strict";xn();ne();vn=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:l,sensitiveKeys:s,isFinalStep:c,finalStepWarning:d}=o,u=[],
|
|
4285
|
+
${h}`.trim()}var tt,xn=x(()=>{"use strict";ke();tt=require("zod")});var vn,Sa=x(()=>{"use strict";xn();ne();vn=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:l,sensitiveKeys:s,isFinalStep:c,finalStepWarning:d}=o,u=[],m=bn(a,e,t);if(u.push({type:"text",text:m}),u.push({type:"text",text:`## CURRENT PAGE STATE
|
|
4286
4286
|
|
|
4287
4287
|
**Interactive Elements**:
|
|
4288
4288
|
${i}`}),r&&Array.isArray(r)&&r.length>0){let h=r.map(([g,f],b)=>`${b+1}. ${g} \u2192 ${f}`);u.push({type:"text",text:`## EXECUTION HISTORY (from test)
|
|
@@ -4298,19 +4298,19 @@ ${h.join(`
|
|
|
4298
4298
|
`,n+=`- Use the EXACT placeholder name as shown above
|
|
4299
4299
|
`,n+=`- Do NOT use the actual value directly in the action
|
|
4300
4300
|
`,n+=`- The values shown are for context only to help you understand what data is available
|
|
4301
|
-
`,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var li=x(()=>{"use strict"});async function vd(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],l=u=>{let p=u.toLowerCase();return p.startsWith("data:")||p.startsWith("blob:")?!0:r.some(h=>p.includes(h))},s=u=>{let p=u.resourceType(),h=u.url();if(!a.has(p)||l(h))return;let g=u.headers();g.purpose==="prefetch"||["video","audio"].includes(g["sec-fetch-dest"])||(i.add(u),n=Date.now())},c=async u=>{let p=u.request();if(!i.has(p))return;let h=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(f=>h.includes(f))){i.delete(p);return}if(![...o].some(f=>h.startsWith(f))){i.delete(p);return}let g=u.headers()["content-length"];if(g)try{if(parseInt(g,10)>5*1024*1024){i.delete(p);return}}catch{}i.delete(p),n=Date.now()},d=Date.now()-xd;for(let u of await e.requests()){let p=u.resourceType(),h=u.url(),g=u.timing();a.has(p)&&!l(h)&&g.responseEnd===-1&&g.startTime>=d&&(i.add(u),n=Date.now())}w.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",s),e.on("response",c);try{let u=Date.now(),p=yd;for(;;){await new Promise(g=>setTimeout(g,100));let h=Date.now();if(i.size===0&&h-n>=p){w.debug(`[waitForStableNetwork] Network idle after ${h-u}ms`);break}if(h-u>t){w.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",s),e.removeListener("response",c)}}async function it(e,t=bd,i=wd){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),vd(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 wd,bd,yd,xd,Ce=x(()=>{"use strict";li();U();wd=.5*1e3,bd=30*1e3,yd=1*1e3,xd=3*1e3});function _d(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 es(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),l=t.domService||new Pe(t.agentServices.getDomServiceOptions()),s={...t,domService:l};S.init(),S.section("Task Execution Started"),S.log(`Task: ${e}`),S.log(`Max steps: ${a}`),S.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],u=yn(i.customPrompt),p=new vn(u);S.log(`System prompt length: ${u.length} chars`);let h=!1,g="",f=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();S.section(`Step ${c.currentStep}/${a}`),S.log(`URL: ${s.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{S.log("Waiting for page to stabilize..."),await it(s.page),S.log("Page stabilized")}catch{S.log("Page stabilization timed out, continuing anyway")}let m;try{S.log("Preparing context (DOM + screenshot)...");let R=s.agentServices.getInteractiveClassNames(),W=s.agentServices.getIframeFallbackDomains();m=await Zr(s.page,s.domService,R,W),S.log("Context prepared")}catch(R){if(R.message.includes("Execution context was destroyed")){S.log("Page navigating, waiting for load..."),await it(s.page);let W=s.agentServices.getInteractiveClassNames(),D=s.agentServices.getIframeFallbackDomains();m=await Zr(s.page,s.domService,W,D)}else throw S.error("Error preparing context",R),R}p.addStateMessage(e,m.currentUrl,m.domTree,m.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let y=await Sd(p,r,i,m.screenshotBase64);if(y.tokenUsages&&y.tokenUsages.length>0&&d.push(...y.tokenUsages),!y.stepOutput){if(S.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){g="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let v=y.stepOutput;$d(c.currentStep,a,v);let E=await Td(v,s,m.domState,c.currentStep,i.onEvent,m.screenshotBase64,y.debugInfo);f.push(...E.actionEntities);let A=Ad(c.currentStep,v,E,c,b,y.debugInfo,y.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){S.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),g=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){h=E.doneResult.success,g=E.doneResult.summary;break}if(E.completesInstruction){h=!0,g="Instruction completed";break}}return c.currentStep>=a&&!h&&(g="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),S.log(`Build success result: summary=${g}, completed=${h}, actions=${f.length}, tokens=${d.length}`),Md(c,f,h,g,n,d,r)}catch(b){let m=b.message;return S.error(`Task execution failed: ${m}`,b),i.onEvent?.({type:"error",error:m,recoverable:!1}),Id(c,m,n,d,r)}}async function Zr(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function kd(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 Sd(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),l=0;for(let u of r)Array.isArray(u.content)&&(l+=u.content.filter(p=>p.type==="image").length);let s=ve(t,l),c={model:xe(t),system:o,messages:r,temperature:a,providerOptions:s},d=3;for(let u=0;u<d;u++)try{let p=Date.now();S.log(`Calling LLM (${t})...`);let h=await(0,Qr.generateText)(c),g=Date.now()-p,f=h,b=f.usage;S.llmCall(t,g,b);let m=f.reasoningText;m&&(S.thinking(m),i.onEvent?.({type:"thinking",text:m})),e.addAssistantMessage(h.text);let y={systemPrompt:o,userPrompt:kd(r),rawLlmResponse:h.text,reasoningContent:m,screenshotWithSom:n},v=[],E=_d(b,t);E&&v.push(E);let A=Ed(h.text);if(!A)if(u<d-1){S.log(`Attempt ${u+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(M=>setTimeout(M,i.retryDelay||1e3));continue}else return S.error("All parsing attempts failed"),{stepOutput:null,debugInfo:y,tokenUsages:v};return{stepOutput:A,debugInfo:y,tokenUsages:v}}catch(p){if(u<d-1){S.log(`Attempt ${u+1}/${d}: LLM call failed (${p.message}), retrying...`),await new Promise(h=>setTimeout(h,i.retryDelay||1e3));continue}else throw S.error("All LLM call attempts failed",p),p}return{stepOutput:null}}function Ed(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 S.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return S.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return S.error("Action missing required field: action_name"),null;if(!n.description)return S.error("Action missing required field: description"),null}return i}catch(i){return S.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),S.error(`Parse error: ${i.message}`),null}}async function Td(e,t,i,n,a,o,r){let l=[],s=!0,c=null;S.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,u={...t,domState:i},p=o;for(let h of e.actions){if(h.action_name==="done"){d={success:h.kwargs.success??!0,summary:h.kwargs.summary||h.kwargs.text||"Task completed"};break}let g={},f=h.kwargs?.element_index??h.kwargs?.index;if(typeof f=="number"){let m=i.selectorMap.get(f);m&&(g=await F(t.page,m))}let b={...g,action_description:h.description,action_data:{action_name:h.action_name,kwargs:h.kwargs}};try{let m=await B.execute(h.action_name,h.kwargs,u);h.action_name==="perform_accurate_operation"&&(b=m.actionEntity);let y=await u.agentServices.getCurrentPage();if(y&&(u.page=y,t.page=u.page),m?.success===!1){s=!1,S.log("Action failed, stopping execution of remaining actions in this step"),c=m.error||"Action execution failed";break}l.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(m){s=!1,c=m.message,S.error(`Action execution failed: ${m.message}`);break}}return{allSuccess:s,failReason:c,actionEntities:l,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Ad(e,t,i,n,a,o,r){let l={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let s=t.memory.trim();n.memory.includes(s)||(n.memory.push(s),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(l),l}function $d(e,t,i){if(S.log(`Step ${e}/${t}`),i.thinking&&S.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&S.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&S.log(`Memory: ${i.memory}`),S.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];S.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else S.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{S.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Md(e,t,i,n,a,o,r){let l=o.reduce((d,u)=>d+u.prompt_tokens,0),s=o.reduce((d,u)=>d+u.completion_tokens,0),c=o.reduce((d,u)=>d+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-a,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:l,completionTokens:s,totalTokens:c,tokenUsages:o}}}function Id(e,t,i,n,a){let o=n.reduce((s,c)=>s+c.prompt_tokens,0),r=n.reduce((s,c)=>s+c.completion_tokens,0),l=n.reduce((s,c)=>s+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:a,successfulSteps:e.stepHistory.filter(s=>s.outcome.success).length,failedSteps:e.stepHistory.filter(s=>!s.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:l,tokenUsages:n}}}var Qr,ts=x(()=>{"use strict";Sa();xn();ke();Fe();ne();Ce();_e();z();Qr=require("ai")});var is={};Ge(is,{TaskMessageManager:()=>vn,formatFinalStepWarning:()=>Jr,formatTaskContext:()=>bn,getBrowserTaskJSONPrompt:()=>yn,runTaskLoop:()=>es});var ns=x(()=>{"use strict";ts();Sa();xn();ke();Vi();Fe();xt();vt();Je();_t();kt();ne();Ce();li();_e();mt();ze();pt();Re();z();Le();U();ie();Tt();H();be()});async function At(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(B.has(i)){let a=await B.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 Pd()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Pd(){if(_n)return _n;let e=await Promise.resolve().then(()=>(wn(),fn));return _n=new e.default,_n}async function Xi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Yn(r,o,n);return l.status==="error"?{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error,debugInfo:l.debugInfo}:{status:"success",completed:l.goalAccomplished||!1,actionEntities:l.actionEntity?[l.actionEntity]:[],explanation:l.reasoning,debugInfo:l.debugInfo}}async function Yi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Yn(r,o,n);if(l.status==="error"||!l.actionEntity)return{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error||"No action generated",debugInfo:l.debugInfo};let{actionEntity:s,reasoning:c,goalAccomplished:d,debugInfo:u}=l,p=await At(s,o);return p.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[s],explanation:c,debugInfo:u}):{status:"error",completed:!1,actionEntities:[s],error:p.error||"Action execution failed",debugInfo:u}}async function Ji(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),vo(o,a,n)}async function qi(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(ns(),is)),r=n?s=>{n(s)}:void 0,l=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:l.success?"success":"error",completed:l.completed,actionEntities:l.trajectory.actions,explanation:l.summary,error:l.error,tokenUsages:l.metadata.tokenUsages}}var _n,$t=x(()=>{"use strict";Ri();ke();Fe();_n=null});var fx,_,yx,Ax,Ix,_s,mx,ks,Fd,Hd,Sn,px,gx,Ss,Es,Wd,vs,Ud,ci,Bd,jd,Gd,re,Kd,zd,bx,Mx,di=x(()=>{"use strict";be();fx=require("uuid"),_=require("zod"),yx=require("yaml"),Ax=require("uuid"),Ix=require("yaml"),_s=112,mx=1080-_s,ks=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ks||{}),Fd={"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"}},Hd={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"]},Sn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Hd[e].map(n=>Fd[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},px={desktop:{label:"Desktop",type:"desktop",devices:Sn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Sn("mobile")}},gx={desktop:{label:"Desktop",type:"desktop",devices:Sn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Sn("mobile",!0)}},Ss=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ss||{}),Es=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Es||{}),Wd=_.z.enum(["JS_CODE","AI_MODE"]),vs=_.z.object({type:Wd,expression:_.z.string()}),Ud=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ci=_.z.object({uid:_.z.string(),type:Ud,comment:_.z.string().optional()}),Bd=_.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(),jd=ci.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),Gd=ci.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:Bd.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),re=_.z.lazy(()=>_.z.union([jd,Gd,ci.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(re),reference_id:_.z.number().optional(),template_path:_.z.string().optional(),template_params:_.z.record(_.z.string()).optional()}),ci.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:vs,then:_.z.array(re),else:_.z.array(re).optional()}),ci.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:vs,body:_.z.array(re),timeout_ms:_.z.number().optional()})])),Kd=_.z.object({name:_.z.string(),statements:_.z.array(re),teardown:_.z.array(re).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()}),zd=_.z.object({tests:_.z.array(Kd).min(1),beforeAll:_.z.array(re).optional(),afterAll:_.z.array(re).optional(),beforeEach:_.z.array(re).optional(),afterEach:_.z.array(re).optional()}),bx=_.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(re).optional(),teardown:_.z.array(re).optional(),last_modified_at:_.z.string().optional(),testGroup:zd.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),Mx=1024*1024});var $a=x(()=>{"use strict";ne();Ce()});var Cs=x(()=>{"use strict"});var Ns=x(()=>{"use strict"});var Os=x(()=>{"use strict"});var nu,Ds=x(()=>{"use strict";nu=require("uuid")});var k,Ls,Ia,Rs,at,Fs,Hs,Ws,ae,Us,En,Pa,Ca=x(()=>{"use strict";k=require("zod"),Ls=k.z.enum(["JS_CODE","AI_MODE"]),Ia=k.z.object({type:Ls,expression:k.z.string()}),Rs=k.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),at=k.z.object({uid:k.z.string(),type:Rs,comment:k.z.string().optional()}),Fs=k.z.object({action_data:k.z.object({action_name:k.z.string(),kwargs:k.z.record(k.z.any()).optional(),args:k.z.array(k.z.any()).optional()}),action_description:k.z.string().optional(),url:k.z.string().optional(),xpath:k.z.string().nullable().optional(),locator:k.z.string().nullable().optional(),css_selector:k.z.string().nullable().optional(),unique_selector:k.z.string().nullable().optional(),element_index:k.z.number().nullable().optional(),frame_path:k.z.array(k.z.any()).optional(),artifacts:k.z.record(k.z.any()).optional(),feedback:k.z.string().optional(),original_browser_use_action:k.z.any().optional()}).passthrough(),Hs=at.extend({type:k.z.literal("DRAFT"),description:k.z.string()}),Ws=at.extend({type:k.z.literal("ACTION"),description:k.z.string(),action_entity:Fs.optional(),locator:k.z.string().optional(),use_pure_vision:k.z.boolean().optional()}),ae=k.z.lazy(()=>k.z.union([Hs,Ws,at.extend({type:k.z.literal("STEP"),description:k.z.string().optional().default(""),statements:k.z.array(ae),reference_id:k.z.number().optional(),template_path:k.z.string().optional(),template_params:k.z.record(k.z.string()).optional()}),at.extend({type:k.z.literal("IF_ELSE"),description:k.z.string().optional(),condition:Ia,then:k.z.array(ae),else:k.z.array(ae).optional()}),at.extend({type:k.z.literal("WHILE_LOOP"),description:k.z.string().optional(),condition:Ia,body:k.z.array(ae),timeout_ms:k.z.number().optional()})])),Us=k.z.object({name:k.z.string(),statements:k.z.array(ae),teardown:k.z.array(ae).optional(),skip:k.z.union([k.z.boolean(),k.z.string()]).optional(),timeout:k.z.number().optional(),fail:k.z.union([k.z.boolean(),k.z.string()]).optional(),only:k.z.boolean().optional(),slow:k.z.boolean().optional()}),En=k.z.object({tests:k.z.array(Us).min(1),beforeAll:k.z.array(ae).optional(),afterAll:k.z.array(ae).optional(),beforeEach:k.z.array(ae).optional(),afterEach:k.z.array(ae).optional()}),Pa=k.z.object({comment:k.z.string().optional(),version:k.z.string().optional(),goal:k.z.string().optional(),url:k.z.string().optional(),baseURL:k.z.string().optional(),final_feedback:k.z.string().optional(),completed:k.z.boolean().optional(),success:k.z.boolean().optional(),statements:k.z.array(ae).optional(),teardown:k.z.array(ae).optional(),last_modified_at:k.z.string().optional(),testGroup:En.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 Tn(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,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},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 An(e,t){if(e.testGroup)return zs(e,t);let i=Tn(e,t),n=new L.Document(i);return e.comment&&(n.commentBefore=e.comment),Bs(n,e.statements??[]),e.teardown&&Bs(n,e.teardown,"teardown"),n.toString(Ks)}function Bs(e,t,i="statements"){let n=e.contents;if(!n||!(0,L.isMap)(n))return;let a=n.get(i,!0);(0,L.isSeq)(a)&&hi(a,t)}function hi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),(0,L.isMap)(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);(0,L.isSeq)(r)&&hi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);(0,L.isSeq)(r)&&hi(r,n.then);let l=o.get("ELSE",!0);(0,L.isSeq)(l)&&n.else&&hi(l,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);(0,L.isSeq)(r)&&hi(r,n.body)}}}}function zs(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(le)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(le)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(le),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(le)),r}),n.suite=a,(0,L.stringify)(n,Ks)}function le(e){switch(e.type){case"DRAFT":return au(e);case"ACTION":return ou(e);case"STEP":return ru(e);case"IF_ELSE":return su(e);case"WHILE_LOOP":return lu(e)}}function au(e){return{intent:e.description}}function ou(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let l=i?.statement;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s=i?.code;return typeof s=="string"?{VERIFY:l,js:s}:{VERIFY:l}}}if(t==="go_to_url"){let l=i?.url;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s={URL:l};return i?.new_tab===!0&&(s.new_tab=!0),typeof i?.timeout_seconds=="number"&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="js_action"){let l=i?.code;if(typeof l=="string"&&e.description)return{intent:e.description,js:l}}if(t==="ai_wait_until"){let l=i?.condition;if(typeof l=="string"){let s={WAIT_UNTIL:l};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="wait"){let l=i?.seconds,c={WAIT:e.description||`Wait ${l}s`};return typeof l=="number"&&(c.seconds=l),c}if(t==="js_code"){let l=i?.code;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:l}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[l,s]of Object.entries(n.kwargs))a[l]=s;return n.args&&n.args.length>0&&(a.args=n.args),a}function ru(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function su(e){let t={IF:Vs(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function lu(e){let t={WHILE:Vs(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function Vs(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Oa(e){try{let t=(0,L.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()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),i}catch{return{}}}function Na(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Na);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]=Na(o);return n}function Te(e){if(e.length>js)throw new Error(`YAML input too large (${e.length} bytes, max ${js})`);let t=Na((0,L.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return cu(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=Pa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return $n(e,a),a}function cu(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let a={tests:i.map(l=>{if(!l.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(l.statements)||l.statements.length===0)throw new Error(`Suite test "${l.name}" must have a non-empty "statements" array`);let s={name:l.name,statements:ce(l.statements)};return Array.isArray(l.teardown)&&l.teardown.length>0&&(s.teardown=ce(l.teardown)),l.skip!==void 0&&(s.skip=l.skip),typeof l.timeout=="number"&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only===!0&&(s.only=!0),l.slow===!0&&(s.slow=!0),s})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ce(t.afterEach));let o=En.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(du)}function du(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 uu(t);if("WHILE"in t)return hu(t);if("STEP"in t)return mu(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,se.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)&&t.action!=="verify"){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 Gs({...n,action:"function",functionName:i})}if("action"in t)return Gs(t);if("intent"in t&&typeof t.intent=="string"||"desc"in t&&typeof t.desc=="string")return{uid:(0,se.v4)(),type:"DRAFT",description:typeof t.intent=="string"?t.intent:t.desc};throw new Error(`Cannot infer statement type from object: ${JSON.stringify(t)}`)}function Xs(e){if(typeof e!="string")throw new Error(`Condition must be a string, got ${typeof e}`);return e.startsWith("js:")?{type:"JS_CODE",expression:e.slice(3)}:{type:"AI_MODE",expression:e}}function uu(e){let t=Xs(e.IF),i=e.THEN;if(!Array.isArray(i))throw new Error("IF_ELSE requires a THEN array");let n={uid:(0,se.v4)(),type:"IF_ELSE",condition:t,then:ce(i)};return"ELSE"in e&&Array.isArray(e.ELSE)&&(n.else=ce(e.ELSE)),n}function hu(e){let t=Xs(e.WHILE),i=e.DO;if(!Array.isArray(i))throw new Error("WHILE_LOOP requires a DO array");let n={uid:(0,se.v4)(),type:"WHILE_LOOP",condition:t,body:ce(i)};return typeof e.timeout_ms=="number"&&(n.timeout_ms=e.timeout_ms),n}function mu(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)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,a={};for(let[o,r]of Object.entries(n))a[o]=String(r);i.template_params=a}return i}function Gs(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))pu.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js);let l={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(l.locator=n),a&&(l.xpath=a);let s={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:l};return o&&(s.use_pure_vision=!0),s}function $n(e,t){let i;try{i=(0,L.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,L.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let s=n.items?.[0];s?.key&&s.key.commentBefore&&(t.comment=s.key.commentBefore)}let a=n,o=a.get("statements",!0);(0,L.isSeq)(o)&&t.statements&&ot(o,t.statements);let r=a.get("teardown",!0);(0,L.isSeq)(r)&&t.teardown&&ot(r,t.teardown)}function ot(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let a=t[i];if(a.type==="STEP"&&(0,L.isMap)(n)){let o=n.get("statements",!0);(0,L.isSeq)(o)&&ot(o,a.statements)}else if(a.type==="IF_ELSE"&&(0,L.isMap)(n)){let o=n.get("THEN",!0);(0,L.isSeq)(o)&&ot(o,a.then);let r=n.get("ELSE",!0);(0,L.isSeq)(r)&&a.else&&ot(r,a.else)}else if(a.type==="WHILE_LOOP"&&(0,L.isMap)(n)){let o=n.get("DO",!0);(0,L.isSeq)(o)&&ot(o,a.body)}}}var L,se,Ks,js,pu,Mn=x(()=>{"use strict";Ca();L=require("yaml"),se=require("uuid");Ks={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};js=1024*1024;pu=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});var Ys,Js=x(()=>{"use strict";Mn();Ys=require("yaml")});var In=x(()=>{"use strict"});var qs=x(()=>{"use strict";Mn();In()});var Pn=x(()=>{"use strict"});var Zs=x(()=>{"use strict";Pn()});var Qs,wu,el,tl,mi,bu,yu,il=x(()=>{"use strict";Qs=112,wu=1080-Qs,el={"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"}},tl={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},mi=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),tl[e].map(n=>el[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},bu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile")}},yu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile",!0)}}});var nl=x(()=>{"use strict"});var al=x(()=>{"use strict";In()});var We,ol=x(()=>{"use strict";We=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(We||{})});var rl=x(()=>{"use strict"});var sl=x(()=>{"use strict"});var ll=x(()=>{"use strict"});var cl=x(()=>{"use strict";Pn()});var rt=x(()=>{"use strict";Cs();Ns();Os();Ds();Js();qs();Mn();Ca();Zs();il();nl();al();In();ol();rl();sl();ll();cl();Pn()});function Eu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Tu(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 ml(e){let t=Eu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Tu(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){te.set(e,t)}function Ue(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function dl(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}function gl(e,t,i){let n={expandingPaths:new Set([(0,lt.resolve)(t)]),depth:0,referencedPaths:new Set,basePath:i},a={...e};Array.isArray(a.statements)&&(a.statements=Oe(a.statements,t,n)),Array.isArray(a.teardown)&&(a.teardown=Oe(a.teardown,t,n));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(a[o])&&(a[o]=Oe(a[o],t,n));return{doc:a,referencedTemplatePaths:Array.from(n.referencedPaths)}}function Oe(e,t,i){let n=[];for(let a of e)if(Au(a)){let o=$u(a,t,i);n.push(o)}else n.push(Mu(a,t,i));return n}function Au(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function $u(e,t,i){if(i.depth>=ul)throw new Error(`Template expansion exceeded maximum depth of ${ul}. Check for deeply nested or circular template references.`);let n=(0,lt.resolve)((0,lt.dirname)(t),e.template),a=!(0,Cn.existsSync)(n)&&i.basePath?(0,lt.resolve)(i.basePath,e.template):n;if(i.expandingPaths.has(a))throw new Error(`Circular template reference detected: ${a} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${a}`);i.referencedPaths.add(a);let o;try{o=(0,Cn.readFileSync)(a,"utf-8")}catch(g){throw new Error(`Failed to read template file: ${a} (referenced from ${t}): ${g.message}`)}let r=(0,pi.parse)(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${a} \u2014 expected a YAML object`);let l=r.params||[],s=e.params||{};for(let g of l)if(!(g in s))throw new Error(`Template ${e.template} requires param "${g}" but it was not provided. Required params: [${l.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let f=(0,pi.stringify)(c);for(let[b,m]of Object.entries(s))f=f.split(`<<${b}>>`).join(String(m));c=(0,pi.parse)(f)}let d={expandingPaths:new Set([...i.expandingPaths,a]),depth:i.depth+1,referencedPaths:i.referencedPaths},u=Oe(c,a,d),h={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:u};return Object.keys(s).length>0&&(h.template_params=s),h}function Mu(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Oe(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Oe(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Oe(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Oe(n.DO,t,i)),n}function wl(e,t,i){let n=(0,gi.parse)(e),a=n?.name,o=n?.tags,r=n?.use;if(n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use),n?.suite){if(n.goal||n.statements)throw new fl('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Pu(n,a,o,r,t,i)}return Iu(n,a,o,r,t,i)}function Iu(e,t,i,n,a,o){let r=e?.beforeEach,l=e?.afterEach,s=bl(e?.parameters),c=e?.timeout,d=e?.skip,u=e?.fail,p=e?.only,h=e?.slow,g=e?.settings,f=n;if(g){let v={};g.auto_dismiss_modal!==void 0&&(v.autoDismissModal=!!g.auto_dismiss_modal),g.browser_timezone!==void 0&&g.browser_timezone!==null&&(v.timezoneId=String(g.browser_timezone)),g.browser_language!==void 0&&g.browser_language!==null&&(v.locale=String(g.browser_language)),g.extra_http_headers!==void 0&&g.extra_http_headers!==null&&typeof g.extra_http_headers=="object"&&(v.extraHTTPHeaders=g.extra_http_headers),Object.keys(v).length>0&&(f={...f,...v})}if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow,delete e.settings),e?.url)throw new fl(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let b=[];if(a&&e&&typeof e=="object"){let v=gl(e,a,o);e=v.doc,b=v.referencedTemplatePaths}let m=(0,gi.stringify)(e),y=Te(m);return a&&(st(y.statements??[],a,"main"),y.teardown&&st(y.teardown,a,"teardown")),{testFlow:y,name:t,tags:i,use:f,beforeEach:r,afterEach:l,parameters:s,timeout:c,skip:d,fail:u,only:p,slow:h,referencedTemplatePaths:b}}function Pu(e,t,i,n,a,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let l=r.beforeAll,s=r.afterAll,c=r.beforeEach,d=r.afterEach,u=[],p=r.tests.map(f=>{if(!f.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(f.statements)||f.statements.length===0)throw new Error(`Suite test "${f.name}" must have a non-empty "statements" array.`);let b={goal:f.name,statements:f.statements};f.teardown&&(b.teardown=f.teardown);let m=[],y=b;if(a&&typeof b=="object"){let M=gl(b,a,o);y=M.doc,m=M.referencedTemplatePaths,u.push(...m)}let v=(0,gi.stringify)(y),E=Te(v),A=bl(f.parameters);return{testFlow:E,name:f.name,tags:Array.isArray(f.tags)?f.tags:void 0,parameters:A,timeout:f.timeout,skip:f.skip,fail:f.fail,only:f.only,slow:f.slow}}),h=r.base_url,g=h?{...n,baseURL:h}:n;return{suite:{beforeAll:l,afterAll:s,beforeEach:c,afterEach:d,tests:p},name:t,tags:i,use:g,referencedTemplatePaths:u}}function bl(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function st(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Cu(t,o,r),a.type===We.STEP)st(a.statements,t,o);else if(a.type===We.IF_ELSE){let l=a;st(l.then,t,`${o}.then`),l.else&&st(l.else,t,`${o}.else`)}else a.type===We.WHILE_LOOP&&st(a.body,t,`${o}.body`)}}function Cu(e,t,i){let n=(0,pl.createHash)("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${n.slice(0,8)}-${n.slice(8,12)}-${n.slice(12,16)}-${n.slice(16,20)}-${n.slice(20,32)}`}var Su,pl,gi,Cn,lt,pi,hl,te,ul,fl,yl=x(()=>{"use strict";rt();Su=require("yaml");rt();pl=require("crypto"),gi=require("yaml");rt();Cn=require("fs"),lt=require("path"),pi=require("yaml");rt();hl=5e3;te=new Map;$("click",e=>{let t=ml(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??hl;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",te.get("click"));$("click_element_by_index",te.get("click"));$("double_click",e=>Ue("double_click",e));$("double_click_on_element",te.get("double_click"));$("right_click",e=>Ue("right_click",e));$("right_click_on_element",te.get("right_click"));$("hover",e=>Ue("hover",e));$("hover_element_by_index",te.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Ue("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",te.get("input_text"));$("clear_input",e=>Ue("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",te.get("press"));$("send_keys_on_element",e=>{let t=ml(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??hl;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Ue("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",te.get("scroll"));$("scroll_up",te.get("scroll"));$("scroll_element",te.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Ue("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",te.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
|
|
4301
|
+
`,n+='- In action descriptions, describe what the placeholder represents in natural language (e.g., "Type the first user name" instead of "Type {{ firstUserName }}")',n}}});var li=x(()=>{"use strict"});async function vd(e,t){let i=new Set,n=Date.now(),a=new Set(["document","stylesheet","image","font","script","iframe"]),o=new Set(["text/html","text/css","application/javascript","image/","font/","application/json"]),r=["analytics","tracking","telemetry","beacon","metrics","doubleclick","adsystem","adserver","advertising","facebook.com/plugins","platform.twitter","linkedin.com/embed","livechat","zendesk","intercom","crisp.chat","hotjar","push-notifications","onesignal","pushwoosh","heartbeat","ping","alive","webrtc","rtmp://","wss://","cloudfront.net","fastly.net"],l=u=>{let m=u.toLowerCase();return m.startsWith("data:")||m.startsWith("blob:")?!0:r.some(h=>m.includes(h))},s=u=>{let m=u.resourceType(),h=u.url();if(!a.has(m)||l(h))return;let g=u.headers();g.purpose==="prefetch"||["video","audio"].includes(g["sec-fetch-dest"])||(i.add(u),n=Date.now())},c=async u=>{let m=u.request();if(!i.has(m))return;let h=(u.headers()["content-type"]||"").toLowerCase();if(["streaming","video","audio","webm","mp4","event-stream","websocket","protobuf"].some(f=>h.includes(f))){i.delete(m);return}if(![...o].some(f=>h.startsWith(f))){i.delete(m);return}let g=u.headers()["content-length"];if(g)try{if(parseInt(g,10)>5*1024*1024){i.delete(m);return}}catch{}i.delete(m),n=Date.now()},d=Date.now()-xd;for(let u of await e.requests()){let m=u.resourceType(),h=u.url(),g=u.timing();a.has(m)&&!l(h)&&g.responseEnd===-1&&g.startTime>=d&&(i.add(u),n=Date.now())}w.debug(`[waitForStableNetwork] Pre-populated ${i.size} in-flight requests`),e.on("request",s),e.on("response",c);try{let u=Date.now(),m=yd;for(;;){await new Promise(g=>setTimeout(g,100));let h=Date.now();if(i.size===0&&h-n>=m){w.debug(`[waitForStableNetwork] Network idle after ${h-u}ms`);break}if(h-u>t){w.debug(`[waitForStableNetwork] Max wait time exceeded (${t}ms), pending: ${i.size}`);break}}}finally{e.removeListener("request",s),e.removeListener("response",c)}}async function it(e,t=bd,i=wd){let n=Date.now();try{await Promise.all([e.waitForLoadState("load",{timeout:t}).catch(()=>{}),vd(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 wd,bd,yd,xd,Ce=x(()=>{"use strict";li();U();wd=.5*1e3,bd=30*1e3,yd=1*1e3,xd=3*1e3});function _d(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 es(e,t,i={}){let n=Date.now();if(i.maxSteps!==void 0&&i.maxSteps<=0)throw new Error(`maxSteps must be >= 1, got ${i.maxSteps}`);let a=i.maxSteps??15,o=3,r=t.agentServices.getModel(),l=t.domService||new Pe(t.agentServices.getDomServiceOptions()),s={...t,domService:l};S.init(),S.section("Task Execution Started"),S.log(`Task: ${e}`),S.log(`Max steps: ${a}`),S.log(`Model: ${r}`);let c={currentStep:0,maxSteps:a,consecutiveFailures:0,maxFailures:o,lastFailReason:null,stepHistory:[],memory:[],lastGoal:null,lastEvaluation:null},d=[],u=yn(i.customPrompt),m=new vn(u);S.log(`System prompt length: ${u.length} chars`);let h=!1,g="",f=[];try{for(i.onEvent?.({type:"start",task:e,maxSteps:a});c.currentStep<a;){if(i.abortSignal?.aborted)throw new Error("Task aborted by user");c.currentStep++;let b=Date.now();S.section(`Step ${c.currentStep}/${a}`),S.log(`URL: ${s.page.url()}`),i.onEvent?.({type:"step_start",step:c.currentStep});try{S.log("Waiting for page to stabilize..."),await it(s.page),S.log("Page stabilized")}catch{S.log("Page stabilization timed out, continuing anyway")}let p;try{S.log("Preparing context (DOM + screenshot)...");let R=s.agentServices.getInteractiveClassNames(),W=s.agentServices.getIframeFallbackDomains();p=await Zr(s.page,s.domService,R,W),S.log("Context prepared")}catch(R){if(R.message.includes("Execution context was destroyed")){S.log("Page navigating, waiting for load..."),await it(s.page);let W=s.agentServices.getInteractiveClassNames(),D=s.agentServices.getIframeFallbackDomains();p=await Zr(s.page,s.domService,W,D)}else throw S.error("Error preparing context",R),R}m.addStateMessage(e,p.currentUrl,p.domTree,p.screenshotBase64,c,{isFinalStep:c.currentStep===a-1,placeholderData:t.variables,sensitiveKeys:t.sensitiveKeys});let y=await Sd(m,r,i,p.screenshotBase64);if(y.tokenUsages&&y.tokenUsages.length>0&&d.push(...y.tokenUsages),!y.stepOutput){if(S.error("Failed to get valid LLM response"),c.consecutiveFailures++,c.consecutiveFailures>=o){g="Reached the maximum allowed consecutive failures. Most recent error: Unable to get a valid response from the language model.";break}continue}let v=y.stepOutput;$d(c.currentStep,a,v);let E=await Td(v,s,p.domState,c.currentStep,i.onEvent,p.screenshotBase64,y.debugInfo);f.push(...E.actionEntities);let A=Ad(c.currentStep,v,E,c,b,y.debugInfo,y.tokenUsages),M=Date.now()-b;if(i.onEvent?.({type:"step_complete",step:c.currentStep,duration:M}),c.consecutiveFailures>=o){S.error(`Too many consecutive failures (${c.consecutiveFailures}), stopping`),g=`Reached the maximum allowed consecutive failures. Most recent error: ${c.lastFailReason}`;break}if(E.doneResult){h=E.doneResult.success,g=E.doneResult.summary;break}if(E.completesInstruction){h=!0,g="Instruction completed";break}}return c.currentStep>=a&&!h&&(g="Reached the maximum allowed steps."),i.onEvent?.({type:"complete",totalSteps:c.currentStep,duration:Date.now()-n}),S.log(`Build success result: summary=${g}, completed=${h}, actions=${f.length}, tokens=${d.length}`),Md(c,f,h,g,n,d,r)}catch(b){let p=b.message;return S.error(`Task execution failed: ${p}`,b),i.onEvent?.({type:"error",error:p,recoverable:!1}),Id(c,p,n,d,r)}}async function Zr(e,t,i,n){let{domState:a,screenshotBase64:o}=await t.getClickableElementsWithScreenshot(e,{interactiveClassNames:i,playwrightFrameFallbackDomains:n}),r=a.elementTree.clickableElementsToString();return{currentUrl:e.url(),domTree:r,screenshotBase64:o,domState:a}}function kd(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 Sd(e,t,i,n){let a=i.temperature??0,{system:o,messages:r}=e.getMessages(),l=0;for(let u of r)Array.isArray(u.content)&&(l+=u.content.filter(m=>m.type==="image").length);let s=ve(t,l),c={model:xe(t),system:o,messages:r,temperature:a,providerOptions:s},d=3;for(let u=0;u<d;u++)try{let m=Date.now();S.log(`Calling LLM (${t})...`);let h=await(0,Qr.generateText)(c),g=Date.now()-m,f=h,b=f.usage;S.llmCall(t,g,b);let p=f.reasoningText;p&&(S.thinking(p),i.onEvent?.({type:"thinking",text:p})),e.addAssistantMessage(h.text);let y={systemPrompt:o,userPrompt:kd(r),rawLlmResponse:h.text,reasoningContent:p,screenshotWithSom:n},v=[],E=_d(b,t);E&&v.push(E);let A=Ed(h.text);if(!A)if(u<d-1){S.log(`Attempt ${u+1}/${d}: Failed to parse response, retrying...`),e.addTextMessage("user","Your response was not valid JSON. Please respond with a properly formatted JSON object according to the expected format."),await new Promise(M=>setTimeout(M,i.retryDelay||1e3));continue}else return S.error("All parsing attempts failed"),{stepOutput:null,debugInfo:y,tokenUsages:v};return{stepOutput:A,debugInfo:y,tokenUsages:v}}catch(m){if(u<d-1){S.log(`Attempt ${u+1}/${d}: LLM call failed (${m.message}), retrying...`),await new Promise(h=>setTimeout(h,i.retryDelay||1e3));continue}else throw S.error("All LLM call attempts failed",m),m}return{stepOutput:null}}function Ed(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 S.error("Missing required field: current_goal"),null;if(!i.actions||!Array.isArray(i.actions)||i.actions.length===0)return S.error("Missing required field: actions (must be non-empty array)"),null;for(let n of i.actions){if(!n.action_name)return S.error("Action missing required field: action_name"),null;if(!n.description)return S.error("Action missing required field: description"),null}return i}catch(i){return S.error(`Failed to parse LLM JSON response: ${t.substring(0,500)}`),S.error(`Parse error: ${i.message}`),null}}async function Td(e,t,i,n,a,o,r){let l=[],s=!0,c=null;S.log(`Using pre-captured DOM state with ${i.selectorMap.size} elements for ${e.actions.length} action(s)`);let d=null,u={...t,domState:i},m=o;for(let h of e.actions){if(h.action_name==="done"){d={success:h.kwargs.success??!0,summary:h.kwargs.summary||h.kwargs.text||"Task completed"};break}let g={},f=h.kwargs?.element_index??h.kwargs?.index;if(typeof f=="number"){let p=i.selectorMap.get(f);p&&(g=await F(t.page,p))}let b={...g,action_description:h.description,action_data:{action_name:h.action_name,kwargs:h.kwargs}};try{let p=await B.execute(h.action_name,h.kwargs,u);h.action_name==="perform_accurate_operation"&&(b=p.actionEntity);let y=await u.agentServices.getCurrentPage();if(y&&(u.page=y,t.page=u.page),p?.success===!1){s=!1,S.log("Action failed, stopping execution of remaining actions in this step"),c=p.error||"Action execution failed";break}l.push(b),a?.({type:"action",action_entity:b,step:n,debugInfo:r})}catch(p){s=!1,c=p.message,S.error(`Action execution failed: ${p.message}`);break}}return{allSuccess:s,failReason:c,actionEntities:l,doneResult:d,completesInstruction:e.completes_instruction??!1}}function Ad(e,t,i,n,a,o,r){let l={stepNumber:e,thinking:t.thinking,evaluation:t.evaluation_previous_goal,memory:t.memory,goal:t.current_goal,actions:i.actionEntities,timestamp:a,duration:Date.now()-a,outcome:{success:i.allSuccess},debugInfo:o,tokenUsages:r};if(n.lastGoal=t.current_goal,t.evaluation_previous_goal&&(n.lastEvaluation=t.evaluation_previous_goal),t.memory&&t.memory.trim()){let s=t.memory.trim();n.memory.includes(s)||(n.memory.push(s),n.memory.length>10&&(n.memory=n.memory.slice(-10)))}return i.allSuccess?(n.consecutiveFailures=0,n.lastFailReason=null):(n.consecutiveFailures++,n.lastFailReason=i.failReason),n.stepHistory.push(l),l}function $d(e,t,i){if(S.log(`Step ${e}/${t}`),i.thinking&&S.log(`Thinking: ${i.thinking}`),i.evaluation_previous_goal&&S.log(`Evaluation: ${i.evaluation_previous_goal}`),i.memory&&S.log(`Memory: ${i.memory}`),S.log(`Goal: ${i.current_goal}`),i.actions.length===1){let n=i.actions[0];S.log(`Action: ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)}else S.log(`Actions (${i.actions.length}):`),i.actions.forEach((n,a)=>{S.log(` ${a+1}. ${n.action_name}(${JSON.stringify(n.kwargs)}) - ${n.description}`)})}function Md(e,t,i,n,a,o,r){let l=o.reduce((d,u)=>d+u.prompt_tokens,0),s=o.reduce((d,u)=>d+u.completion_tokens,0),c=o.reduce((d,u)=>d+u.total_tokens,0);return{success:!0,completed:i,summary:n,trajectory:{steps:e.currentStep,actions:t,stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-a,model:r,successfulSteps:e.stepHistory.filter(d=>d.outcome.success).length,failedSteps:e.stepHistory.filter(d=>!d.outcome.success).length,promptTokens:l,completionTokens:s,totalTokens:c,tokenUsages:o}}}function Id(e,t,i,n,a){let o=n.reduce((s,c)=>s+c.prompt_tokens,0),r=n.reduce((s,c)=>s+c.completion_tokens,0),l=n.reduce((s,c)=>s+c.total_tokens,0);return{success:!1,completed:!1,error:t,trajectory:{steps:e.currentStep,actions:[],stepRecords:e.stepHistory},metadata:{totalSteps:e.currentStep,totalDuration:Date.now()-i,model:a,successfulSteps:e.stepHistory.filter(s=>s.outcome.success).length,failedSteps:e.stepHistory.filter(s=>!s.outcome.success).length,promptTokens:o,completionTokens:r,totalTokens:l,tokenUsages:n}}}var Qr,ts=x(()=>{"use strict";Sa();xn();ke();Fe();ne();Ce();_e();z();Qr=require("ai")});var is={};Ge(is,{TaskMessageManager:()=>vn,formatFinalStepWarning:()=>Jr,formatTaskContext:()=>bn,getBrowserTaskJSONPrompt:()=>yn,runTaskLoop:()=>es});var ns=x(()=>{"use strict";ts();Sa();xn();ke();Xi();Fe();xt();vt();Je();_t();kt();ne();Ce();li();_e();mt();ze();pt();Re();z();Le();U();ie();Tt();H();be()});async function At(e,t){try{if(!e.action_data)return{success:!1,error:"Action entity missing action_data"};let{action_name:i,kwargs:n}=e.action_data;if(B.has(i)){let a=await B.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 Pd()).execute(a,e,o),{success:!0,error:void 0}}}catch(i){return{success:!1,error:i.message}}}async function Pd(){if(_n)return _n;let e=await Promise.resolve().then(()=>(wn(),fn));return _n=new e.default,_n}async function Yi(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Yn(r,o,n);return l.status==="error"?{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error,debugInfo:l.debugInfo}:{status:"success",completed:l.goalAccomplished||!1,actionEntities:l.actionEntity?[l.actionEntity]:[],explanation:l.reasoning,debugInfo:l.debugInfo}}async function Ji(e,t,i,n={},a){let o=a||{page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},r=i.replaceVariables(e),l=await Yn(r,o,n);if(l.status==="error"||!l.actionEntity)return{status:"error",completed:l.goalAccomplished||!1,actionEntities:[],explanation:l.reasoning,error:l.error||"No action generated",debugInfo:l.debugInfo};let{actionEntity:s,reasoning:c,goalAccomplished:d,debugInfo:u}=l,m=await At(s,o);return m.success?(c&&i.addNote(c),{status:"success",completed:d||!1,actionEntities:[s],explanation:c,debugInfo:u}):{status:"error",completed:!1,actionEntities:[s],error:m.error||"Action execution failed",debugInfo:u}}async function qi(e,t,i,n={}){let a={page:t,agentServices:i,domService:new Pe(i.getDomServiceOptions()),executionHistory:n.executionHistory,variables:n.variables,sensitiveKeys:n.sensitiveKeys},o=i.replaceVariables(e);return n.useCleanScreenshotForAssertion??(n.useCleanScreenshotForAssertion=i.isUseCleanScreenshotForAssertion()),vo(o,a,n)}async function Zi(e,t,i,n,a={}){let{runTaskLoop:o}=await Promise.resolve().then(()=>(ns(),is)),r=n?s=>{n(s)}:void 0,l=await o(e,{page:t,agentServices:i,domService:void 0,executionHistory:a.executionHistory,variables:a.variables,sensitiveKeys:a.sensitiveKeys},{maxSteps:a.maxSteps,onEvent:r,abortSignal:a.abortSignal});return{status:l.success?"success":"error",completed:l.completed,actionEntities:l.trajectory.actions,explanation:l.summary,error:l.error,tokenUsages:l.metadata.tokenUsages}}var _n,$t=x(()=>{"use strict";Ri();ke();Fe();_n=null});var _,wx,Ex,$x,Px,_s,mx,ks,Fd,Hd,Sn,px,gx,Ss,Es,Wd,vs,Ud,ci,Bd,jd,Gd,re,Kd,zd,fx,Ax,di=x(()=>{"use strict";be();_=require("zod"),wx=require("yaml"),Ex=require("uuid"),$x=require("yaml"),Px=require("uuid"),_s=112,mx=1080-_s,ks=(e=>(e.Chromium="chromium",e.Firefox="firefox",e.Webkit="webkit",e))(ks||{}),Fd={"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"}},Hd={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"]},Sn=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),Hd[e].map(n=>Fd[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},px={desktop:{label:"Desktop",type:"desktop",devices:Sn("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:Sn("mobile")}},gx={desktop:{label:"Desktop",type:"desktop",devices:Sn("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:Sn("mobile",!0)}},Ss=(e=>(e.PASSWORD="password",e.OAUTH2="oauth2",e.SSO="sso",e.API="api",e))(Ss||{}),Es=(e=>(e.SMS="sms",e.EMAIL="email",e.TOTP="totp",e))(Es||{}),Wd=_.z.enum(["JS_CODE","AI_MODE"]),vs=_.z.object({type:Wd,expression:_.z.string()}),Ud=_.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),ci=_.z.object({uid:_.z.string(),type:Ud,comment:_.z.string().optional()}),Bd=_.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(),jd=ci.extend({type:_.z.literal("DRAFT"),description:_.z.string()}),Gd=ci.extend({type:_.z.literal("ACTION"),description:_.z.string(),action_entity:Bd.optional(),locator:_.z.string().optional(),use_pure_vision:_.z.boolean().optional()}),re=_.z.lazy(()=>_.z.union([jd,Gd,ci.extend({type:_.z.literal("STEP"),description:_.z.string().optional().default(""),statements:_.z.array(re),reference_id:_.z.number().optional(),template_path:_.z.string().optional(),template_params:_.z.record(_.z.string()).optional()}),ci.extend({type:_.z.literal("IF_ELSE"),description:_.z.string().optional(),condition:vs,then:_.z.array(re),else:_.z.array(re).optional()}),ci.extend({type:_.z.literal("WHILE_LOOP"),description:_.z.string().optional(),condition:vs,body:_.z.array(re),timeout_ms:_.z.number().optional()})])),Kd=_.z.object({name:_.z.string(),statements:_.z.array(re),teardown:_.z.array(re).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()}),zd=_.z.object({tests:_.z.array(Kd).min(1),beforeAll:_.z.array(re).optional(),afterAll:_.z.array(re).optional(),beforeEach:_.z.array(re).optional(),afterEach:_.z.array(re).optional()}),fx=_.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(re).optional(),teardown:_.z.array(re).optional(),last_modified_at:_.z.string().optional(),testGroup:zd.optional()}).refine(e=>e.testGroup!==void 0?e.goal===void 0&&(e.statements===void 0||e.statements.length===0):e.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),Ax=1024*1024});var $a=x(()=>{"use strict";ne();Ce()});var k,Cs,Ia,Ns,at,Os,Ds,Ls,ae,Rs,En,Pa,Ca=x(()=>{"use strict";k=require("zod"),Cs=k.z.enum(["JS_CODE","AI_MODE"]),Ia=k.z.object({type:Cs,expression:k.z.string()}),Ns=k.z.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),at=k.z.object({uid:k.z.string(),type:Ns,comment:k.z.string().optional()}),Os=k.z.object({action_data:k.z.object({action_name:k.z.string(),kwargs:k.z.record(k.z.any()).optional(),args:k.z.array(k.z.any()).optional()}),action_description:k.z.string().optional(),url:k.z.string().optional(),xpath:k.z.string().nullable().optional(),locator:k.z.string().nullable().optional(),css_selector:k.z.string().nullable().optional(),unique_selector:k.z.string().nullable().optional(),element_index:k.z.number().nullable().optional(),frame_path:k.z.array(k.z.any()).optional(),artifacts:k.z.record(k.z.any()).optional(),feedback:k.z.string().optional(),original_browser_use_action:k.z.any().optional()}).passthrough(),Ds=at.extend({type:k.z.literal("DRAFT"),description:k.z.string()}),Ls=at.extend({type:k.z.literal("ACTION"),description:k.z.string(),action_entity:Os.optional(),locator:k.z.string().optional(),use_pure_vision:k.z.boolean().optional()}),ae=k.z.lazy(()=>k.z.union([Ds,Ls,at.extend({type:k.z.literal("STEP"),description:k.z.string().optional().default(""),statements:k.z.array(ae),reference_id:k.z.number().optional(),template_path:k.z.string().optional(),template_params:k.z.record(k.z.string()).optional()}),at.extend({type:k.z.literal("IF_ELSE"),description:k.z.string().optional(),condition:Ia,then:k.z.array(ae),else:k.z.array(ae).optional()}),at.extend({type:k.z.literal("WHILE_LOOP"),description:k.z.string().optional(),condition:Ia,body:k.z.array(ae),timeout_ms:k.z.number().optional()})])),Rs=k.z.object({name:k.z.string(),statements:k.z.array(ae),teardown:k.z.array(ae).optional(),skip:k.z.union([k.z.boolean(),k.z.string()]).optional(),timeout:k.z.number().optional(),fail:k.z.union([k.z.boolean(),k.z.string()]).optional(),only:k.z.boolean().optional(),slow:k.z.boolean().optional()}),En=k.z.object({tests:k.z.array(Rs).min(1),beforeAll:k.z.array(ae).optional(),afterAll:k.z.array(ae).optional(),beforeEach:k.z.array(ae).optional(),afterEach:k.z.array(ae).optional()}),Pa=k.z.object({comment:k.z.string().optional(),version:k.z.string().optional(),goal:k.z.string().optional(),url:k.z.string().optional(),baseURL:k.z.string().optional(),final_feedback:k.z.string().optional(),completed:k.z.boolean().optional(),success:k.z.boolean().optional(),statements:k.z.array(ae).optional(),teardown:k.z.array(ae).optional(),last_modified_at:k.z.string().optional(),testGroup:En.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 Tn(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,...t?.timeout!==void 0?{timeout:t.timeout}:{},...t?.settings&&Object.keys(t.settings).length>0?{settings:t.settings}:{},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 An(e,t){if(e.testGroup)return Bs(e,t);let i=Tn(e,t),n=new L.Document(i);return e.comment&&(n.commentBefore=e.comment),Fs(n,e.statements??[]),e.teardown&&Fs(n,e.teardown,"teardown"),n.toString(Us)}function Fs(e,t,i="statements"){let n=e.contents;if(!n||!(0,L.isMap)(n))return;let a=n.get(i,!0);(0,L.isSeq)(a)&&hi(a,t)}function hi(e,t){for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=t[i],a=e.items[i];if(i>0&&(a.spaceBefore=!0),n.comment&&(i===0?e.commentBefore=n.comment:a.commentBefore=n.comment),(0,L.isMap)(a)){let o=a;if(n.type==="STEP"){let r=o.get("statements",!0);(0,L.isSeq)(r)&&hi(r,n.statements)}else if(n.type==="IF_ELSE"){let r=o.get("THEN",!0);(0,L.isSeq)(r)&&hi(r,n.then);let l=o.get("ELSE",!0);(0,L.isSeq)(l)&&n.else&&hi(l,n.else)}else if(n.type==="WHILE_LOOP"){let r=o.get("DO",!0);(0,L.isSeq)(r)&&hi(r,n.body)}}}}function Bs(e,t){let i=e.testGroup;if(!i)throw new Error("suiteToYaml requires a TestFlow with testGroup");let n={};t?.test_case_id!==void 0&&(n.test_case_id=t.test_case_id),t?.name&&(n.name=t.name),t?.tags&&t.tags.length>0&&(n.tags=t.tags),t?.use&&Object.keys(t.use).length>0&&(n.use=t.use),t?.settings&&Object.keys(t.settings).length>0&&(n.settings=t.settings);let a={};return e.baseURL&&(a.base_url=e.baseURL),i.beforeAll&&i.beforeAll.length>0&&(a.beforeAll=i.beforeAll.map(le)),i.beforeEach&&i.beforeEach.length>0&&(a.beforeEach=i.beforeEach.map(le)),i.afterEach&&i.afterEach.length>0&&(a.afterEach=i.afterEach.map(le)),i.afterAll&&i.afterAll.length>0&&(a.afterAll=i.afterAll.map(le)),a.tests=i.tests.map(o=>{let r={name:o.name};return o.skip!==void 0&&(r.skip=o.skip),o.timeout!==void 0&&(r.timeout=o.timeout),o.fail!==void 0&&(r.fail=o.fail),o.only!==void 0&&(r.only=o.only),o.slow!==void 0&&(r.slow=o.slow),r.statements=o.statements.map(le),o.teardown&&o.teardown.length>0&&(r.teardown=o.teardown.map(le)),r}),n.suite=a,(0,L.stringify)(n,Us)}function le(e){switch(e.type){case"DRAFT":return nu(e);case"ACTION":return au(e);case"STEP":return ou(e);case"IF_ELSE":return ru(e);case"WHILE_LOOP":return su(e)}}function nu(e){return{intent:e.description}}function au(e){let t=e.action_entity?.action_data?.action_name??e.action_entity?.action?.action_name,i=e.action_entity?.action_data?.kwargs??e.action_entity?.action?.kwargs;if(t==="verify"){let l=i?.statement;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s=i?.code;return typeof s=="string"?{VERIFY:l,js:s}:{VERIFY:l}}}if(t==="go_to_url"){let l=i?.url;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath){let s={URL:l};return i?.new_tab===!0&&(s.new_tab=!0),typeof i?.timeout_seconds=="number"&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="js_action"){let l=i?.code;if(typeof l=="string"&&e.description)return{intent:e.description,js:l}}if(t==="ai_wait_until"){let l=i?.condition;if(typeof l=="string"){let s={WAIT_UNTIL:l};return typeof i?.timeout_seconds=="number"&&i.timeout_seconds!==60&&(s.timeout_seconds=i.timeout_seconds),s}}if(t==="wait"){let l=i?.seconds,c={WAIT:e.description||`Wait ${l}s`};return typeof l=="number"&&(c.seconds=l),c}if(t==="js_code"){let l=i?.code;if(typeof l=="string"&&!e.action_entity?.locator&&!e.action_entity?.xpath)return{CODE:l}}if(!e.action_entity)return{intent:e.description};let n=e.action_entity.action_data??e.action_entity.action;if(!n)return{intent:e.description};let a={intent:e.description,action:n.action_name},o=e.locator??e.action_entity.locator;o&&(a.locator=o);let r=e.action_entity.xpath;if(r&&(a.xpath=r),e.use_pure_vision&&(a.use_pure_vision=!0),n.kwargs&&Object.keys(n.kwargs).length>0)for(let[l,s]of Object.entries(n.kwargs))a[l]=s;return n.args&&n.args.length>0&&(a.args=n.args),a}function ou(e){if(e.template_path){let i={template:e.template_path};return e.template_params&&Object.keys(e.template_params).length>0&&(i.params=e.template_params),i}let t={STEP:e.description,statements:e.statements.map(le)};return e.reference_id!==void 0&&(t.reference_id=e.reference_id),t}function ru(e){let t={IF:js(e.condition),THEN:e.then.map(le)};return e.else&&e.else.length>0&&(t.ELSE=e.else.map(le)),t}function su(e){let t={WHILE:js(e.condition),DO:e.body.map(le)};return e.timeout_ms!==void 0&&(t.timeout_ms=e.timeout_ms),t}function js(e){return e.type==="JS_CODE"?`js:${e.expression}`:e.expression}function Oa(e){try{let t=(0,L.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()),typeof t.timeout=="number"&&Number.isFinite(t.timeout)&&(i.timeout=t.timeout),t.settings&&typeof t.settings=="object"&&!Array.isArray(t.settings)&&(i.settings=t.settings),i}catch{return{}}}function Na(e){if(e==null||typeof e!="object")return e;if(Array.isArray(e))return e.map(Na);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]=Na(o);return n}function Te(e){if(e.length>Hs)throw new Error(`YAML input too large (${e.length} bytes, max ${Hs})`);let t=Na((0,L.parse)(e));if(!t||typeof t!="object")throw new Error("Invalid YAML: expected an object at root level");if(t.suite)return lu(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=Pa.safeParse(i);if(!n.success)throw new Error(`Invalid TestFlow after YAML conversion: ${JSON.stringify(n.error.errors)}`);let a=n.data;return $n(e,a),a}function lu(e){let t=e.suite;if(!t||typeof t!="object")throw new Error("Invalid suite: expected an object");let i=t.tests;if(!Array.isArray(i)||i.length===0)throw new Error('Suite must have a non-empty "tests" array');let a={tests:i.map(l=>{if(!l.name)throw new Error('Each test in a suite must have a "name" field');if(!Array.isArray(l.statements)||l.statements.length===0)throw new Error(`Suite test "${l.name}" must have a non-empty "statements" array`);let s={name:l.name,statements:ce(l.statements)};return Array.isArray(l.teardown)&&l.teardown.length>0&&(s.teardown=ce(l.teardown)),l.skip!==void 0&&(s.skip=l.skip),typeof l.timeout=="number"&&(s.timeout=l.timeout),l.fail!==void 0&&(s.fail=l.fail),l.only===!0&&(s.only=!0),l.slow===!0&&(s.slow=!0),s})};Array.isArray(t.beforeAll)&&t.beforeAll.length>0&&(a.beforeAll=ce(t.beforeAll)),Array.isArray(t.afterAll)&&t.afterAll.length>0&&(a.afterAll=ce(t.afterAll)),Array.isArray(t.beforeEach)&&t.beforeEach.length>0&&(a.beforeEach=ce(t.beforeEach)),Array.isArray(t.afterEach)&&t.afterEach.length>0&&(a.afterEach=ce(t.afterEach));let o=En.safeParse(a);if(!o.success)throw new Error(`Invalid TestGroup: ${JSON.stringify(o.error.errors)}`);return{version:"1.3.0",baseURL:t.base_url||void 0,testGroup:o.data}}function ce(e){if(!Array.isArray(e))throw new Error("Expected an array of statements");return e.map(cu)}function cu(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 du(t);if("WHILE"in t)return uu(t);if("STEP"in t)return hu(t);if("VERIFY"in t){let i=t.VERIFY,n={statement:typeof i=="string"?i:String(i)};return typeof t.js=="string"&&(n.code=t.js),{uid:(0,se.v4)(),type:"ACTION",description:String(i),action_entity:{action_description:String(i),action_data:{action_name:"verify",kwargs:n}}}}if("URL"in t){let i=t.URL,n=t.new_tab===!0?!0:void 0,a=typeof t.timeout_seconds=="number"?t.timeout_seconds:void 0,o={url:typeof i=="string"?i:String(i)};return n&&(o.new_tab=!0),a!==void 0&&(o.timeout_seconds=a),{uid:(0,se.v4)(),type:"ACTION",description:`Navigate to ${i}`,action_entity:{action_description:`Navigate to ${i}`,action_data:{action_name:"go_to_url",kwargs:o}}}}if("WAIT_UNTIL"in t){let i=t.WAIT_UNTIL,n=typeof t.timeout_seconds=="number"?t.timeout_seconds:60;return{uid:(0,se.v4)(),type:"ACTION",description:`Wait until: ${i}`,action_entity:{action_description:`Wait until: ${i}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:typeof i=="string"?i:String(i),timeout_seconds:n}}}}}if("WAIT"in t){let i=t.WAIT,n=typeof t.seconds=="number"?t.seconds:3;return{uid:(0,se.v4)(),type:"ACTION",description:typeof i=="string"?i:`Wait ${n}s`,action_entity:{action_description:typeof i=="string"?i:`Wait ${n}s`,action_data:{action_name:"wait",kwargs:{seconds:n}}}}}if("CODE"in t){let i=t.CODE;if(i==null)throw new Error('CODE statement has no code. Use "CODE: |" followed by indented code on the next line.');return{uid:(0,se.v4)(),type:"ACTION",description:"Code block",action_entity:{action_description:"Code block",action_data:{action_name:"js_code",kwargs:{code:typeof i=="string"?i:String(i)}}}}}if("js"in t&&("intent"in t||"desc"in t)&&!("VERIFY"in t)&&t.action!=="verify"){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 Ws({...n,action:"function",functionName:i})}if("action"in t)return Ws(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 Gs(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 du(e){let t=Gs(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 uu(e){let t=Gs(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 hu(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)};if(typeof e.reference_id=="number"&&(i.reference_id=e.reference_id),typeof e.template_path=="string"&&(i.template_path=e.template_path),e.template_params&&typeof e.template_params=="object"&&!Array.isArray(e.template_params)){let n=e.template_params,a={};for(let[o,r]of Object.entries(n))a[o]=String(r);i.template_params=a}return i}function Ws(e){let t=typeof e.action=="string"?e.action:String(e.action),i=typeof e.intent=="string"?e.intent:typeof e.desc=="string"?e.desc:"",n=typeof e.locator=="string"?e.locator:void 0,a=typeof e.xpath=="string"?e.xpath:void 0,o=typeof e.use_pure_vision=="boolean"?e.use_pure_vision:void 0,r={};for(let[c,d]of Object.entries(e))mu.has(c)||(r[c]=d);t==="verify"&&typeof r.js=="string"&&(r.code=r.js,delete r.js);let l={action_description:i,action_data:{action_name:t,kwargs:Object.keys(r).length>0?r:{}}};n&&(l.locator=n),a&&(l.xpath=a);let s={uid:(0,se.v4)(),type:"ACTION",description:i,action_entity:l};return o&&(s.use_pure_vision=!0),s}function $n(e,t){let i;try{i=(0,L.parseDocument)(e)}catch{return}let n=i.contents;if(!n||!(0,L.isMap)(n))return;if(i.commentBefore)t.comment=i.commentBefore;else{let s=n.items?.[0];s?.key&&s.key.commentBefore&&(t.comment=s.key.commentBefore)}let a=n,o=a.get("statements",!0);(0,L.isSeq)(o)&&t.statements&&ot(o,t.statements);let r=a.get("teardown",!0);(0,L.isSeq)(r)&&t.teardown&&ot(r,t.teardown)}function ot(e,t){e.commentBefore&&t.length>0&&(t[0].comment=e.commentBefore);for(let i=0;i<Math.min(e.items.length,t.length);i++){let n=e.items[i];n.commentBefore&&!(i===0&&e.commentBefore)&&(t[i].comment=n.commentBefore);let a=t[i];if(a.type==="STEP"&&(0,L.isMap)(n)){let o=n.get("statements",!0);(0,L.isSeq)(o)&&ot(o,a.statements)}else if(a.type==="IF_ELSE"&&(0,L.isMap)(n)){let o=n.get("THEN",!0);(0,L.isSeq)(o)&&ot(o,a.then);let r=n.get("ELSE",!0);(0,L.isSeq)(r)&&a.else&&ot(r,a.else)}else if(a.type==="WHILE_LOOP"&&(0,L.isMap)(n)){let o=n.get("DO",!0);(0,L.isSeq)(o)&&ot(o,a.body)}}}var L,se,Us,Hs,mu,Mn=x(()=>{"use strict";Ca();L=require("yaml"),se=require("uuid");Us={lineWidth:120,defaultKeyType:"PLAIN",defaultStringType:"PLAIN"};Hs=1024*1024;mu=new Set(["action","intent","desc","locator","xpath","use_pure_vision"])});var Ks,zs=x(()=>{"use strict";Mn();Ks=require("yaml")});var In=x(()=>{"use strict"});var Vs=x(()=>{"use strict";Mn();In()});var Xs=x(()=>{"use strict";In()});var fu,Ys=x(()=>{"use strict";fu=require("uuid")});var We,Js=x(()=>{"use strict";We=(e=>(e.DRAFT="DRAFT",e.STEP="STEP",e.ACTION="ACTION",e.IF_ELSE="IF_ELSE",e.WHILE_LOOP="WHILE_LOOP",e))(We||{})});var Pn=x(()=>{"use strict"});var qs=x(()=>{"use strict";Pn()});var Zs,bu,Qs,el,mi,yu,xu,tl=x(()=>{"use strict";Zs=112,bu=1080-Zs,Qs={"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"}},el={desktop:["Desktop Chrome","Desktop Chrome Medium Resolution","Desktop Chrome (Branded)","Desktop Chrome Medium Resolution (Branded)","Desktop Edge (Branded)","Desktop Edge Medium Resolution (Branded)","Desktop Safari"],mobile:["iPhone 15 Pro Max","iPhone 15 Pro","iPhone 15 Plus","iPhone 15","iPhone 14 Pro Max","iPhone 14 Pro","iPhone 14 Plus","iPhone 14","iPhone 13 Pro Max","iPhone 13 Pro","iPhone 13","iPhone 13 Mini","iPhone 12 Pro Max","iPhone 12 Pro","iPhone 12","iPhone 12 Mini","iPhone 11 Pro Max","iPhone 11 Pro","iPhone 11","iPhone XR","iPhone X","iPhone SE (3rd gen)","iPhone SE","iPhone 8 Plus","iPhone 8","iPhone 7 Plus","iPhone 7","iPhone 6 Plus","iPhone 6","Galaxy S24","Galaxy A55","Galaxy S9+","Galaxy S8","Galaxy S5","Galaxy Note 3","Galaxy Note II","Galaxy S III","Pixel 7","Pixel 5","Pixel 4a (5G)","Pixel 4","Pixel 3","Pixel 2 XL","Pixel 2","Nexus 6P","Nexus 6","Nexus 5X","Nexus 5","Nexus 4","Moto G4","LG Optimus L70","Microsoft Lumia 950","Microsoft Lumia 550","Nokia Lumia 520","Nokia N9","BlackBerry Z30"]},mi=(e,t=!1)=>{let i=["chromium"];return t&&i.push("webkit"),el[e].map(n=>Qs[n]).filter(n=>n.defaultBrowserType&&i.includes(n.defaultBrowserType))},yu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile")}},xu={desktop:{label:"Desktop",type:"desktop",devices:mi("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:mi("mobile",!0)}}});var il=x(()=>{"use strict"});var nl=x(()=>{"use strict"});var al=x(()=>{"use strict"});var ol=x(()=>{"use strict"});var rl=x(()=>{"use strict"});var sl=x(()=>{"use strict"});var ll=x(()=>{"use strict"});var cl=x(()=>{"use strict";Pn()});var rt=x(()=>{"use strict";zs();Vs();Mn();Ca();Xs();Ys();In();Js();qs();tl();il();nl();al();ol();rl();sl();ll();cl();Pn()});function Eu(e){let t=e.frame_path;return!t||t.length===0?"page":`page.frameLocator('${t[0]}')`}function Tu(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 ml(e){let t=Eu(e),i=e.locator;if(typeof i=="string"&&i.trim())return i=i.trim(),i.endsWith("first()")?`${t}.${i}`:`${t}.${i}.first()`;let n=Tu(e);if(n){let a=JSON.stringify(n);return`${t}.locator(${a}).first()`}return null}function $(e,t){te.set(e,t)}function Ue(e,t,i=[]){let n=[...i];return t.locator?n.push(`locator: ${JSON.stringify(t.locator)}`):t.xpath&&n.push(`xpath: ${JSON.stringify(t.xpath)}`),t.frame_path&&t.frame_path.length>0&&n.push(`frame_path: ${JSON.stringify(t.frame_path)}`),n.length===0?[`await agent.execAction("${e}", page, {});`]:[`await agent.execAction("${e}", page, {`,...n.map(a=>` ${a},`),"});"]}function dl(e){let t=e.functionName;if(!t)return null;let i=Array.isArray(e.args)?e.args.map(String):[];if(i.length===0)return`await ${t}()`;let n=["page","testContext","request","agent"],a=["undefined","null","true","false"],o=i.map(r=>n.includes(r)||a.includes(r)||/^-?\d+(\.\d+)?$/.test(r)?r:r.startsWith("$")?`agent.agentServices.readVariable('${r.substring(1)}')`:`"${r}"`);return`await ${t}(${o.join(", ")})`}function gl(e,t,i){let n={expandingPaths:new Set([(0,lt.resolve)(t)]),depth:0,referencedPaths:new Set,basePath:i},a={...e};Array.isArray(a.statements)&&(a.statements=Oe(a.statements,t,n)),Array.isArray(a.teardown)&&(a.teardown=Oe(a.teardown,t,n));for(let o of["beforeAll","afterAll","beforeEach","afterEach"])Array.isArray(a[o])&&(a[o]=Oe(a[o],t,n));return{doc:a,referencedTemplatePaths:Array.from(n.referencedPaths)}}function Oe(e,t,i){let n=[];for(let a of e)if(Au(a)){let o=$u(a,t,i);n.push(o)}else n.push(Mu(a,t,i));return n}function Au(e){return typeof e=="object"&&e!==null&&typeof e.template=="string"}function $u(e,t,i){if(i.depth>=ul)throw new Error(`Template expansion exceeded maximum depth of ${ul}. Check for deeply nested or circular template references.`);let n=(0,lt.resolve)((0,lt.dirname)(t),e.template),a=!(0,Cn.existsSync)(n)&&i.basePath?(0,lt.resolve)(i.basePath,e.template):n;if(i.expandingPaths.has(a))throw new Error(`Circular template reference detected: ${a} is already being expanded. Stack: ${Array.from(i.expandingPaths).join(" \u2192 ")} \u2192 ${a}`);i.referencedPaths.add(a);let o;try{o=(0,Cn.readFileSync)(a,"utf-8")}catch(g){throw new Error(`Failed to read template file: ${a} (referenced from ${t}): ${g.message}`)}let r=(0,pi.parse)(o);if(!r||typeof r!="object")throw new Error(`Invalid template file: ${a} \u2014 expected a YAML object`);let l=r.params||[],s=e.params||{};for(let g of l)if(!(g in s))throw new Error(`Template ${e.template} requires param "${g}" but it was not provided. Required params: [${l.join(", ")}]`);let c=r.statements;if(!Array.isArray(c))throw new Error(`Template ${e.template} must have a "statements" array`);if(Object.keys(s).length>0){let f=(0,pi.stringify)(c);for(let[b,p]of Object.entries(s))f=f.split(`<<${b}>>`).join(String(p));c=(0,pi.parse)(f)}let d={expandingPaths:new Set([...i.expandingPaths,a]),depth:i.depth+1,referencedPaths:i.referencedPaths},u=Oe(c,a,d),h={STEP:r.name||e.template.replace(/\.yaml$/,"").split("/").pop()||e.template,template_path:e.template,statements:u};return Object.keys(s).length>0&&(h.template_params=s),h}function Mu(e,t,i){if(typeof e!="object"||e===null)return e;let n={...e};return Array.isArray(n.statements)&&(n.statements=Oe(n.statements,t,i)),Array.isArray(n.THEN)&&(n.THEN=Oe(n.THEN,t,i)),Array.isArray(n.ELSE)&&(n.ELSE=Oe(n.ELSE,t,i)),Array.isArray(n.DO)&&(n.DO=Oe(n.DO,t,i)),n}function wl(e,t,i){let n=(0,gi.parse)(e),a=n?.name,o=n?.tags,r=n?.use;if(n&&(n.name!==void 0||n.tags!==void 0||n.use!==void 0)&&(delete n.name,delete n.tags,delete n.use),n?.suite){if(n.goal||n.statements)throw new fl('YAML file cannot have both "suite" and top-level "goal"/"statements". Use either suite format or single-test format.');return Pu(n,a,o,r,t,i)}return Iu(n,a,o,r,t,i)}function Iu(e,t,i,n,a,o){let r=e?.beforeEach,l=e?.afterEach,s=bl(e?.parameters),c=e?.timeout,d=e?.skip,u=e?.fail,m=e?.only,h=e?.slow,g=e?.settings,f=n;if(g){let v={};g.auto_dismiss_modal!==void 0&&(v.autoDismissModal=!!g.auto_dismiss_modal),g.browser_timezone!==void 0&&g.browser_timezone!==null&&(v.timezoneId=String(g.browser_timezone)),g.browser_language!==void 0&&g.browser_language!==null&&(v.locale=String(g.browser_language)),g.extra_http_headers!==void 0&&g.extra_http_headers!==null&&typeof g.extra_http_headers=="object"&&(v.extraHTTPHeaders=g.extra_http_headers),Object.keys(v).length>0&&(f={...f,...v})}if(e&&(delete e.beforeEach,delete e.afterEach,delete e.parameters,delete e.timeout,delete e.skip,delete e.fail,delete e.only,delete e.slow,delete e.settings),e?.url)throw new fl(`The "url" field is not supported in local YAML tests. Use "base_url: ${e.url}" and add "- URL: /" as the first statement instead.`);e&&!e.goal&&t&&(e.goal=t);let b=[];if(a&&e&&typeof e=="object"){let v=gl(e,a,o);e=v.doc,b=v.referencedTemplatePaths}let p=(0,gi.stringify)(e),y=Te(p);return a&&(st(y.statements??[],a,"main"),y.teardown&&st(y.teardown,a,"teardown")),{testFlow:y,name:t,tags:i,use:f,beforeEach:r,afterEach:l,parameters:s,timeout:c,skip:d,fail:u,only:m,slow:h,referencedTemplatePaths:b}}function Pu(e,t,i,n,a,o){let r=e.suite;if(!Array.isArray(r.tests)||r.tests.length===0)throw new Error('Suite must have a non-empty "tests" array.');let l=r.beforeAll,s=r.afterAll,c=r.beforeEach,d=r.afterEach,u=[],m=r.tests.map(f=>{if(!f.name)throw new Error('Each test in a suite must have a "name" field.');if(!Array.isArray(f.statements)||f.statements.length===0)throw new Error(`Suite test "${f.name}" must have a non-empty "statements" array.`);let b={goal:f.name,statements:f.statements};f.teardown&&(b.teardown=f.teardown);let p=[],y=b;if(a&&typeof b=="object"){let M=gl(b,a,o);y=M.doc,p=M.referencedTemplatePaths,u.push(...p)}let v=(0,gi.stringify)(y),E=Te(v),A=bl(f.parameters);return{testFlow:E,name:f.name,tags:Array.isArray(f.tags)?f.tags:void 0,parameters:A,timeout:f.timeout,skip:f.skip,fail:f.fail,only:f.only,slow:f.slow}}),h=r.base_url,g=h?{...n,baseURL:h}:n;return{suite:{beforeAll:l,afterAll:s,beforeEach:c,afterEach:d,tests:m},name:t,tags:i,use:g,referencedTemplatePaths:u}}function bl(e){if(!(!Array.isArray(e)||e.length===0))return e.map((t,i)=>{if(!t.name)throw new Error(`Parameter set at index ${i} must have a "name" field.`);if(!t.values||typeof t.values!="object")throw new Error(`Parameter set "${t.name}" must have a "values" object.`);return{name:t.name,values:t.values}})}function st(e,t,i){for(let n=0;n<e.length;n++){let a=e[n],o=`${i}.${n}`,r=a.description||"";if(a.uid=Cu(t,o,r),a.type===We.STEP)st(a.statements,t,o);else if(a.type===We.IF_ELSE){let l=a;st(l.then,t,`${o}.then`),l.else&&st(l.else,t,`${o}.else`)}else a.type===We.WHILE_LOOP&&st(a.body,t,`${o}.body`)}}function Cu(e,t,i){let n=(0,pl.createHash)("sha256").update(`${e}:${t}:${i}`).digest("hex");return`${n.slice(0,8)}-${n.slice(8,12)}-${n.slice(12,16)}-${n.slice(16,20)}-${n.slice(20,32)}`}var Su,pl,gi,Cn,lt,pi,hl,te,ul,fl,yl=x(()=>{"use strict";rt();Su=require("yaml");rt();pl=require("crypto"),gi=require("yaml");rt();Cn=require("fs"),lt=require("path"),pi=require("yaml");rt();hl=5e3;te=new Map;$("click",e=>{let t=ml(e);if(!t)return['await agent.execAction("click", page, {});'];let i=e.action_data?.kwargs?.timeout_ms??hl;return[`await ${t}.click({ timeout: ${i} });`]});$("click_element",te.get("click"));$("click_element_by_index",te.get("click"));$("double_click",e=>Ue("double_click",e));$("double_click_on_element",te.get("double_click"));$("right_click",e=>Ue("right_click",e));$("right_click_on_element",te.get("right_click"));$("hover",e=>Ue("hover",e));$("hover_element_by_index",te.get("hover"));$("input_text",e=>{let t=e.action_data?.kwargs?.text??e.action_data?.kwargs?.value??"";return Ue("input_text",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("fill",te.get("input_text"));$("clear_input",e=>Ue("clear_input",e));$("press",e=>{let t=e.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(t)});`]});$("send_keys",te.get("press"));$("send_keys_on_element",e=>{let t=ml(e),i=e.action_data?.kwargs?.keys||"";if(!t)return['await agent.execAction("send_keys_on_element", page, {',` action_data: { kwargs: { keys: ${JSON.stringify(i)} } },`,"});"];let n=e.action_data?.kwargs?.timeout_ms??hl;return[`await ${t}.press(${JSON.stringify(i)}, { timeout: ${n} });`]});$("select_dropdown_option",e=>{let t=e.action_data?.kwargs?.text||e.action_data?.kwargs?.option||"";return Ue("select_dropdown_option",e,[`action_data: { kwargs: { text: ${JSON.stringify(t)} } }`])});$("scroll",e=>{let t=e.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(e.action_data?.kwargs?.num_pages??1)*(t?1:-1)})');`]});$("scroll_down",te.get("scroll"));$("scroll_up",te.get("scroll"));$("scroll_element",te.get("scroll"));$("scroll_to_text",e=>{let t=e.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(t)}, { exact: false }).first().scrollIntoViewIfNeeded();`]});$("scroll_on_element",e=>Ue("scroll_on_element",e,[`action_data: { kwargs: ${JSON.stringify(e.action_data?.kwargs||{})} }`]));$("go_to_url",e=>{let t=e.action_data?.kwargs?.url||"";return e.action_data?.kwargs?.new_tab===!0?['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)}, new_tab: true } },`,"});"]:['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { url: ${JSON.stringify(t)} } },`,"});"]});$("open_tab",te.get("go_to_url"));$("go_back",()=>['await agent.execAction("go_back", page, {});']);$("reload_page",()=>['await agent.execAction("reload_page", page, {});']);$("wait",e=>[`await page.waitForTimeout(${(e.action_data?.kwargs?.seconds||1)*1e3});`]);$("wait_for_page_ready",()=>["await page.waitForLoadState('domcontentloaded');"]);$("verify",(e,t)=>{let i=e.action_data?.kwargs,n=typeof i?.code=="string",a=n?i?.statement||e.action_description:e.action_description||i?.statement;if(n&&a){let r=i.code.split(`
|
|
4302
4302
|
`),l=JSON.stringify(a);return["{ const _t = Date.now(); try {",...r.map(s=>` ${s}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${l}\`);`,"} catch (_e) {",` console.log(\`[VERIFY:JS\u2192AI] JS failed \${((Date.now()-_t)/1000).toFixed(1)}s: (\${_e instanceof Error ? _e.message : String(_e)}), falling back to AI: ${l}\`);`,` await agent.assert(page, ${l}, ${JSON.stringify(t||"")});`,"} }"]}return n?i.code.split(`
|
|
4303
4303
|
`):a?[`await agent.assert(page, ${JSON.stringify(a)}, ${JSON.stringify(t||"")});`]:["// Skipping verify: missing statement or code"]});$("ai_assert",te.get("verify"));$("assert",te.get("verify"));$("ai_action",(e,t)=>{let i=e.action_data?.kwargs?.statement;if(!i)return["// Skipping ai_action: missing statement"];let n=JSON.stringify(i),a=e.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${n}, '${t||""}', ${a});`]});$("ai_step",(e,t)=>{let i=e.action_data?.kwargs?.statement;return i?[`await agent.run(page, ${JSON.stringify(i)}, '${t||""}');`]:["// Skipping ai_step: missing statement"]});$("ai_extract",(e,t)=>{let i=e.action_data?.kwargs?.element_description,n=e.action_data?.kwargs?.variable_name;if(!i||!n)return["// Skipping ai_extract: missing element_description or variable_name"];let a=JSON.stringify(i),o=JSON.stringify(n);return[`await agent.extract(page, ${a}, ${o}, '${t||""}');`]});$("ai_wait_until",(e,t)=>{let i=e.action_data?.kwargs?.condition,n=e.action_data?.kwargs?.timeout_seconds||60;return i?[`await agent.waitUntilCondition(page, ${JSON.stringify(i)}, ${n}, '${t||""}');`]:["// Skipping ai_wait_until: missing condition"]});$("save_variable",e=>{let t=e.action_data?.kwargs?.name||"",i=e.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(t)}, value: ${JSON.stringify(i)} } },`,"});"]});$("js_code",e=>{let t=e.action_data?.kwargs?.code;if(!t)return["// Skipping js_code: missing code"];let i=["{"],n=t.split(`
|
|
4304
4304
|
`);for(let a of n)i.push(` ${a}`);return i.push("}"),i});$("function",(e,t,i)=>{let n=e.action_data?.kwargs||{},a=n.functionName;if(a&&a.includes("#")){let[r,l]=a.split("#");if(r&&l){let s=r.replace(/\.(ts|js|mjs)$/,""),c=`import { ${l} } from '${s}';`;i?.imports?.add(c);let d={...n,functionName:l},u=dl(d);return u?[u.endsWith(";")?u:`${u};`]:["// Skipping function: invalid export pattern"]}}let o=dl(n);return o?[o.endsWith(";")?o:`${o};`]:["// Skipping function: missing functionName"]});$("generate_2fa_code",e=>{let t=e.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(t)} } },`,"});"]});$("upload_file",e=>{let t=e.action_data?.kwargs||{},i=[],n={};return t.paths?n.paths=t.paths:t.path&&(n.path=t.path),t.use_file_input&&(n.use_file_input=!0),i.push(`action_data: { kwargs: ${JSON.stringify(n)} }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("upload_file", page, {',...i.map(a=>` ${a},`),"});"]});$("wait_for_download_complete",e=>['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${e.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]);$("switch_tab",e=>['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${e.action_data?.kwargs?.page_id??e.action_data?.kwargs?.tab_index??0} } },`,"});"]);$("close_tab",e=>{let t=e.action_data?.kwargs?.page_id;return t=t??e.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${t} } },`,"});"]});$("set_date_for_native_date_picker",e=>{let t=e.action_data?.kwargs?.date??"",i=[];return i.push(`action_data: { kwargs: { date: ${JSON.stringify(t)} } }`),e.locator?i.push(`locator: ${JSON.stringify(e.locator)}`):e.xpath&&i.push(`xpath: ${JSON.stringify(e.xpath)}`),e.frame_path&&e.frame_path.length>0&&i.push(`frame_path: ${JSON.stringify(e.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...i.map(n=>` ${n},`),"});"]});$("done",()=>["// Done - no action needed"]);$("js_action",e=>{let t=e.action_data?.kwargs?.code;return t?t.split(`
|
|
4305
|
-
`):["// Skipping js_action: missing code"]});ul=5;fl=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var _l={};Ge(_l,{createTestFlowRouter:()=>Ou});function Be(e){if(!e||e.length===0)return[];let i=(0,ue.stringify)({goal:"_hook",statements:e});return Te(i).statements??[]}async function vl(e){try{let t=await N.readdir(e,{withFileTypes:!0});for(let i of t)if(!(i.name==="node_modules"||i.name.startsWith("."))&&(i.isFile()&&i.name.endsWith(".test.yaml")||i.isDirectory()&&await vl(C.join(e,i.name))))return!0}catch{}return!1}function Nn(e){let t=2166136261;for(let i=0;i<e.length;i++)t^=e.charCodeAt(i),t=Math.imul(t,16777619)>>>0;return t%2147483647+1}async function Nu(e){let t=new Map,i;try{i=await N.readdir(e)}catch(n){if(n.code==="ENOENT")return t;throw n}for(let n of i.filter(a=>a.endsWith(".yaml")))try{let a=C.join(e,n),r=(0,ue.parse)(await N.readFile(a,"utf-8"))?.name??C.basename(n,".yaml");t.set(Nn(r),`templates/${n}`)}catch{}return t}function La(e,t){if(Array.isArray(e))return e.map(o=>La(o,t));if(!e||typeof e!="object")return e;let i=e,n={};for(let[o,r]of Object.entries(i))n[o]=La(r,t);let a=typeof i.reference_id=="number"?i.reference_id:void 0;if(a!==void 0&&typeof n.template_path!="string"){let o=t.get(a);o&&(n.template_path=o,delete n.reference_id)}return n}function Da(e){return Tn({statements:e}).statements}function Ou(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=(0,xl.Router)();function r(){return C.join(n??t,"fixtures")}o.get("/api/files",async(s,c)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,u=C.resolve(d),p=await N.readdir(u,{withFileTypes:!0}),h=[];for(let f of p)if(f.name!=="node_modules"&&!f.name.startsWith("."))if(f.isDirectory()){let b=C.join(u,f.name);await vl(b)&&h.push({name:f.name,type:"directory",path:b})}else f.isFile()&&f.name.endsWith(".test.yaml")&&h.push({name:f.name,type:"file",path:C.join(u,f.name)});h.sort((f,b)=>f.type!==b.type?f.type==="directory"?-1:1:f.name.localeCompare(b.name));let g=C.dirname(u);c.json({dir:u,parent:g!==u?g:null,entries:h,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),c.status(500).json({error:d.message})}});function l(s){if(typeof s=="string"&&s){let c=C.resolve(s);return c.endsWith(".test.yaml")?{filePath:c}:{error:"File must be a .test.yaml file"}}return i?{filePath:i}:{error:"No file specified. Pass ?file= parameter."}}return o.get("/api/test-flow",async(s,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath;try{a?.(u);let p=await N.readFile(u,"utf-8"),h=await N.stat(u),g=Oa(p),f=wl(p,u,n);if(f.suite){let b=f.suite,m={tests:b.tests.map(v=>({name:v.name,statements:v.testFlow.statements??[],teardown:v.testFlow.teardown,skip:v.skip,timeout:v.timeout,fail:v.fail,only:v.only,slow:v.slow})),beforeAll:Be(b.beforeAll),afterAll:Be(b.afterAll),beforeEach:Be(b.beforeEach),afterEach:Be(b.afterEach)},y={version:"1.3.0",baseURL:f.use?.baseURL,testGroup:m};c.json({isSuite:!0,testFlow:y,metadata:g,name:f.name,tags:f.tags,use:f.use,filePath:u,fileName:C.basename(u),lastModified:h.mtimeMs})}else{let b=f.testFlow;$n(p,b),c.json({isSuite:!1,testFlow:b,metadata:g,name:f.name,tags:f.tags,use:f.use,filePath:u,fileName:C.basename(u),lastModified:h.mtimeMs})}}catch(p){if(p.code==="ENOENT")return c.status(404).json({error:`File not found: ${u}`});console.error("[debugger] Error loading test flow:",p),c.status(500).json({error:p.message})}}),o.put("/api/test-flow",async(s,c)=>{try{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath,{testFlow:p,metadata:h}=s.body;if(!p)return c.status(400).json({error:"testFlow is required"});let g=C.join(n??t,"templates"),f=await Nu(g),b=La(p,f),m=An(b,h),y=u+".tmp";await N.writeFile(y,m,"utf-8"),await N.rename(y,u);let v=await N.stat(u);c.json({success:!0,lastModified:v.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),c.status(500).json({error:d.message})}}),o.get("/api/fixtures",async(s,c)=>{try{let d=r();try{let p=(await N.readdir(d,{withFileTypes:!0})).filter(h=>h.isFile()).map(h=>h.name).sort();c.json({files:p,dir:d})}catch(u){if(u.code==="ENOENT")c.json({files:[],dir:d});else throw u}}catch(d){console.error("[debugger] Error listing fixtures:",d),c.status(500).json({error:d.message})}}),o.post("/api/fixtures",async(s,c)=>{try{let d=r();await N.mkdir(d,{recursive:!0});let{name:u,content:p}=s.body;if(!u||!p)return c.status(400).json({error:"name and content are required"});let h=C.basename(u);if(!h)return c.status(400).json({error:"Invalid file name"});let g=C.join(d,h);await N.writeFile(g,Buffer.from(p,"base64")),c.json({fileName:h})}catch(d){console.error("[debugger] Error saving fixture:",d),c.status(500).json({error:d.message})}}),o.get("/api/functions",async(s,c)=>{let d=C.join(n??t,"helpers"),u;try{u=await N.readdir(d)}catch(f){return f.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading helpers dir:",f),c.status(500).json({error:f.message}))}let p=u.filter(f=>/\.(ts|js|mjs)$/.test(f)),h=[],g=1;for(let f of p){let b=await N.readFile(C.join(d,f),"utf-8"),m=/export\s+async\s+function\s+(\w+)\s*(\([^)]*\))/g,y;for(;(y=m.exec(b))!==null;){let[,v,E]=y,A=E.replace(/\s*:\s*[^,)]+/g,"");h.push({id:g++,name:`helpers/${f}#${v}`,description:"",status:"Active",code:`async function ${v}${A} {}`})}}c.json(h)}),o.get("/api/reusable-steps",async(s,c)=>{let d=C.join(n??t,"templates"),u;try{u=await N.readdir(d)}catch(g){return g.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading templates dir:",g),c.status(500).json({error:g.message}))}let p=u.filter(g=>g.endsWith(".yaml")).sort(),h=[];for(let g of p)try{let f=await N.readFile(C.join(d,g),"utf-8"),b=(0,ue.parse)(f);if(!b||typeof b!="object")continue;let m=b.name??C.basename(g,".yaml"),y=b.description??"",v=Be(b.statements);h.push({id:Nn(m),organizationId:"local",name:m,description:y,statements:v})}catch(f){console.error(`[debugger] Error parsing template ${g}:`,f)}c.json(h)}),o.post("/api/reusable-steps/exists/:name",async(s,c)=>{let d=C.join(n??t,"templates"),u=decodeURIComponent(s.params.name).toLowerCase(),p;try{p=await N.readdir(d)}catch(h){return h.code==="ENOENT"?c.json(!1):c.status(500).json({error:h.message})}for(let h of p.filter(g=>g.endsWith(".yaml")))try{let g=await N.readFile(C.join(d,h),"utf-8");if(((0,ue.parse)(g)?.name??C.basename(h,".yaml")).toLowerCase()===u)return c.json(!0)}catch{}c.json(!1)}),o.post("/api/reusable-steps",async(s,c)=>{let d=C.join(n??t,"templates"),{reusableStep:u}=s.body??{};if(!u?.name||!Array.isArray(u.statements))return c.status(400).json({error:"reusableStep.name and reusableStep.statements are required"});await N.mkdir(d,{recursive:!0});let p=u.name.replace(/[/\\:*?"<>|]/g,"-").trim(),h=C.join(d,`${p}.yaml`),g={name:u.name,statements:Da(u.statements)};u.description&&(g.description=u.description),await N.writeFile(h,(0,ue.stringify)(g),"utf-8"),c.json({id:Nn(u.name),organizationId:"local",name:u.name,description:u.description??"",statements:u.statements})}),o.put("/api/reusable-steps/:id/update",async(s,c)=>{let d=parseInt(s.params.id,10),u=C.join(n??t,"templates"),p;try{p=await N.readdir(u)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(g=>g.endsWith(".yaml")))try{let g=C.join(u,h),f=(0,ue.parse)(await N.readFile(g,"utf-8"))??{},b=f.name??C.basename(h,".yaml");if(Nn(b)!==d)continue;let m=s.body??{};return m.description!==void 0&&(f.description=m.description),m.statements!==void 0&&(f.statements=Da(m.statements)),await N.writeFile(g,(0,ue.stringify)(f),"utf-8"),c.json({id:d,organizationId:"local",...f,statements:m.statements!==void 0?m.statements:Be(f.statements)})}catch{}c.status(404).json({error:`Template with id ${d} not found`})}),o.put("/api/templates/:name",async(s,c)=>{let d=C.join(n??t,"templates"),u=decodeURIComponent(s.params.name),p;try{p=await N.readdir(d)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of p.filter(g=>g.endsWith(".yaml")))try{let g=C.join(d,h),f=(0,ue.parse)(await N.readFile(g,"utf-8"))??{};if((f.name??C.basename(h,".yaml"))!==u)continue;let m=s.body??{};return m.name!==void 0&&(f.name=m.name),m.description!==void 0&&(f.description=m.description),m.statements!==void 0&&(f.statements=Da(m.statements)),await N.writeFile(g,(0,ue.stringify)(f),"utf-8"),c.json({organizationId:"local",...f,statements:m.statements!==void 0?m.statements:Be(f.statements)})}catch{}c.status(404).json({error:`Template "${u}" not found`})}),o}var xl,N,C,ue,kl=x(()=>{"use strict";xl=require("express"),N=Q(require("fs/promises"),1),C=Q(require("path"),1);rt();yl();ue=require("yaml")});var El={};Ge(El,{createIntRunnerRouter:()=>Du});function Du(e){let t=(0,Sl.Router)();return t.get("/api/browser-cdp",async(i,n)=>{let a=e.getCdpEndpoint();if(!a)return n.status(404).json({error:"No browser running. Start a debug session first."});n.json({cdpUrl:a})}),t.post("/api/int-runner/create-session",async(i,n)=>{try{let a=i.body.startingUrl||i.body.testFlow?.url||i.body.urlOverride,o=i.body.testFilePath,r=await e.createSession({startingUrl:a,testFilePath:o});n.json({status:"success",sessionId:r.sessionId,searchParams:""})}catch(a){console.error("[debugger] create-session error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/login",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.executeLogin(a.sessionId);n.json(o)}catch(a){console.error("[debugger] login error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/liveview-url",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.startDebug(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] start-debug error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/execute-action",async(i,n)=>{try{let{session:a,actionEntity:o,stepId:r,withSelfHealing:l,stmtUid:s,executionHistory:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let d=await e.executeAction(a.sessionId,o,r,{withSelfHealing:l,stmtUid:s,executionHistory:c});n.json(d)}catch(a){console.error("[debugger] execute-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/run-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:l}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let s=c=>{n.write(`data: ${JSON.stringify(c)}
|
|
4305
|
+
`):["// Skipping js_action: missing code"]});ul=5;fl=class extends Error{constructor(e){super(e),this.name="YamlValidationError"}}});var _l={};Ge(_l,{createTestFlowRouter:()=>Ou});function Be(e){if(!e||e.length===0)return[];let i=(0,ue.stringify)({goal:"_hook",statements:e});return Te(i).statements??[]}async function vl(e){try{let t=await N.readdir(e,{withFileTypes:!0});for(let i of t)if(!(i.name==="node_modules"||i.name.startsWith("."))&&(i.isFile()&&i.name.endsWith(".test.yaml")||i.isDirectory()&&await vl(C.join(e,i.name))))return!0}catch{}return!1}function Nn(e){let t=2166136261;for(let i=0;i<e.length;i++)t^=e.charCodeAt(i),t=Math.imul(t,16777619)>>>0;return t%2147483647+1}async function Nu(e){let t=new Map,i;try{i=await N.readdir(e)}catch(n){if(n.code==="ENOENT")return t;throw n}for(let n of i.filter(a=>a.endsWith(".yaml")))try{let a=C.join(e,n),r=(0,ue.parse)(await N.readFile(a,"utf-8"))?.name??C.basename(n,".yaml");t.set(Nn(r),`templates/${n}`)}catch{}return t}function La(e,t){if(Array.isArray(e))return e.map(o=>La(o,t));if(!e||typeof e!="object")return e;let i=e,n={};for(let[o,r]of Object.entries(i))n[o]=La(r,t);let a=typeof i.reference_id=="number"?i.reference_id:void 0;if(a!==void 0&&typeof n.template_path!="string"){let o=t.get(a);o&&(n.template_path=o,delete n.reference_id)}return n}function Da(e){return Tn({statements:e}).statements}function Ou(e){let{initialDir:t,initialFile:i,projectRoot:n,onFileSelected:a}=e,o=(0,xl.Router)();function r(){return C.join(n??t,"fixtures")}o.get("/api/files",async(s,c)=>{try{let d=typeof s.query.dir=="string"?s.query.dir:t,u=C.resolve(d),m=await N.readdir(u,{withFileTypes:!0}),h=[];for(let f of m)if(f.name!=="node_modules"&&!f.name.startsWith("."))if(f.isDirectory()){let b=C.join(u,f.name);await vl(b)&&h.push({name:f.name,type:"directory",path:b})}else f.isFile()&&f.name.endsWith(".test.yaml")&&h.push({name:f.name,type:"file",path:C.join(u,f.name)});h.sort((f,b)=>f.type!==b.type?f.type==="directory"?-1:1:f.name.localeCompare(b.name));let g=C.dirname(u);c.json({dir:u,parent:g!==u?g:null,entries:h,initialFile:i??null,projectRoot:n??t})}catch(d){console.error("[debugger] Error listing files:",d),c.status(500).json({error:d.message})}});function l(s){if(typeof s=="string"&&s){let c=C.resolve(s);return c.endsWith(".test.yaml")?{filePath:c}:{error:"File must be a .test.yaml file"}}return i?{filePath:i}:{error:"No file specified. Pass ?file= parameter."}}return o.get("/api/test-flow",async(s,c)=>{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath;try{a?.(u);let m=await N.readFile(u,"utf-8"),h=await N.stat(u),g=Oa(m),f=wl(m,u,n);if(f.suite){let b=f.suite,p={tests:b.tests.map(v=>({name:v.name,statements:v.testFlow.statements??[],teardown:v.testFlow.teardown,skip:v.skip,timeout:v.timeout,fail:v.fail,only:v.only,slow:v.slow})),beforeAll:Be(b.beforeAll),afterAll:Be(b.afterAll),beforeEach:Be(b.beforeEach),afterEach:Be(b.afterEach)},y={version:"1.3.0",baseURL:f.use?.baseURL,testGroup:p};c.json({isSuite:!0,testFlow:y,metadata:g,name:f.name,tags:f.tags,use:f.use,filePath:u,fileName:C.basename(u),lastModified:h.mtimeMs})}else{let b=f.testFlow;$n(m,b),c.json({isSuite:!1,testFlow:b,metadata:g,name:f.name,tags:f.tags,use:f.use,filePath:u,fileName:C.basename(u),lastModified:h.mtimeMs})}}catch(m){if(m.code==="ENOENT")return c.status(404).json({error:`File not found: ${u}`});console.error("[debugger] Error loading test flow:",m),c.status(500).json({error:m.message})}}),o.put("/api/test-flow",async(s,c)=>{try{let d=l(s.query.file);if("error"in d)return c.status(400).json({error:d.error});let u=d.filePath,{testFlow:m,metadata:h}=s.body;if(!m)return c.status(400).json({error:"testFlow is required"});let g=C.join(n??t,"templates"),f=await Nu(g),b=La(m,f),p=An(b,h),y=u+".tmp";await N.writeFile(y,p,"utf-8"),await N.rename(y,u);let v=await N.stat(u);c.json({success:!0,lastModified:v.mtimeMs})}catch(d){console.error("[debugger] Error saving test flow:",d),c.status(500).json({error:d.message})}}),o.get("/api/fixtures",async(s,c)=>{try{let d=r();try{let m=(await N.readdir(d,{withFileTypes:!0})).filter(h=>h.isFile()).map(h=>h.name).sort();c.json({files:m,dir:d})}catch(u){if(u.code==="ENOENT")c.json({files:[],dir:d});else throw u}}catch(d){console.error("[debugger] Error listing fixtures:",d),c.status(500).json({error:d.message})}}),o.post("/api/fixtures",async(s,c)=>{try{let d=r();await N.mkdir(d,{recursive:!0});let{name:u,content:m}=s.body;if(!u||!m)return c.status(400).json({error:"name and content are required"});let h=C.basename(u);if(!h)return c.status(400).json({error:"Invalid file name"});let g=C.join(d,h);await N.writeFile(g,Buffer.from(m,"base64")),c.json({fileName:h})}catch(d){console.error("[debugger] Error saving fixture:",d),c.status(500).json({error:d.message})}}),o.get("/api/functions",async(s,c)=>{let d=C.join(n??t,"helpers"),u;try{u=await N.readdir(d)}catch(f){return f.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading helpers dir:",f),c.status(500).json({error:f.message}))}let m=u.filter(f=>/\.(ts|js|mjs)$/.test(f)),h=[],g=1;for(let f of m){let b=await N.readFile(C.join(d,f),"utf-8"),p=/export\s+async\s+function\s+(\w+)\s*(\([^)]*\))/g,y;for(;(y=p.exec(b))!==null;){let[,v,E]=y,A=E.replace(/\s*:\s*[^,)]+/g,"");h.push({id:g++,name:`helpers/${f}#${v}`,description:"",status:"Active",code:`async function ${v}${A} {}`})}}c.json(h)}),o.get("/api/reusable-steps",async(s,c)=>{let d=C.join(n??t,"templates"),u;try{u=await N.readdir(d)}catch(g){return g.code==="ENOENT"?c.json([]):(console.error("[debugger] Error reading templates dir:",g),c.status(500).json({error:g.message}))}let m=u.filter(g=>g.endsWith(".yaml")).sort(),h=[];for(let g of m)try{let f=await N.readFile(C.join(d,g),"utf-8"),b=(0,ue.parse)(f);if(!b||typeof b!="object")continue;let p=b.name??C.basename(g,".yaml"),y=b.description??"",v=Be(b.statements);h.push({id:Nn(p),organizationId:"local",name:p,description:y,statements:v})}catch(f){console.error(`[debugger] Error parsing template ${g}:`,f)}c.json(h)}),o.post("/api/reusable-steps/exists/:name",async(s,c)=>{let d=C.join(n??t,"templates"),u=decodeURIComponent(s.params.name).toLowerCase(),m;try{m=await N.readdir(d)}catch(h){return h.code==="ENOENT"?c.json(!1):c.status(500).json({error:h.message})}for(let h of m.filter(g=>g.endsWith(".yaml")))try{let g=await N.readFile(C.join(d,h),"utf-8");if(((0,ue.parse)(g)?.name??C.basename(h,".yaml")).toLowerCase()===u)return c.json(!0)}catch{}c.json(!1)}),o.post("/api/reusable-steps",async(s,c)=>{let d=C.join(n??t,"templates"),{reusableStep:u}=s.body??{};if(!u?.name||!Array.isArray(u.statements))return c.status(400).json({error:"reusableStep.name and reusableStep.statements are required"});await N.mkdir(d,{recursive:!0});let m=u.name.replace(/[/\\:*?"<>|]/g,"-").trim(),h=C.join(d,`${m}.yaml`),g={name:u.name,statements:Da(u.statements)};u.description&&(g.description=u.description),await N.writeFile(h,(0,ue.stringify)(g),"utf-8"),c.json({id:Nn(u.name),organizationId:"local",name:u.name,description:u.description??"",statements:u.statements})}),o.put("/api/reusable-steps/:id/update",async(s,c)=>{let d=parseInt(s.params.id,10),u=C.join(n??t,"templates"),m;try{m=await N.readdir(u)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of m.filter(g=>g.endsWith(".yaml")))try{let g=C.join(u,h),f=(0,ue.parse)(await N.readFile(g,"utf-8"))??{},b=f.name??C.basename(h,".yaml");if(Nn(b)!==d)continue;let p=s.body??{};return p.description!==void 0&&(f.description=p.description),p.statements!==void 0&&(f.statements=Da(p.statements)),await N.writeFile(g,(0,ue.stringify)(f),"utf-8"),c.json({id:d,organizationId:"local",...f,statements:p.statements!==void 0?p.statements:Be(f.statements)})}catch{}c.status(404).json({error:`Template with id ${d} not found`})}),o.put("/api/templates/:name",async(s,c)=>{let d=C.join(n??t,"templates"),u=decodeURIComponent(s.params.name),m;try{m=await N.readdir(d)}catch(h){return h.code==="ENOENT"?c.status(404).json({error:"Templates directory not found"}):c.status(500).json({error:h.message})}for(let h of m.filter(g=>g.endsWith(".yaml")))try{let g=C.join(d,h),f=(0,ue.parse)(await N.readFile(g,"utf-8"))??{};if((f.name??C.basename(h,".yaml"))!==u)continue;let p=s.body??{};return p.name!==void 0&&(f.name=p.name),p.description!==void 0&&(f.description=p.description),p.statements!==void 0&&(f.statements=Da(p.statements)),await N.writeFile(g,(0,ue.stringify)(f),"utf-8"),c.json({organizationId:"local",...f,statements:p.statements!==void 0?p.statements:Be(f.statements)})}catch{}c.status(404).json({error:`Template "${u}" not found`})}),o}var xl,N,C,ue,kl=x(()=>{"use strict";xl=require("express"),N=Q(require("fs/promises"),1),C=Q(require("path"),1);rt();yl();ue=require("yaml")});var El={};Ge(El,{createIntRunnerRouter:()=>Du});function Du(e){let t=(0,Sl.Router)();return t.get("/api/browser-cdp",async(i,n)=>{let a=e.getCdpEndpoint();if(!a)return n.status(404).json({error:"No browser running. Start a debug session first."});n.json({cdpUrl:a})}),t.post("/api/int-runner/create-session",async(i,n)=>{try{let a=i.body.startingUrl||i.body.testFlow?.url||i.body.urlOverride,o=i.body.testFilePath,r=await e.createSession({startingUrl:a,testFilePath:o});n.json({status:"success",sessionId:r.sessionId,searchParams:""})}catch(a){console.error("[debugger] create-session error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/login",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.executeLogin(a.sessionId);n.json(o)}catch(a){console.error("[debugger] login error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/liveview-url",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({liveviewUrl:"",browserWsUrl:""})}),t.post("/api/int-runner/end-debug",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.json({status:"success"})}),t.post("/api/int-runner/start-debug",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.startDebug(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] start-debug error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/execute-action",async(i,n)=>{try{let{session:a,actionEntity:o,stepId:r,withSelfHealing:l,stmtUid:s,executionHistory:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or actionEntity"});let d=await e.executeAction(a.sessionId,o,r,{withSelfHealing:l,stmtUid:s,executionHistory:c});n.json(d)}catch(a){console.error("[debugger] execute-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/run-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:l}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let s=c=>{n.write(`data: ${JSON.stringify(c)}
|
|
4306
4306
|
|
|
4307
4307
|
`)};try{await e.runStep(a.sessionId,o,r,s,l)}catch(c){s({type:"error",data:{message:c.message}})}finally{n.end()}}),t.post("/api/int-runner/execute-step",async(i,n)=>{let{session:a,statement:o,stepId:r,executionHistory:l,maxSteps:s}=i.body;if(!a?.sessionId||!o)return n.status(400).json({success:!1,message:"Session and statement required"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let c=d=>{n.write(`data: ${JSON.stringify(d)}
|
|
4308
4308
|
|
|
4309
4309
|
`)};try{await e.runStep(a.sessionId,o,r,c,l)}catch(d){c({type:"error",data:{message:d.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-run-step",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=e.stopRunStep(a.sessionId);n.json({status:"success",aborted:o})}catch(a){console.error("[debugger] stop-run-step error:",a),n.status(500).json({status:"error",aborted:!1,details:a.message})}}),t.post("/api/int-runner/evaluate",async(i,n)=>{try{let{session:a,statement:o,stepId:r,executionHistory:l}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let s=await e.evaluate(a.sessionId,o,l);n.json(s)}catch(a){console.error("[debugger] evaluate error:",a),n.status(500).json({status:"error",conclusion:"unknown",explanation:a.message})}}),t.post("/api/int-runner/generate-action",async(i,n)=>{try{let{session:a,statement:o,stepId:r,executionHistory:l,usePureVision:s,includeDebugInfo:c}=i.body;if(!a?.sessionId||!o)return n.status(400).json({status:"error",message:"Missing session or statement"});let d=await e.generateAction(a.sessionId,o,r,{executionHistory:l,usePureVision:s,includeDebugInfo:c});n.json(d)}catch(a){console.error("[debugger] generate-action error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/screenshot",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});let o=await e.takeScreenshot(a.sessionId);n.json({status:"success",...o})}catch(a){console.error("[debugger] screenshot error:",a),n.status(500).json({status:"error",message:a.message})}}),t.post("/api/int-runner/start-recorder",async(i,n)=>{let{session:a,testIdAttributeName:o}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});n.setHeader("Content-Type","text/event-stream"),n.setHeader("Cache-Control","no-cache"),n.setHeader("Connection","keep-alive"),n.flushHeaders();let r=l=>{n.write(`data: ${JSON.stringify(l)}
|
|
4310
4310
|
|
|
4311
|
-
`)};try{await e.startRecorder(a.sessionId,r,o)}catch(l){r({type:"error",data:{message:l.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-recorder",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.stopRecorder(a.sessionId),n.json({status:"success"})}catch(a){console.error("[debugger] stop-recorder error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/terminate-session",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(a.sessionId),n.json({status:"success",details:`Session ${a.sessionId} terminated`})}catch(a){console.error("[debugger] terminate-session error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/session-status",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"timed_out"});n.json({status:"active",remainingSeconds:9999})}),t}var Sl,Tl=x(()=>{"use strict";Sl=require("express")});var Ru={};Ge(Ru,{PlaywrightSandboxService:()=>nt,startPlaywrightDebugServer:()=>Lu});module.exports=Cl(Ru);var Ra=Q(require("express"),1),Fa=Q(require("path"),1);var Ne=Q(require("path"),1),Ms=Q(require("fs/promises"),1),Is=Q(require("os"),1),Ps=require("@playwright/test");U();U();$t();Ye();var Ea=require("zod"),Cd=Ea.z.object({instruction:Ea.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function as(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:Cd,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Xe(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,l=await At(r,a);return{success:l.success,actionEntity:r,message:l.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:l.error}}})}_e();U();var os=require("ai"),rs=require("html-to-text");async function Nd(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/events`,l={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(l.from=i.from_email),i.since)l.begin=Math.floor(i.since/1e3).toString();else{let d=new Date(Date.now()-6e5);l.begin=Math.floor(d.getTime()/1e3).toString()}w.info(`Mailgun params: ${JSON.stringify(l)}`);let s=await fetch(r+"?"+new URLSearchParams(l),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!s.ok){let d=await s.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await s.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let u=(d.storage||{}).url;if(w.info(`message_url: ${u}`),!u){let g=(d.message||{}).headers||{},f=g.subject||"",b=g.from||"",
|
|
4312
|
-
`),
|
|
4313
|
-
`}let E=y.subject||"",A=y.from||"",M=y.to||"",R=y.date||"",W=y["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!v.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:A,to:M,date:R,body:v.trim(),message_id:W})}catch(g){w.warn(`Error fetching raw message: ${g}`)}}if(o.length>0){try{o.sort((u,
|
|
4311
|
+
`)};try{await e.startRecorder(a.sessionId,r,o)}catch(l){r({type:"error",data:{message:l.message}})}finally{n.end()}}),t.post("/api/int-runner/stop-recorder",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.stopRecorder(a.sessionId),n.json({status:"success"})}catch(a){console.error("[debugger] stop-recorder error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/terminate-session",async(i,n)=>{try{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"error",message:"Missing session"});await e.terminateSession(a.sessionId),n.json({status:"success",details:`Session ${a.sessionId} terminated`})}catch(a){console.error("[debugger] terminate-session error:",a),n.status(500).json({status:"error",details:a.message})}}),t.post("/api/int-runner/session-status",async(i,n)=>{let{session:a}=i.body;if(!a?.sessionId)return n.status(400).json({status:"timed_out"});n.json({status:"active",remainingSeconds:9999})}),t}var Sl,Tl=x(()=>{"use strict";Sl=require("express")});var Ru={};Ge(Ru,{PlaywrightSandboxService:()=>nt,startPlaywrightDebugServer:()=>Lu});module.exports=Cl(Ru);var Ra=Q(require("express"),1),Fa=Q(require("path"),1);var Ne=Q(require("path"),1),Ms=Q(require("fs/promises"),1),Is=Q(require("os"),1),Ps=require("@playwright/test");U();U();$t();Ye();var Ea=require("zod"),Cd=Ea.z.object({instruction:Ea.z.string().describe('The instruction of the operation to perform. Can only include one operation. Do not inlcude element indexes just describe the element, e.g. "select the text "Hello, world!" in "Hello, world!""')});function as(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:Cd,usesElementIndex:!1,async execute(t,i){let{instruction:n}=t,a={page:i.page,agentServices:i.agentServices,domService:i.domService},o=await Xe(n,a,{});if(o.status==="error"||!o.actionEntity)return{success:!1,actionEntity:{action_description:n,action_data:{action_name:"perform_accurate_operation",kwargs:{instruction:n}}},error:o.error||"Failed to generate action"};let{actionEntity:r}=o,l=await At(r,a);return{success:l.success,actionEntity:r,message:l.success?`Successfully executed action: ${r.action_data?.action_name}`:void 0,error:l.error}}})}_e();U();var os=require("ai"),rs=require("html-to-text");async function Nd(e,t,i){let{apiKey:n,domain:a}=e;if(!n||!a)throw new Error("Mailgun configuration missing. Please provide apiKey and domain");let o=[];try{let r=`https://api.mailgun.net/v3/${a}/events`,l={event:"accepted",limit:"10",ascending:"yes",recipient:t};if(i.from_email&&(l.from=i.from_email),i.since)l.begin=Math.floor(i.since/1e3).toString();else{let d=new Date(Date.now()-6e5);l.begin=Math.floor(d.getTime()/1e3).toString()}w.info(`Mailgun params: ${JSON.stringify(l)}`);let s=await fetch(r+"?"+new URLSearchParams(l),{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!s.ok){let d=await s.text();throw new Error(`Mailgun events API error: ${d}`)}let c=(await s.json()).items||[];for(let d of c.slice(0,10)){if(d.event!=="accepted")continue;let u=(d.storage||{}).url;if(w.info(`message_url: ${u}`),!u){let g=(d.message||{}).headers||{},f=g.subject||"",b=g.from||"",p=g.to||"";if(i.from_email&&!b.toLowerCase().includes(i.from_email.toLowerCase())||i.to_email&&!p.toLowerCase().includes(i.to_email.toLowerCase())||i.subject&&!f.toLowerCase().includes(i.subject.toLowerCase()))continue;o.push({subject:f,from:b,to:p,date:new Date(d.timestamp*1e3).toUTCString(),body:"Message body not available (Mailgun storage disabled)",message_id:g["message-id"]||""});continue}let m=u.split("/"),h=m[m.length-1];if(w.info(`Storage key: ${h}`),h){let g=`https://api.mailgun.net/v3/domains/${a}/messages/${h}`;try{let f=await fetch(g,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`,Accept:"application/json"}});if(f.ok){let b=await f.json(),p=b.Subject||"",y=b.From||"",v=b.To||"",E=b.Date||"",A=b["Message-Id"]||"";w.info(`subject: ${p}`),w.info(`from_addr: ${y}`),w.info(`to_addr: ${v}`),w.info(`date: ${E}`),w.info(`message_id: ${A}`);let M=b["body-html"]||b["body-plain"]||"";if(M&&M.includes("<")&&(M=(0,rs.convert)(M)),w.info(`Body: ${M.substring(0,200)}...`),i.subject&&!p.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!M.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:p,from:y,to:v,date:E,body:M,message_id:A});continue}else w.warn(`Messages API returned ${f.status}`)}catch(f){w.warn(`Failed to parse JSON response: ${f}`)}}try{let g=await fetch(u,{method:"GET",headers:{Authorization:`Basic ${Buffer.from(`api:${n}`).toString("base64")}`}});if(!g.ok){w.warn(`Could not fetch stored message: ${g.status}`);continue}let f=await g.text();w.info(`Fallback: Raw email length: ${f.length}`);let b=f.split(`
|
|
4312
|
+
`),p=!0,y={},v="";for(let D=0;D<b.length;D++){let X=b[D];if(X.trim()===""&&p){p=!1;continue}if(p){let ee=X.match(/^([^:]+):\s*(.+)$/);ee&&(y[ee[1].toLowerCase()]=ee[2])}else v+=X+`
|
|
4313
|
+
`}let E=y.subject||"",A=y.from||"",M=y.to||"",R=y.date||"",W=y["message-id"]||"";if(i.subject&&!E.toLowerCase().includes(i.subject.toLowerCase())||i.body_contains&&!v.toLowerCase().includes(i.body_contains.toLowerCase()))continue;o.push({subject:E,from:A,to:M,date:R,body:v.trim(),message_id:W})}catch(g){w.warn(`Error fetching raw message: ${g}`)}}if(o.length>0){try{o.sort((u,m)=>{let h=new Date(u.date).getTime();return new Date(m.date).getTime()-h})}catch{}let d=o[0];return w.info(`Returning most recent email: ${d.subject}`),[d]}return o}catch(r){throw w.error(`Error fetching emails from Mailgun: ${r.message}`),new Error(`Error fetching emails from Mailgun: ${r.message}`)}}function Od(e,t){if(e==="verification_code")return`You are analyzing an email to extract an OTP (One-Time Password) or verification code.
|
|
4314
4314
|
|
|
4315
4315
|
Please carefully examine the email content and look for:
|
|
4316
4316
|
1. Numeric codes (usually 4-8 digits)
|
|
@@ -4378,15 +4378,15 @@ ${e}
|
|
|
4378
4378
|
extraction_type: ${t.extraction_type}
|
|
4379
4379
|
filters: ${JSON.stringify(t.filters||{})}
|
|
4380
4380
|
timeout: ${t.timeout||60}
|
|
4381
|
-
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let a=Od(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),l=0;for(w.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){l++,w.info(`Polling attempt ${l}`);try{let c=t.filters||{},d=await Nd(e,t.forward_email,c);if(d.length>0){w.info(`Found ${d.length} emails matching criteria`);let u=[];for(let
|
|
4382
|
-
From: ${
|
|
4383
|
-
To: ${
|
|
4384
|
-
Date: ${
|
|
4381
|
+
polling_interval: 10`);let i=t.timeout||60,n=10;try{if(t.extraction_type==="custom"&&!t.prompt)return{data:void 0,status:"error",message:"Custom prompt is required when extraction_type is custom"};let a=Od(t.extraction_type,t.prompt),o=new Date,r=new Date(o.getTime()+i*1e3),l=0;for(w.info(`Starting email polling for ${i} seconds with ${n}s intervals`);new Date<r;){l++,w.info(`Polling attempt ${l}`);try{let c=t.filters||{},d=await Nd(e,t.forward_email,c);if(d.length>0){w.info(`Found ${d.length} emails matching criteria`);let u=[];for(let m of d){let h=`Subject: ${m.subject}
|
|
4382
|
+
From: ${m.from}
|
|
4383
|
+
To: ${m.to}
|
|
4384
|
+
Date: ${m.date}
|
|
4385
4385
|
|
|
4386
4386
|
Body:
|
|
4387
|
-
${
|
|
4387
|
+
${m.body}`,g=await Dd(h,a,t.model);w.info(`Extracted content: ${g}`),g&&g!=="NOT_FOUND"&&u.push({content:g,email_subject:m.subject,email_from:m.from,email_date:m.date})}if(u.length>0){let m=u[0],h=`$email_${t.extraction_type}`;t.extraction_type==="custom"?h="$email_extracted_content":t.extraction_type==="activation_link"?h="$email_magic_link":t.extraction_type==="verification_code"&&(h="$email_otp_code");let g=(new Date().getTime()-o.getTime())/1e3;return w.info(`Successfully extracted content after ${l} attempts in ${g.toFixed(1)} seconds`),{data:m.content,result_variable:h,status:"success",message:`Successfully extracted content from email: ${m.email_subject.substring(0,50)}... (attempts: ${l})`}}else w.info(`Found emails but no extractable content in attempt ${l}`)}else w.info(`No emails found in attempt ${l}`)}catch(c){w.warn(`Error in polling attempt ${l}: ${c.message}`)}if(new Date(Date.now()+n*1e3)>=r){w.info("Not enough time for another polling attempt");break}w.info(`Waiting ${n} seconds before next attempt...`),await new Promise(c=>setTimeout(c,n*1e3))}let s=(new Date().getTime()-o.getTime())/1e3;return{data:void 0,status:"error",message:`No emails with extractable content found after ${l} attempts over ${s.toFixed(1)} seconds`}}catch(a){return w.error(`Error extracting email content: ${a.message}`),{data:void 0,status:"error",message:`Error extracting email content: ${a.message}`}}}U();ie();var pe=require("zod");function ls(e){switch(e){case"verification_code":return"email_otp_code";case"activation_link":return"email_magic_link";case"custom":return"email_extracted_content";default:return"email_content"}}var cs=class{getMailgunConfig(){let e=K().env||{};if(e.MAILGUN_API_KEY)return{apiKey:e.MAILGUN_API_KEY,domain:e.MAILGUN_DOMAIN||""}}async execute(e,t,i){let n=t.action_data;if(!n)throw new Error("Action data not found");let a=this.getMailgunConfig();if(!a)throw new Error("Mailgun configuration not provided. Please configure MAILGUN_API_KEY and MAILGUN_DOMAIN in SDK config.");let o=n.kwargs,r=i.getModel?.()||"gemini-2.5-pro",l=await ss(a,{model:r,forward_email:o.forward_email,extraction_type:o.extraction_type,prompt:o.prompt,filters:{from_email:o.filter_from_email,to_email:o.filter_to_email,subject:o.filter_subject,body_contains:o.filter_body_contains},timeout:o.timeout});if(l.status==="success"&&l.data){let s=l.result_variable?.replace(/^\$/,"")||ls(o.extraction_type);i.variableStore.set(s,l.data),w.info(`[extract_email_content] Extracted and saved to ${s}`)}else throw new Error(l.message||"Failed to extract email content")}transpile(e){let t=e.action_data?.kwargs||{};return['await agent.execAction("extract_email_content", page, {',` action_data: { kwargs: ${JSON.stringify(t)} },`,"});"]}},Ld=pe.z.object({forward_email:pe.z.string().describe("Email address where emails are forwarded to (Mailgun inbox)"),extraction_type:pe.z.enum(["verification_code","activation_link","custom"]).describe("Type of content to extract: verification_code for OTP codes, activation_link for magic links, custom for custom prompts"),prompt:pe.z.string().optional().describe("Custom extraction prompt (required when extraction_type is custom)"),filter_from_email:pe.z.string().optional().describe("Filter emails by sender address"),filter_to_email:pe.z.string().optional().describe("Filter emails by recipient address"),filter_subject:pe.z.string().optional().describe("Filter emails by subject (partial match)"),filter_body_contains:pe.z.string().optional().describe("Filter emails by body content (partial match)"),timeout:pe.z.number().optional().describe("Timeout in seconds for polling (default: 60)")});function ds(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:Ld,async execute(i,n){let{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}=i,{page:m,agentServices:h}=n;w.info(`[extract_email_content] Extracting ${o} from ${a}`);try{let g={action_description:`Extract ${o} from email`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}}};await t.execute(m,g,h);let f=ls(o);return{success:!0,actionEntity:g,message:`Extracted ${o} and saved to $${f}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:`Extract ${o} from email (failed)`,action_data:{action_name:"extract_email_content",kwargs:{forward_email:a,extraction_type:o,prompt:r,filter_from_email:l,filter_to_email:s,filter_subject:c,filter_body_contains:d,timeout:u}},feedback:g.message}}}}})}Mt();It();Pt();Ct();Ot();Lt();Rt();Ht();Wt();Ut();Bt();jt();Gt();zt();Vt();Xt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();si();var kn=null;async function ge(){if(kn)return kn;let e=(await Promise.resolve().then(()=>(wn(),fn))).default;return kn=new e,kn}async function us(e){let t=await ge(),i=t.getAction("click"),n=t.getAction("hover"),a=t.getAction("right_click"),o=t.getAction("double_click");return Fr(e,i),Pr(e,n),wr(e,a),Gr(e,o),"Click, hover, double-click, right-click, or drag elements"}async function hs(e){let t=await ge(),i=t.getAction("go_to_url"),n=t.getAction("go_back"),a=t.getAction("reload_page");return Mr(e,i),$r(e,n),gr(e,a),"Navigate to URLs, go back, or reload the page"}async function ms(e){let t=await ge(),i=t.getAction("clear_input"),n=t.getAction("input_text"),a=t.getAction("press");return Lr(e,i),Nr(e,n),hr(e,a),"Type text into inputs, clear input values, or press keyboard keys"}async function ps(e){let t=await ge(),i=t.getAction("scroll_on_element"),n=t.getAction("scroll_to_text"),a=t.getAction("scroll");return Yo(e,i),qo(e,n),xr(e,a),"Scroll the page or scroll to specific text/elements"}async function gs(e){let t=await ge(),i=t.getAction("close_tab"),n=t.getAction("switch_tab");return Wr(e,i),ar(e,n),"Switch between browser tabs or close tabs"}async function fs(e){let t=await ge(),i=t.getAction("upload_file"),n=t.getAction("wait_for_download_complete");return cr(e,i),Go(e,n),"Upload files or wait for downloads to complete"}async function ws(e){let t=await ge(),i=t.getAction("get_dropdown_options"),n=t.getAction("select_dropdown_option"),a=t.getAction("set_date_for_native_date_picker");return Er(e,i),er(e,n),ir(e,a),"Get dropdown options, select dropdown values, or set date for native date picker input"}async function bs(e){let t=await ge(),i=t.getAction("wait"),n=t.getAction("save_variable"),a=t.getAction("done");return ur(e,i),yr(e,n),Br(e,a),as(e),"Wait for conditions, save variables, or complete tasks"}async function ys(e){let t=(await ge()).getAction("generate_2fa_code");_r(e,t);let i=new cs;return(await Promise.resolve().then(()=>(wn(),fn))).default.registerAction("extract_email_content",i),ds(e,i),"Generate 2FA codes or extract email/activation codes"}async function xs(e){let t=await ge(),i=t.getAction("verify"),n=t.getAction("ai_extract"),a=t.getAction("ai_wait_until");return Vr(e,i),Yr(e,n),zo(e,a),"Perform AI-powered assertions, extractions, or wait conditions"}ke();var Rd=[us(B),hs(B),ms(B),ps(B),gs(B),fs(B),ws(B),bs(B),xs(B),ys(B)],ax=Promise.all(Rd);dt();di();Ce();li();U();var Ta=require("playwright");var Ts=require("child_process"),As=Q(require("fs"),1),$s=Q(require("path"),1);function qd(e){let t=(0,Ts.execFileSync)("ps",["-axo","pid=,ppid=,args="],{encoding:"utf-8"}),i=[];for(let o of t.split(`
|
|
4388
4388
|
`)){let r=o.trimStart().match(/^(\d+)\s+(\d+)\s+(.*)$/);r&&i.push({pid:parseInt(r[1],10),ppid:parseInt(r[2],10),args:r[3]})}let n=new Set([e]),a=!0;for(;a;){a=!1;for(let o of i)!n.has(o.pid)&&n.has(o.ppid)&&(n.add(o.pid),a=!0)}for(let o of i){if(o.pid===e||!n.has(o.pid)||!/chrome|chromium/i.test(o.args))continue;let r=o.args.match(/--user-data-dir=([^\s]+)/);if(r)return r[1]}return null}async function Zd(e,t){let i=$s.join(e,"DevToolsActivePort"),n=Date.now()+t;for(;Date.now()<n;){try{let a=As.readFileSync(i,"utf-8").trim(),[o,r]=a.split(`
|
|
4389
|
-
`),l=parseInt(o,10);if(Number.isFinite(l)&&l>0&&typeof r=="string"&&r.startsWith("/"))return{port:l,wsPath:r}}catch{}await new Promise(a=>setTimeout(a,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function Aa(e,t=3e4){let i=qd(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:a}=await Zd(i,t);return`ws://127.0.0.1:${n}${a}`}di();var Qd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Qd||{});$t();Fe();$a();ne();di();Ce();U();Ce();U();var Ma=require("otplib"),hv=(0,Ma.createGuardrails)({MIN_SECRET_BYTES:1});var ui=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(ui||{});
|
|
4389
|
+
`),l=parseInt(o,10);if(Number.isFinite(l)&&l>0&&typeof r=="string"&&r.startsWith("/"))return{port:l,wsPath:r}}catch{}await new Promise(a=>setTimeout(a,100))}throw new Error(`Timed out waiting for ${i} \u2014 Chromium never exposed DevTools`)}async function Aa(e,t=3e4){let i=qd(e);if(!i)throw new Error(`No Chromium descendant of pid ${e} with --user-data-dir found. Did you launch with --remote-debugging-port=0 and is the browser still running?`);let{port:n,wsPath:a}=await Zd(i,t);return`ws://127.0.0.1:${n}${a}`}di();var Qd=(e=>(e.Desktop="desktop",e.Mobile="mobile",e))(Qd||{});$t();Fe();$a();ne();di();Ce();U();Ce();U();var Ma=require("otplib"),hv=(0,Ma.createGuardrails)({MIN_SECRET_BYTES:1});var ui=(e=>(e.Started="started",e.Action="action",e.Completion="completion",e.Error="error",e.Aborted="aborted",e.Keepalive="keepalive",e))(ui||{});Ft();U();$t();Ri();Di();yi();Ye();Ti();$i();Ke();Ai();Pi();ft();wt();ke();dt();gt();Xi();Fe();xt();vt();Je();_t();kt();$a();ne();di();Ce();li();_e();mt();ze();pt();Re();ka();Hi();Wi();Ui();Bi();ji();Gi();Ki();zi();Vi();Qi();en();Mt();It();Pt();Ct();Ot();Lt();Rt();Ht();Wt();Ut();Bt();jt();Gt();zt();Vt();Xt();Yt();qt();Zt();ei();ti();ii();ni();ai();oi();ri();Et();si();hn();Ft();z();Le();U();ie();Tt();gn();H();be();var nt=class{page;agent;testDir=process.cwd();projectRoot;sessionId="pw-"+Math.random().toString(36).slice(2,10);abortController=null;recorderStopResolver;recorderEnabled=!1;constructor(t,i,n,a){this.page=t,this.agent=i,this.projectRoot=a,n&&(this.agent._getContext().testDataDir=n)}cdpEndpoint=null;setCdpEndpoint(t){this.cdpEndpoint=t}getCdpEndpoint(){if(this.cdpEndpoint)return this.cdpEndpoint;let t=this.page.context().browser();if(!t)return null;let i=t.wsEndpoint?.();return typeof i=="string"?i:null}async createSession(t){return t?.testFilePath&&(this.testDir=Ne.dirname(t.testFilePath)),{sessionId:this.sessionId}}async executeLogin(t){return{status:"success",details:"Handled by Playwright"}}async ensureBrowser(t){return{page:this.page,liveviewUrl:""}}async startDebug(t){return{sessionId:this.sessionId,liveviewUrl:"",browserWsUrl:""}}async executeAction(t,i,n,a){let o=i.action_data||i.action;if(!o)throw new Error("ActionEntity has no action_data");console.error(`[pw-sandbox] executeAction stepId=${JSON.stringify(n)} action_name=${JSON.stringify(o.action_name)} locator=${JSON.stringify(i.locator)} kwargs=${JSON.stringify(o.kwargs)}`);let r=this.agent.agentServices.validatePage(this.page);if(o.action_name==="js_code"&&n==="prelude"){if(r.url()==="about:blank"){let m=o.kwargs?.code?.match(/PLAYWRIGHT_STARTING_URL \|\| '([^']*)'/)?.[1];m&&await r.goto(m,{waitUntil:"domcontentloaded"})}return{status:"success"}}if(o.action_name==="js_code"&&o.kwargs?.isSync===!0)return this.executeCode(t,o.kwargs.code||"");if(o.action_name==="function"&&o.kwargs?.functionName?.includes("#"))return this.executeFunction(o.kwargs);let l=a?.stmtUid;l&&this.agent.getNewActionEntities().delete(l);let s;if(He.isAiAction(i))await this.agent.execAction(o.action_name,r,i),s={};else{let m=i.action_description||o.action_name,h=!!a?.withSelfHealing&&He.canSelfHeal(i);s=await this.agent.step(r,async()=>{await this.agent.execAction(o.action_name,r,i)},m,n,l,h)}let c=this.agent.getAgentNote(),d=this.agent._getContext()?.variableStore,u={...s,status:"success",testContext:d?d.getAll():void 0};if(c&&(u.details=c),l){let m=this.agent.getNewActionEntities().get(l);if(m){let{element_index:h,...g}=m.action_data?.kwargs||{};u.newActionEntity={...m,action_data:m.action_data?{...m.action_data,kwargs:g}:m.action_data}}}return u}async runStep(t,i,n,a,o){let r=[];this.abortController=new AbortController;try{let l=await this.agent.run(this.agent.agentServices.validatePage(this.page),i,n,{onAction:c=>{r.push(c),a({type:ui.Action,data:{action_entity:c}})}}),s=this.agent._getContext()?.variableStore;return a({type:ui.Completion,data:{success:l?.success??!0,details:l?.details,testContext:s?s.getAll():void 0}}),{success:l?.success??!0,actions:r,details:l?.details}}finally{this.abortController=null}}async executeFunction(t){let i=t.functionName,[n,a]=i.split("#");try{let l=(await import(Ne.isAbsolute(n)?n:Ne.resolve(this.projectRoot??this.testDir,n)))[a];if(typeof l!="function")return{status:"error",details:`Export "${a}" not found or not a function in ${n}`};let c=l.toString().match(/\(([^)]*)\)/),d=c&&c[1].trim()?c[1].split(",").map(y=>y.split(":")[0].trim().replace(/\?$/,"")):[],u=Array.isArray(t.parameterNames)?t.parameterNames.map(String):[],m=Array.isArray(t.parameterValues)?t.parameterValues.map(String):Array.isArray(t.args)?t.args.map(String):[],h={};u.forEach((y,v)=>{let E=y.split(":")[0].trim();h[E]=m[v]??""});let g=["page","agent","request","testContext"],f=this.agent.agentServices.validatePage(this.page),b=d.map(y=>{if(y==="page")return f;if(y==="agent")return this.agent;if(y==="request")return;if(y==="testContext")return this.agent._getContext?.()?.variableStore;let v=h[y]??"";return v.startsWith("$")?this.agent.agentServices.readVariable(v.substring(1)):v}),p=d.length>0?b:m.map(y=>{if(y==="page")return f;if(y==="agent")return this.agent;if(y!=="request")return y==="testContext"?this.agent._getContext?.()?.variableStore:y.startsWith("$")?this.agent.agentServices.readVariable(y.substring(1)):y});return await l(...p),{status:"success"}}catch(o){let r=o instanceof Error?o.message:String(o);return{status:"error",details:`Function call failed: ${i} \u2014 ${r}`}}}async executeCode(t,i){try{return{status:"success",result:await new Function("page","expect","agent",`return (async () => { return (${i}); })();`)(this.agent.agentServices.validatePage(this.page),Ps.expect,this.agent)}}catch(n){return{status:"error",details:n instanceof Error?n.message:String(n)}}}stopRunStep(t){return this.abortController?(this.abortController.abort(),!0):!1}async evaluate(t,i,n){try{let a=await this.agent.evaluate(this.agent.agentServices.validatePage(this.page),i);return{status:"success",conclusion:a?"true":"false",explanation:a?`Condition met: ${i}`:`Condition not met: ${i}`}}catch(a){return{status:"error",conclusion:"unknown",explanation:a.message}}}async generateAction(t,i,n,a){let o=await this.agent.generate(this.agent.agentServices.validatePage(this.page),i,n,a?.usePureVision),r=o.actions?.[0];return r?{status:"success",action:r,explanation:o.details,debugInfo:o.debugInfo,completes_instruction:o.success}:{status:"error",explanation:o.details||"Failed to generate action",debugInfo:o.debugInfo}}async takeScreenshot(t){let i=await this.agent.agentServices.validatePage(this.page).screenshot(),n=Ne.join(Is.tmpdir(),`shiplight-screenshot-${Date.now()}.png`);return await Ms.writeFile(n,i),{screenshot:i.toString("base64"),screenshotPath:n}}async startRecorder(t,i,n){let a=this.page.context(),o=new Promise(l=>{this.recorderStopResolver=l}),r={actionAdded:(l,s,c)=>{i({type:"actionAdded",action:s.action,code:c,timestamp:Date.now()})},actionUpdated:(l,s,c)=>{i({type:"actionUpdated",action:s.action,code:c,timestamp:Date.now()})},signalAdded:(l,s)=>{i({type:"signal",signal:s.signal,timestamp:Date.now()})}};if(this.recorderEnabled)a._onRecorderEventSink=r,await this.page.evaluate(()=>window.__pw_recorderSetMode?.("recording")).catch(()=>{});else{let l="x-pw-overlay { display: none !important; }";await a.addInitScript(`(() => {
|
|
4390
4390
|
const orig = Element.prototype.attachShadow;
|
|
4391
4391
|
Element.prototype.attachShadow = function(init) {
|
|
4392
4392
|
const shadow = orig.call(this, init);
|