@shiplightai/mcp 0.1.56 → 0.1.57
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/{agentHelpers-CBXDLHMV-FEWOZV7Q.js → agentHelpers-BWIZZVR4-6SA75OLH.js} +1 -1
- package/dist/{agentLogin-5KZL6HVN-IMIVPSCB.js → agentLogin-LDQHQBLK-H5M326VA.js} +1 -1
- package/dist/{chunk-KLNLVLWZ.js → chunk-F2VF6EGN.js} +13 -13
- package/dist/{chunk-VGJ5XDNL.js → chunk-GTYDC5DF.js} +2 -2
- package/dist/{chunk-JCRZBZKB.js → chunk-JTLVXRYI.js} +332 -435
- package/dist/chunk-KG3IU2VV.js +4009 -0
- package/dist/{chunk-D7CZ6CG6.js → chunk-R4J6G5GI.js} +2 -2
- package/dist/{chunk-XJBTNDI5.js → chunk-RONU7WUE.js} +3 -3
- package/dist/dist-CT5TSYOS.js +4 -0
- package/dist/{dist-FZZSZ2MI.js → dist-I44QS3SL.js} +1 -1
- package/dist/{handler-NCYONWSZ-FHSI4NBE.js → handler-7JPASJ4Y-KWA27ONH.js} +1 -1
- package/dist/index.js +2 -2
- package/dist/{relayBrowserCache-QL6LD4JJ-AD6FFB2L.js → relayBrowserCache-QL6LD4JJ-7EUDH6YT.js} +1 -1
- package/dist/server-HRQ65FLP.js +22 -0
- package/dist/{task-YAUXJI3I-PMEHHFOD.js → task-TMX75KZR-MX73VAM2.js} +1 -1
- package/package.json +1 -1
- package/dist/chunk-MINNFENX.js +0 -3999
- package/dist/dist-VKTI46EV.js +0 -4
- package/dist/server-4Y6IT6HL.js +0 -22
|
@@ -139,7 +139,7 @@ ${t.comment}`:t.comment}this.doc.range[2]=t.offset;break}default:this.errors.pus
|
|
|
139
139
|
`)+1;for(;t!==0;)this.onNewLine(this.offset+t),t=this.source.indexOf(`
|
|
140
140
|
`,t)+1}yield*this.pop();break;default:yield*this.pop(),yield*this.step()}}*blockMap(e){let t=e.items[e.items.length-1];switch(this.type){case"newline":if(this.onKeyLine=!1,t.value){let s="end"in t.value?t.value.end:void 0;(Array.isArray(s)?s[s.length-1]:void 0)?.type==="comment"?s?.push(this.sourceToken):e.items.push({start:[this.sourceToken]})}else t.sep?t.sep.push(this.sourceToken):t.start.push(this.sourceToken);return;case"space":case"comment":if(t.value)e.items.push({start:[this.sourceToken]});else if(t.sep)t.sep.push(this.sourceToken);else{if(this.atIndentedComment(t.start,e.indent)){let s=e.items[e.items.length-2]?.value?.end;if(Array.isArray(s)){Array.prototype.push.apply(s,t.start),s.push(this.sourceToken),e.items.pop();return}}t.start.push(this.sourceToken)}return}if(this.indent>=e.indent){let s=!this.onKeyLine&&this.indent===e.indent,a=s&&(t.sep||t.explicitKey)&&this.type!=="seq-item-ind",l=[];if(a&&t.sep&&!t.value){let h=[];for(let p=0;p<t.sep.length;++p){let b=t.sep[p];switch(b.type){case"newline":h.push(p);break;case"space":break;case"comment":b.indent>e.indent&&(h.length=0);break;default:h.length=0}}h.length>=2&&(l=t.sep.splice(h[1]))}switch(this.type){case"anchor":case"tag":a||t.value?(l.push(this.sourceToken),e.items.push({start:l}),this.onKeyLine=!0):t.sep?t.sep.push(this.sourceToken):t.start.push(this.sourceToken);return;case"explicit-key-ind":!t.sep&&!t.explicitKey?(t.start.push(this.sourceToken),t.explicitKey=!0):a||t.value?(l.push(this.sourceToken),e.items.push({start:l,explicitKey:!0})):this.stack.push({type:"block-map",offset:this.offset,indent:this.indent,items:[{start:[this.sourceToken],explicitKey:!0}]}),this.onKeyLine=!0;return;case"map-value-ind":if(t.explicitKey)if(t.sep)if(t.value)e.items.push({start:[],key:null,sep:[this.sourceToken]});else if(y(t.sep,"map-value-ind"))this.stack.push({type:"block-map",offset:this.offset,indent:this.indent,items:[{start:l,key:null,sep:[this.sourceToken]}]});else if(c(t.key)&&!y(t.sep,"newline")){let h=o(t.start),p=t.key,b=t.sep;b.push(this.sourceToken),delete t.key,delete t.sep,this.stack.push({type:"block-map",offset:this.offset,indent:this.indent,items:[{start:h,key:p,sep:b}]})}else l.length>0?t.sep=t.sep.concat(l,this.sourceToken):t.sep.push(this.sourceToken);else if(y(t.start,"newline"))Object.assign(t,{key:null,sep:[this.sourceToken]});else{let h=o(t.start);this.stack.push({type:"block-map",offset:this.offset,indent:this.indent,items:[{start:h,key:null,sep:[this.sourceToken]}]})}else t.sep?t.value||a?e.items.push({start:l,key:null,sep:[this.sourceToken]}):y(t.sep,"map-value-ind")?this.stack.push({type:"block-map",offset:this.offset,indent:this.indent,items:[{start:[],key:null,sep:[this.sourceToken]}]}):t.sep.push(this.sourceToken):Object.assign(t,{key:null,sep:[this.sourceToken]});this.onKeyLine=!0;return;case"alias":case"scalar":case"single-quoted-scalar":case"double-quoted-scalar":{let h=this.flowScalar(this.type);a||t.value?(e.items.push({start:l,key:h,sep:[]}),this.onKeyLine=!0):t.sep?this.stack.push(h):(Object.assign(t,{key:h,sep:[]}),this.onKeyLine=!0);return}default:{let h=this.startBlockValue(e);if(h){if(h.type==="block-seq"){if(!t.explicitKey&&t.sep&&!y(t.sep,"newline")){yield*this.pop({type:"error",offset:this.offset,message:"Unexpected block-seq-ind on same line with key",source:this.source});return}}else s&&e.items.push({start:l});this.stack.push(h);return}}}}yield*this.pop(),yield*this.step()}*blockSequence(e){let t=e.items[e.items.length-1];switch(this.type){case"newline":if(t.value){let s="end"in t.value?t.value.end:void 0;(Array.isArray(s)?s[s.length-1]:void 0)?.type==="comment"?s?.push(this.sourceToken):e.items.push({start:[this.sourceToken]})}else t.start.push(this.sourceToken);return;case"space":case"comment":if(t.value)e.items.push({start:[this.sourceToken]});else{if(this.atIndentedComment(t.start,e.indent)){let s=e.items[e.items.length-2]?.value?.end;if(Array.isArray(s)){Array.prototype.push.apply(s,t.start),s.push(this.sourceToken),e.items.pop();return}}t.start.push(this.sourceToken)}return;case"anchor":case"tag":if(t.value||this.indent<=e.indent)break;t.start.push(this.sourceToken);return;case"seq-item-ind":if(this.indent!==e.indent)break;t.value||y(t.start,"seq-item-ind")?e.items.push({start:[this.sourceToken]}):t.start.push(this.sourceToken);return}if(this.indent>e.indent){let s=this.startBlockValue(e);if(s){this.stack.push(s);return}}yield*this.pop(),yield*this.step()}*flowCollection(e){let t=e.items[e.items.length-1];if(this.type==="flow-error-end"){let s;do yield*this.pop(),s=this.peek(1);while(s&&s.type==="flow-collection")}else if(e.end.length===0){switch(this.type){case"comma":case"explicit-key-ind":!t||t.sep?e.items.push({start:[this.sourceToken]}):t.start.push(this.sourceToken);return;case"map-value-ind":!t||t.value?e.items.push({start:[],key:null,sep:[this.sourceToken]}):t.sep?t.sep.push(this.sourceToken):Object.assign(t,{key:null,sep:[this.sourceToken]});return;case"space":case"comment":case"newline":case"anchor":case"tag":!t||t.value?e.items.push({start:[this.sourceToken]}):t.sep?t.sep.push(this.sourceToken):t.start.push(this.sourceToken);return;case"alias":case"scalar":case"single-quoted-scalar":case"double-quoted-scalar":{let a=this.flowScalar(this.type);!t||t.value?e.items.push({start:[],key:a,sep:[]}):t.sep?this.stack.push(a):Object.assign(t,{key:a,sep:[]});return}case"flow-map-end":case"flow-seq-end":e.end.push(this.sourceToken);return}let s=this.startBlockValue(e);s?this.stack.push(s):(yield*this.pop(),yield*this.step())}else{let s=this.peek(2);if(s.type==="block-map"&&(this.type==="map-value-ind"&&s.indent===e.indent||this.type==="newline"&&!s.items[s.items.length-1].sep))yield*this.pop(),yield*this.step();else if(this.type==="map-value-ind"&&s.type!=="flow-collection"){let a=n(s),l=o(a);i(e);let h=e.end.splice(1,e.end.length);h.push(this.sourceToken);let p={type:"block-map",offset:e.offset,indent:e.indent,items:[{start:l,key:e,sep:h}]};this.onKeyLine=!0,this.stack[this.stack.length-1]=p}else yield*this.lineEnd(e)}}flowScalar(e){if(this.onNewLine){let t=this.source.indexOf(`
|
|
141
141
|
`)+1;for(;t!==0;)this.onNewLine(this.offset+t),t=this.source.indexOf(`
|
|
142
|
-
`,t)+1}return{type:e,offset:this.offset,indent:this.indent,source:this.source}}startBlockValue(e){switch(this.type){case"alias":case"scalar":case"single-quoted-scalar":case"double-quoted-scalar":return this.flowScalar(this.type);case"block-scalar-header":return{type:"block-scalar",offset:this.offset,indent:this.indent,props:[this.sourceToken],source:""};case"flow-map-start":case"flow-seq-start":return{type:"flow-collection",offset:this.offset,indent:this.indent,start:this.sourceToken,items:[],end:[]};case"seq-item-ind":return{type:"block-seq",offset:this.offset,indent:this.indent,items:[{start:[this.sourceToken]}]};case"explicit-key-ind":{this.onKeyLine=!0;let t=n(e),s=o(t);return s.push(this.sourceToken),{type:"block-map",offset:this.offset,indent:this.indent,items:[{start:s,explicitKey:!0}]}}case"map-value-ind":{this.onKeyLine=!0;let t=n(e),s=o(t);return{type:"block-map",offset:this.offset,indent:this.indent,items:[{start:s,key:null,sep:[this.sourceToken]}]}}}return null}atIndentedComment(e,t){return this.type!=="comment"||this.indent<=t?!1:e.every(s=>s.type==="newline"||s.type==="space")}*documentEnd(e){this.type!=="doc-mode"&&(e.end?e.end.push(this.sourceToken):e.end=[this.sourceToken],this.type==="newline"&&(yield*this.pop()))}*lineEnd(e){switch(this.type){case"comma":case"doc-start":case"doc-end":case"flow-seq-end":case"flow-map-end":case"map-value-ind":yield*this.pop(),yield*this.step();break;case"newline":this.onKeyLine=!1;case"space":case"comment":default:e.end?e.end.push(this.sourceToken):e.end=[this.sourceToken],this.type==="newline"&&(yield*this.pop())}}};f.Parser=r}),xt=E(f=>{"use strict";var g=et(),d=fe(),m=de(),y=Ke(),u=C(),c=it(),n=st();function o(s){let a=s.prettyErrors!==!1;return{lineCounter:s.lineCounter||a&&new c.LineCounter||null,prettyErrors:a}}function i(s,a={}){let{lineCounter:l,prettyErrors:h}=o(a),p=new n.Parser(l?.addNewLine),b=new g.Composer(a),w=Array.from(b.compose(p.parse(s)));if(h&&l)for(let k of w)k.errors.forEach(m.prettifyError(s,l)),k.warnings.forEach(m.prettifyError(s,l));return w.length>0?w:Object.assign([],{empty:!0},b.streamInfo())}function r(s,a={}){let{lineCounter:l,prettyErrors:h}=o(a),p=new n.Parser(l?.addNewLine),b=new g.Composer(a),w=null;for(let k of b.compose(p.parse(s),!0,s.length))if(!w)w=k;else if(w.options.logLevel!=="silent"){w.errors.push(new m.YAMLParseError(k.range.slice(0,2),"MULTIPLE_DOCS","Source contains multiple documents; please use YAML.parseAllDocuments()"));break}return h&&l&&(w.errors.forEach(m.prettifyError(s,l)),w.warnings.forEach(m.prettifyError(s,l))),w}function e(s,a,l){let h;typeof a=="function"?h=a:l===void 0&&a&&typeof a=="object"&&(l=a);let p=r(s,l);if(!p)return null;if(p.warnings.forEach(b=>y.warn(p.options.logLevel,b)),p.errors.length>0){if(p.options.logLevel!=="silent")throw p.errors[0];p.errors=[]}return p.toJS(Object.assign({reviver:h},l))}function t(s,a,l){let h=null;if(typeof a=="function"||Array.isArray(a)?h=a:l===void 0&&a&&(l=a),typeof l=="string"&&(l=l.length),typeof l=="number"){let p=Math.round(l);l=p<1?void 0:p>8?{indent:8}:{indent:p}}if(s===void 0){let{keepUndefined:p}=l??a??{};if(!p)return}return u.isDocument(s)&&!h?s.toString(l):new d.Document(s,h,l).toString(l)}f.parse=e,f.parseAllDocuments=i,f.parseDocument=r,f.stringify=t}),rt=E(f=>{"use strict";var g=et(),d=fe(),m=Ve(),y=de(),u=oe(),c=C(),n=V(),o=D(),i=z(),r=Y(),e=Pe(),t=tt(),s=it(),a=st(),l=xt(),h=ne();f.Composer=g.Composer,f.Document=d.Document,f.Schema=m.Schema,f.YAMLError=y.YAMLError,f.YAMLParseError=y.YAMLParseError,f.YAMLWarning=y.YAMLWarning,f.Alias=u.Alias,f.isAlias=c.isAlias,f.isCollection=c.isCollection,f.isDocument=c.isDocument,f.isMap=c.isMap,f.isNode=c.isNode,f.isPair=c.isPair,f.isScalar=c.isScalar,f.isSeq=c.isSeq,f.Pair=n.Pair,f.Scalar=o.Scalar,f.YAMLMap=i.YAMLMap,f.YAMLSeq=r.YAMLSeq,f.CST=e,f.Lexer=t.Lexer,f.LineCounter=s.LineCounter,f.Parser=a.Parser,f.parse=l.parse,f.parseAllDocuments=l.parseAllDocuments,f.parseDocument=l.parseDocument,f.stringify=l.stringify,f.visit=h.visit,f.visitAsync=h.visitAsync}),ci=ye(rt(),1),ui=ye(rt(),1);function fi(f,g){if(!f||typeof f!="string")return f;let d=g instanceof Map?Object.fromEntries(g):g,m=u=>{let c=u.startsWith("$")?u.slice(1):u,n=d[c]??d[`$${c}`];return n!=null?String(n):void 0},y=f;return y=y.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(u,c)=>{let n=m(c.trim());return n!==void 0?n:u}),y=y.replace(/<secret>\$?([\w-]+)<\/secret>/g,(u,c)=>{let n=m(c);return n!==void 0?n:u}),y=y.replace(/\$\{([^}]+)\}/g,(u,c)=>{let n=m(c.trim());return n!==void 0?n:u}),y=y.replace(/\$([a-zA-Z_]\w*)/g,(u,c)=>{let n=m(c);return n!==void 0?n:u}),y}var Ct="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",nt=112,It=1920,Kt=1080,Bt=1920,$t=1080-nt,_t=1280,Dt=720,Ft=500,Gt=500,se="Desktop Chrome",jt=(f=>(f.Chromium="chromium",f.Firefox="firefox",f.Webkit="webkit",f))(jt||{}),ot={"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"}},Wt={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"]},re=(f,g=!1)=>{let d=["chromium"];return g&&d.push("webkit"),Wt[f].map(m=>ot[m]).filter(m=>m.defaultBrowserType&&d.includes(m.defaultBrowserType))},Ee=f=>ot[f],di={desktop:{label:"Desktop",type:"desktop",devices:re("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:re("mobile")}},pi={desktop:{label:"Desktop",type:"desktop",devices:re("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:re("mobile",!0)}},at=(f,g=!1)=>{let d={userAgent:Ct,viewport:{width:Bt,height:$t},isMobile:!1,hasTouch:!1};if(!f||f===se)return d;let m=Ee(f);if(!m)return d;let{width:y,height:u}=m.viewport,c=Math.max(Ft/y,1),n=Math.max(Gt/u,1),o=Math.max(c,n),i={width:Math.round(y*o),height:Math.round(u*o)};return{userAgent:m.userAgent,viewport:g?i:m.viewport,isMobile:m.isMobile,hasTouch:m.hasTouch}},mi=f=>{let g={width:It,height:Kt};if(!f||f===se)return g;let d=at(f);return d.viewport?{width:d.viewport.width,height:d.viewport.height+nt}:g},gi=f=>{let g={width:_t,height:Dt};if(!f||f===se)return g;let d=at(f);return d.viewport?{width:d.viewport.width,height:d.viewport.height}:g},yi=f=>!f||f===se?void 0:Ee(f)?.channel,bi=f=>!f||f===se?"chromium":Ee(f)?.defaultBrowserType??"chromium",qt=(f=>(f.PASSWORD="password",f.OAUTH2="oauth2",f.SSO="sso",f.API="api",f))(qt||{}),Ut=(f=>(f.SMS="sms",f.EMAIL="email",f.TOTP="totp",f))(Ut||{}),wi=class lt{constructor(){ge(this,"data",{}),ge(this,"sensitive",new Set)}get(g){return this.data[g]}set(g,d,m=!1){this.data[g]=d,m?this.sensitive.add(g):this.sensitive.has(g)&&this.sensitive.delete(g)}getAll(){return{...this.data}}isSensitive(g){return this.sensitive.has(g)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(g){return this.sensitive.delete(g),delete this.data[g]}clear(){this.data={},this.sensitive.clear()}has(g){return g in this.data}get size(){return Object.keys(this.data).length}merge(g){for(let[d,m]of Object.entries(g.getAll()))this.set(d,m,g.isSensitive(d))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(g){let d=new lt;if(g.data){let m=new Set(g.sensitiveKeys||[]);for(let[y,u]of Object.entries(g.data))d.set(y,u,m.has(y))}return d}},Rt=P.enum(["JS_CODE","AI_MODE"]),Oe=P.object({type:Rt,expression:P.string()}),Ht=P.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Q=P.object({uid:P.string(),type:Ht}),Vt=P.object({action_data:P.object({action_name:P.string(),kwargs:P.record(P.any()).optional(),args:P.array(P.any()).optional()}),action_description:P.string().optional(),url:P.string().optional(),xpath:P.string().nullable().optional(),locator:P.string().nullable().optional(),css_selector:P.string().nullable().optional(),unique_selector:P.string().nullable().optional(),element_index:P.number().nullable().optional(),frame_path:P.array(P.any()).optional(),artifacts:P.record(P.any()).optional(),feedback:P.string().optional(),original_browser_use_action:P.any().optional()}).passthrough(),zt=Q.extend({type:P.literal("DRAFT"),description:P.string()}),Yt=Q.extend({type:P.literal("ACTION"),description:P.string(),action_entity:Vt.optional(),locator:P.string().optional(),use_pure_vision:P.boolean().optional()}),q=P.lazy(()=>P.union([zt,Yt,Q.extend({type:P.literal("STEP"),description:P.string().optional().default(""),statements:P.array(q),reference_id:P.number().optional()}),Q.extend({type:P.literal("IF_ELSE"),description:P.string().optional(),condition:Oe,then:P.array(q),else:P.array(q).optional()}),Q.extend({type:P.literal("WHILE_LOOP"),description:P.string().optional(),condition:Oe,body:P.array(q),timeout_ms:P.number().optional()})])),Xt=P.object({name:P.string(),statements:P.array(q),teardown:P.array(q).optional(),skip:P.union([P.boolean(),P.string()]).optional(),timeout:P.number().optional(),fail:P.union([P.boolean(),P.string()]).optional(),only:P.boolean().optional(),slow:P.boolean().optional()}),Jt=P.object({tests:P.array(Xt).min(1),beforeAll:P.array(q).optional(),afterAll:P.array(q).optional(),beforeEach:P.array(q).optional(),afterEach:P.array(q).optional()}),vi=P.object({version:P.string().optional(),goal:P.string().optional(),url:P.string().optional(),baseURL:P.string().optional(),final_feedback:P.string().optional(),completed:P.boolean().optional(),success:P.boolean().optional(),statements:P.array(q).optional(),teardown:P.array(q).optional(),last_modified_at:P.string().optional(),testGroup:Jt.optional()}).refine(f=>f.testGroup!==void 0?f.goal===void 0&&(f.statements===void 0||f.statements.length===0):f.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),ki=1024*1024,Qt=5e3,Zt=1e4;async function xe(f,g){let d=Object.getPrototypeOf(async()=>{}).constructor,m=`
|
|
142
|
+
`,t)+1}return{type:e,offset:this.offset,indent:this.indent,source:this.source}}startBlockValue(e){switch(this.type){case"alias":case"scalar":case"single-quoted-scalar":case"double-quoted-scalar":return this.flowScalar(this.type);case"block-scalar-header":return{type:"block-scalar",offset:this.offset,indent:this.indent,props:[this.sourceToken],source:""};case"flow-map-start":case"flow-seq-start":return{type:"flow-collection",offset:this.offset,indent:this.indent,start:this.sourceToken,items:[],end:[]};case"seq-item-ind":return{type:"block-seq",offset:this.offset,indent:this.indent,items:[{start:[this.sourceToken]}]};case"explicit-key-ind":{this.onKeyLine=!0;let t=n(e),s=o(t);return s.push(this.sourceToken),{type:"block-map",offset:this.offset,indent:this.indent,items:[{start:s,explicitKey:!0}]}}case"map-value-ind":{this.onKeyLine=!0;let t=n(e),s=o(t);return{type:"block-map",offset:this.offset,indent:this.indent,items:[{start:s,key:null,sep:[this.sourceToken]}]}}}return null}atIndentedComment(e,t){return this.type!=="comment"||this.indent<=t?!1:e.every(s=>s.type==="newline"||s.type==="space")}*documentEnd(e){this.type!=="doc-mode"&&(e.end?e.end.push(this.sourceToken):e.end=[this.sourceToken],this.type==="newline"&&(yield*this.pop()))}*lineEnd(e){switch(this.type){case"comma":case"doc-start":case"doc-end":case"flow-seq-end":case"flow-map-end":case"map-value-ind":yield*this.pop(),yield*this.step();break;case"newline":this.onKeyLine=!1;case"space":case"comment":default:e.end?e.end.push(this.sourceToken):e.end=[this.sourceToken],this.type==="newline"&&(yield*this.pop())}}};f.Parser=r}),xt=E(f=>{"use strict";var g=et(),d=fe(),m=de(),y=Ke(),u=C(),c=it(),n=st();function o(s){let a=s.prettyErrors!==!1;return{lineCounter:s.lineCounter||a&&new c.LineCounter||null,prettyErrors:a}}function i(s,a={}){let{lineCounter:l,prettyErrors:h}=o(a),p=new n.Parser(l?.addNewLine),b=new g.Composer(a),w=Array.from(b.compose(p.parse(s)));if(h&&l)for(let k of w)k.errors.forEach(m.prettifyError(s,l)),k.warnings.forEach(m.prettifyError(s,l));return w.length>0?w:Object.assign([],{empty:!0},b.streamInfo())}function r(s,a={}){let{lineCounter:l,prettyErrors:h}=o(a),p=new n.Parser(l?.addNewLine),b=new g.Composer(a),w=null;for(let k of b.compose(p.parse(s),!0,s.length))if(!w)w=k;else if(w.options.logLevel!=="silent"){w.errors.push(new m.YAMLParseError(k.range.slice(0,2),"MULTIPLE_DOCS","Source contains multiple documents; please use YAML.parseAllDocuments()"));break}return h&&l&&(w.errors.forEach(m.prettifyError(s,l)),w.warnings.forEach(m.prettifyError(s,l))),w}function e(s,a,l){let h;typeof a=="function"?h=a:l===void 0&&a&&typeof a=="object"&&(l=a);let p=r(s,l);if(!p)return null;if(p.warnings.forEach(b=>y.warn(p.options.logLevel,b)),p.errors.length>0){if(p.options.logLevel!=="silent")throw p.errors[0];p.errors=[]}return p.toJS(Object.assign({reviver:h},l))}function t(s,a,l){let h=null;if(typeof a=="function"||Array.isArray(a)?h=a:l===void 0&&a&&(l=a),typeof l=="string"&&(l=l.length),typeof l=="number"){let p=Math.round(l);l=p<1?void 0:p>8?{indent:8}:{indent:p}}if(s===void 0){let{keepUndefined:p}=l??a??{};if(!p)return}return u.isDocument(s)&&!h?s.toString(l):new d.Document(s,h,l).toString(l)}f.parse=e,f.parseAllDocuments=i,f.parseDocument=r,f.stringify=t}),rt=E(f=>{"use strict";var g=et(),d=fe(),m=Ve(),y=de(),u=oe(),c=C(),n=V(),o=D(),i=z(),r=Y(),e=Pe(),t=tt(),s=it(),a=st(),l=xt(),h=ne();f.Composer=g.Composer,f.Document=d.Document,f.Schema=m.Schema,f.YAMLError=y.YAMLError,f.YAMLParseError=y.YAMLParseError,f.YAMLWarning=y.YAMLWarning,f.Alias=u.Alias,f.isAlias=c.isAlias,f.isCollection=c.isCollection,f.isDocument=c.isDocument,f.isMap=c.isMap,f.isNode=c.isNode,f.isPair=c.isPair,f.isScalar=c.isScalar,f.isSeq=c.isSeq,f.Pair=n.Pair,f.Scalar=o.Scalar,f.YAMLMap=i.YAMLMap,f.YAMLSeq=r.YAMLSeq,f.CST=e,f.Lexer=t.Lexer,f.LineCounter=s.LineCounter,f.Parser=a.Parser,f.parse=l.parse,f.parseAllDocuments=l.parseAllDocuments,f.parseDocument=l.parseDocument,f.stringify=l.stringify,f.visit=h.visit,f.visitAsync=h.visitAsync}),ci=ye(rt(),1),ui=ye(rt(),1),Ct="Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/136.0.0.0 Safari/537.36",nt=112,It=1920,Kt=1080,Bt=1920,$t=1080-nt,_t=1280,Dt=720,Ft=500,Gt=500,se="Desktop Chrome",jt=(f=>(f.Chromium="chromium",f.Firefox="firefox",f.Webkit="webkit",f))(jt||{}),ot={"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"}},Wt={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"]},re=(f,g=!1)=>{let d=["chromium"];return g&&d.push("webkit"),Wt[f].map(m=>ot[m]).filter(m=>m.defaultBrowserType&&d.includes(m.defaultBrowserType))},Ee=f=>ot[f],fi={desktop:{label:"Desktop",type:"desktop",devices:re("desktop")},mobile:{label:"Mobile Web",type:"mobile",devices:re("mobile")}},di={desktop:{label:"Desktop",type:"desktop",devices:re("desktop",!0)},mobile:{label:"Mobile Web",type:"mobile",devices:re("mobile",!0)}},at=(f,g=!1)=>{let d={userAgent:Ct,viewport:{width:Bt,height:$t},isMobile:!1,hasTouch:!1};if(!f||f===se)return d;let m=Ee(f);if(!m)return d;let{width:y,height:u}=m.viewport,c=Math.max(Ft/y,1),n=Math.max(Gt/u,1),o=Math.max(c,n),i={width:Math.round(y*o),height:Math.round(u*o)};return{userAgent:m.userAgent,viewport:g?i:m.viewport,isMobile:m.isMobile,hasTouch:m.hasTouch}},pi=f=>{let g={width:It,height:Kt};if(!f||f===se)return g;let d=at(f);return d.viewport?{width:d.viewport.width,height:d.viewport.height+nt}:g},mi=f=>{let g={width:_t,height:Dt};if(!f||f===se)return g;let d=at(f);return d.viewport?{width:d.viewport.width,height:d.viewport.height}:g},gi=f=>!f||f===se?void 0:Ee(f)?.channel,yi=f=>!f||f===se?"chromium":Ee(f)?.defaultBrowserType??"chromium",qt=(f=>(f.PASSWORD="password",f.OAUTH2="oauth2",f.SSO="sso",f.API="api",f))(qt||{}),Ut=(f=>(f.SMS="sms",f.EMAIL="email",f.TOTP="totp",f))(Ut||{});function bi(f,g){if(!f||typeof f!="string")return f;let d=g instanceof Map?Object.fromEntries(g):g,m=u=>{let c=u.startsWith("$")?u.slice(1):u,n=d[c]??d[`$${c}`];return n!=null?String(n):void 0},y=f;return y=y.replace(/\{\{\s*\$?([^}]+?)\s*\}\}/g,(u,c)=>{let n=m(c.trim());return n!==void 0?n:u}),y=y.replace(/<secret>\$?([\w-]+)<\/secret>/g,(u,c)=>{let n=m(c);return n!==void 0?n:u}),y=y.replace(/\$\{([^}]+)\}/g,(u,c)=>{let n=m(c.trim());return n!==void 0?n:u}),y=y.replace(/\$([a-zA-Z_]\w*)/g,(u,c)=>{let n=m(c);return n!==void 0?n:u}),y}var wi=class lt{constructor(){ge(this,"data",{}),ge(this,"sensitive",new Set)}get(g){return this.data[g]}set(g,d,m=!1){this.data[g]=d,m?this.sensitive.add(g):this.sensitive.has(g)&&this.sensitive.delete(g)}getAll(){return{...this.data}}isSensitive(g){return this.sensitive.has(g)}getAllSensitiveKeys(){return new Set(this.sensitive)}delete(g){return this.sensitive.delete(g),delete this.data[g]}clear(){this.data={},this.sensitive.clear()}has(g){return g in this.data}get size(){return Object.keys(this.data).length}merge(g){for(let[d,m]of Object.entries(g.getAll()))this.set(d,m,g.isSensitive(d))}toJSON(){return{data:{...this.data},sensitiveKeys:Array.from(this.sensitive)}}static fromJSON(g){let d=new lt;if(g.data){let m=new Set(g.sensitiveKeys||[]);for(let[y,u]of Object.entries(g.data))d.set(y,u,m.has(y))}return d}},Rt=P.enum(["JS_CODE","AI_MODE"]),Oe=P.object({type:Rt,expression:P.string()}),Ht=P.enum(["DRAFT","STEP","ACTION","IF_ELSE","WHILE_LOOP"]),Q=P.object({uid:P.string(),type:Ht}),Vt=P.object({action_data:P.object({action_name:P.string(),kwargs:P.record(P.any()).optional(),args:P.array(P.any()).optional()}),action_description:P.string().optional(),url:P.string().optional(),xpath:P.string().nullable().optional(),locator:P.string().nullable().optional(),css_selector:P.string().nullable().optional(),unique_selector:P.string().nullable().optional(),element_index:P.number().nullable().optional(),frame_path:P.array(P.any()).optional(),artifacts:P.record(P.any()).optional(),feedback:P.string().optional(),original_browser_use_action:P.any().optional()}).passthrough(),zt=Q.extend({type:P.literal("DRAFT"),description:P.string()}),Yt=Q.extend({type:P.literal("ACTION"),description:P.string(),action_entity:Vt.optional(),locator:P.string().optional(),use_pure_vision:P.boolean().optional()}),q=P.lazy(()=>P.union([zt,Yt,Q.extend({type:P.literal("STEP"),description:P.string().optional().default(""),statements:P.array(q),reference_id:P.number().optional()}),Q.extend({type:P.literal("IF_ELSE"),description:P.string().optional(),condition:Oe,then:P.array(q),else:P.array(q).optional()}),Q.extend({type:P.literal("WHILE_LOOP"),description:P.string().optional(),condition:Oe,body:P.array(q),timeout_ms:P.number().optional()})])),Xt=P.object({name:P.string(),statements:P.array(q),teardown:P.array(q).optional(),skip:P.union([P.boolean(),P.string()]).optional(),timeout:P.number().optional(),fail:P.union([P.boolean(),P.string()]).optional(),only:P.boolean().optional(),slow:P.boolean().optional()}),Jt=P.object({tests:P.array(Xt).min(1),beforeAll:P.array(q).optional(),afterAll:P.array(q).optional(),beforeEach:P.array(q).optional(),afterEach:P.array(q).optional()}),vi=P.object({version:P.string().optional(),goal:P.string().optional(),url:P.string().optional(),baseURL:P.string().optional(),final_feedback:P.string().optional(),completed:P.boolean().optional(),success:P.boolean().optional(),statements:P.array(q).optional(),teardown:P.array(q).optional(),last_modified_at:P.string().optional(),testGroup:Jt.optional()}).refine(f=>f.testGroup!==void 0?f.goal===void 0&&(f.statements===void 0||f.statements.length===0):f.goal!==void 0,{message:"TestFlow must have either goal/statements (single test) or testGroup (suite), not both"}),ki=1024*1024,Qt=5e3,Zt=1e4;async function xe(f,g){let d=Object.getPrototypeOf(async()=>{}).constructor,m=`
|
|
143
143
|
return await (${g});
|
|
144
144
|
`;return await new d("page",m)(f)}async function be(f,g,d){let m=[],y=[];for(let u of g){let c=!1;try{let n=`page.${u}`;_.log(`Checking element existence: ${n}`),m.push(`Checking element existence: ${n}`);try{await xe(f,`${n}.waitFor({ state: 'attached', timeout: ${Qt} })`),_.log(`Element is attached: ${n}`),m.push(`Element is attached: ${n}`),c=!0}catch{await xe(f,`${n}.count()`)>0?(_.log(`Element found (snapshot): ${n}`),m.push(`Element found (snapshot): ${n}`),c=!0):(_.log(`Element not found: ${n}`),m.push(`Element not found: ${n}`),c=!1)}}catch(n){_.log(`Error checking element: ${n.message}`),m.push(`Error checking element: ${n.message}`),c=!1}if(y.push(c),!c&&d)break}return{successResults:y,logs:m}}async function ei(f,g,d=!0){let{successResults:m,logs:y}=await be(f,g,d);return{success:m.length===g.length&&m.every(u=>u),logs:y}}async function Si(f,g){if(!g||g.length===0)return _.log("No validation expressions provided, cannot validate login"),!1;_.log(`Validating login with ${g.length} expression(s)`);let{success:d,logs:m}=await ei(f,g,!0);return d?_.log("All validation expressions passed"):_.log(`Validation failed: ${m.join(", ")}`),d}async function ti(f,g){let d=f.context().browser();if(!d)throw new Error("Cannot create unsigned-in context: browser not available");let m=await d.newContext(),y=await m.newPage();return await y.goto(g),await Ne(y,Zt),{context:m,page:y,close:async()=>{await y.close(),await m.close()}}}async function ii(f,g,d,m,y,u){let c=`
|
|
145
145
|
Based on the current page status, generate ${y} Playwright locators in JavaScript code that can
|
|
@@ -197,4 +197,4 @@ ${t.join(`
|
|
|
197
197
|
|
|
198
198
|
`,e.some(s=>s)){_.log(`Locator validation on unsigned-in page failed (some passed when should fail). Results: ${JSON.stringify(e)}`),_.log(`Validation logs:
|
|
199
199
|
${t.join(`
|
|
200
|
-
`)}`);continue}}return _.log("Generated validation locators passed dual validation"),r}catch(r){_.log(`Failed to generate validation expressions (attempt ${i+1}/${n}): ${r.message}`)}return _.log("Failed to generate valid locators after max retries"),null}finally{u&&await u.close()}}export{
|
|
200
|
+
`)}`);continue}}return _.log("Generated validation locators passed dual validation"),r}catch(r){_.log(`Failed to generate validation expressions (attempt ${i+1}/${n}): ${r.message}`)}return _.log("Failed to generate valid locators after max retries"),null}finally{u&&await u.close()}}export{nt as a,se as b,jt as c,Ee as d,at as e,pi as f,mi as g,gi as h,yi as i,qt as j,Ut as k,bi as l,wi as m,be as n,ei as o,Si as p,ti as q,ii as r,Mi as s};
|
|
@@ -22,17 +22,17 @@ import{a as nt,b as z,c as V,d as De,e as ue,f as j,j as K,l as X}from"./chunk-X
|
|
|
22
22
|
return (async () => {
|
|
23
23
|
${h}
|
|
24
24
|
})();
|
|
25
|
-
`)(n,y)}transpile(n){let l=this.generateFunctionCallCode(n.action_data?.kwargs||{});return l?[l.endsWith(";")?l:`${l};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(n){let l=n.functionName;if(!l)return null;let c;if(Array.isArray(n.args))c=n.args.map(String);else if(Array.isArray(n.parameterNames)){let x=n.parameterValues||[];c=n.parameterNames.map((w,g)=>g<x.length?String(x[g]):"undefined")}else return`await ${l}()`;if(c.length===0)return`await ${l}()`;let u=["page","testContext","request","agent"],h=["undefined","null","true","false"],y=c.map(x=>u.includes(x)||h.includes(x)||/^-?\d+(\.\d+)?$/.test(x)?x:x.startsWith("$")?`agent.agentServices.readVariable('${x.substring(1)}')`:`"${x}"`);return`await ${l}(${y.join(", ")})`}},Kr=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.statement;if(!h)throw new Error("Missing statement for ai_action");let y=u.kwargs.use_pure_vision,{executeStep:x}=await import("./agentHelpers-
|
|
25
|
+
`)(n,y)}transpile(n){let l=this.generateFunctionCallCode(n.action_data?.kwargs||{});return l?[l.endsWith(";")?l:`${l};`]:["// Skipping function: missing functionName"]}generateFunctionCallCode(n){let l=n.functionName;if(!l)return null;let c;if(Array.isArray(n.args))c=n.args.map(String);else if(Array.isArray(n.parameterNames)){let x=n.parameterValues||[];c=n.parameterNames.map((w,g)=>g<x.length?String(x[g]):"undefined")}else return`await ${l}()`;if(c.length===0)return`await ${l}()`;let u=["page","testContext","request","agent"],h=["undefined","null","true","false"],y=c.map(x=>u.includes(x)||h.includes(x)||/^-?\d+(\.\d+)?$/.test(x)?x:x.startsWith("$")?`agent.agentServices.readVariable('${x.substring(1)}')`:`"${x}"`);return`await ${l}(${y.join(", ")})`}},Kr=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.statement;if(!h)throw new Error("Missing statement for ai_action");let y=u.kwargs.use_pure_vision,{executeStep:x}=await import("./agentHelpers-BWIZZVR4-6SA75OLH.js"),w=await x(h,n,c,{usePureVision:y});if(w.status!=="success")throw new Error(w.error||"Action execution failed")}transpile(n,l){let c=n.action_data?.kwargs?.statement;if(!c)return["// Skipping ai_action: missing statement"];let u=JSON.stringify(c),h=n.action_data?.kwargs?.use_pure_vision;return[`await agent.execute(page, ${u}, '${l||""}', ${h});`]}},bn=rs.object({statement:rs.string().describe('The action to perform (e.g., "click the submit button")')}),Xr=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.statement;if(!h)throw new Error("Missing statement for ai_step");let{runTask:y}=await import("./agentHelpers-BWIZZVR4-6SA75OLH.js"),x=await y(h,n,c);if(x.status!=="success")throw new Error(x.error||"Task execution failed")}transpile(n,l){let c=n.action_data?.kwargs?.statement;return c?[`await agent.run(page, ${JSON.stringify(c)}, '${l||""}');`]:["// Skipping ai_step: missing statement"]}},En=as.object({statement:as.string().describe('The complete step to execute (e.g., "fill in the login form and submit")')}),Yr=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.condition;if(!h)throw new Error("Missing condition for ai_wait_until");let y=(u.kwargs.timeout_seconds||60)*1e3,x=5e3,w=Date.now(),{evaluateStatement:g}=await import("./agentHelpers-BWIZZVR4-6SA75OLH.js");for(;Date.now()-w<y;){if((await g(h,n,c,{})).success)return;await n.waitForTimeout(x)}throw new Error(`Timeout waiting for condition: ${h}`)}transpile(n,l){let c=n.action_data?.kwargs?.condition,u=n.action_data?.kwargs?.timeout_seconds||60;return c?[`await agent.waitUntilCondition(page, ${JSON.stringify(c)}, ${u}, '${l}');`]:["// Skipping ai_wait_until: missing condition"]}},Gr=ot.object({condition:ot.string().describe('The condition to wait for (e.g., "the loading spinner disappears")'),timeout_seconds:ot.number().positive().optional().describe("Timeout in seconds (default: 60)")});function Sn(n,l){n.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:Gr,async execute(c,u){let{condition:h,timeout_seconds:y=60}=c,{page:x,agentServices:w}=u;try{let g={action_description:`Wait until: ${h}`,action_data:{action_name:"ai_wait_until",kwargs:{condition:h,timeout_seconds:y}}};return await l.execute(x,g,w),{success:!0,actionEntity:g,message:`Condition met: ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:`Wait until: ${h} (failed)`,action_data:{action_name:"ai_wait_until",kwargs:{condition:h,timeout_seconds:y}},feedback:g.message}}}}})}j();var Qr=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.text||u.kwargs.option,y=V(n,l),x=z(c,l.action_data?.kwargs?.timeout_ms);if(y&&h)await y.selectOption(h,{timeout:x});else throw new Error("Missing locator or option label for select_dropdown_option action")}transpile(n){let l=n.action_data?.kwargs?.text||n.action_data?.kwargs?.option||"",c=[];return c.push(`action_data: { kwargs: { text: ${JSON.stringify(l)} } }`),n.locator?c.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&c.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&c.push(`frame_path: ${JSON.stringify(n.frame_path)}`),['await agent.execAction("select_dropdown_option", page, {',...c.map(u=>` ${u},`),"});"]}};async function Zr(n,l,c,u){return{...await X(l,n),action_description:u||`Select option "${c}"`,action_data:{action_name:"select_dropdown_option",kwargs:{text:c}}}}function ns(n,l){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:"select_dropdown_option",kwargs:l},feedback:"Element not found in DOM"}}var ea=Fe.object({element_index:Fe.number().int().describe("Index of the dropdown/select element"),option:Fe.string().describe("Option value, label, or index to select"),timeout_ms:Fe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function vn(n,l){n.register({name:"select_dropdown_option",description:"Select an option from a dropdown/select element by value, label, or index.",schema:ea,usesElementIndex:!0,async execute(c,u){let{element_index:h,option:y}=c,{page:x,agentServices:w,actionDescription:g}=u;try{let E=await K(u,h);if(!E)return{success:!1,error:`Dropdown element with index ${h} not found`,actionEntity:ns(g||`Select option in dropdown ${h}`,{index:h,option:y})};let C=await Zr(E,x,y,g);return await l.execute(x,C,w),{success:!0,actionEntity:C,message:`Selected option "${y}" in dropdown ${h}`}}catch(E){return{success:!1,error:E.message,actionEntity:ns(`Select option in dropdown ${h}`,{index:h,option:y})}}}})}j();var ta=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.date;if(!h)throw new Error("Date value is required");if(!/^\d{4}-\d{2}-\d{2}$/.test(h))throw new Error(`Invalid date format: ${h}. Expected format: YYYY-MM-DD (e.g., 2024-03-15)`);let y=c.replaceVariables(String(h)),x=V(n,l);if(x){let w=await x.getAttribute("type").catch(()=>null);if(w&&w!=="date")throw new Error(`Element is not a native date picker (type="${w}"). This action only works with <input type="date">. For custom date pickers, use AI-powered actions.`);await x.fill(y,{timeout:z(c,l.action_data?.kwargs?.timeout_ms)})}else throw new Error("No locator found for set_date_for_native_date_picker action")}transpile(n){let l=n.action_data?.kwargs?.date??"",c=[];return c.push(`action_data: { kwargs: { date: ${JSON.stringify(l)} } }`),n.locator?c.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&c.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&c.push(`frame_path: ${JSON.stringify(n.frame_path)}`),['await agent.execAction("set_date_for_native_date_picker", page, {',...c.map(u=>` ${u},`),"});"]}};async function sa(n,l,c,u){return{...await X(c,l),action_description:n,action_data:{action_name:"set_date_for_native_date_picker",kwargs:{date:u}}}}function lt(n,l){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:"set_date_for_native_date_picker",kwargs:l},feedback:"Element not found in DOM"}}var ia=Le.object({element_index:Le.number().int().describe("Index of the native date picker input element"),date:Le.string().regex(/^\d{4}-\d{2}-\d{2}$/).describe("Date in YYYY-MM-DD format (e.g., 2024-03-15)"),timeout_ms:Le.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function Nn(n,l){n.register({name:"set_date_for_native_date_picker",description:`Set a date in a native HTML date picker input (<input type="date">).
|
|
26
26
|
|
|
27
27
|
IMPORTANT: ONLY use this action for input elements that have type="date" attribute (native HTML date picker).
|
|
28
28
|
Do NOT use it for custom/non-native date pickers
|
|
29
29
|
|
|
30
30
|
The date must be in YYYY-MM-DD format (e.g., 2024-03-15).`,schema:ia,usesElementIndex:!0,async execute(c,u){let{element_index:h,date:y}=c,{page:x,agentServices:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Date picker element with index ${h} not found`,actionEntity:lt(`Set date to ${y} on element ${h}`,{index:h,date:y})};let E=g.attributes.type;if(E!=="date")return{success:!1,error:`Element ${h} is not a native date picker (type="${E}"). This action only works with <input type="date">.`,actionEntity:lt(`Set date to ${y} on element ${h}`,{index:h,date:y})};let C=await sa(`Set date to ${y} on element ${h}`,g,x,y);return await l.execute(x,C,w),{success:!0,actionEntity:C,message:`Set date to ${y} on element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:lt(`Set date to ${y} on element ${h}`,{index:h,date:y})}}}})}var ra=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.page_id??u.kwargs.tab_index??0;if(typeof h=="number"){let y=n.context().pages(),x=h===-1?y.length-1:h;if(c){let w=await c.switchTab(x);await w.waitForLoadState("load",{timeout:15e3}).catch(()=>{}),await w.waitForTimeout(500)}}else throw new Error("Missing page_id for switch_tab action")}transpile(n){return['await agent.execAction("switch_tab", page, {',` action_data: { kwargs: { page_id: ${n.action_data?.kwargs?.page_id??n.action_data?.kwargs?.tab_index??0} } },`,"});"]}},aa=os.object({tab_index:os.number().int().nonnegative().describe("Index of the tab to switch to (0-based). Use 0 for first tab, 1 for second, etc.")});function Dn(n,l){n.register({name:"switch_tab",description:"Switch to a different browser tab by index (0-based).",schema:aa,async execute(c,u){let h=c.tab_index,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Switch to tab ${h}`,action_data:{action_name:"switch_tab",kwargs:{page_id:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Switched to tab ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||`Switch to tab ${h}`)+" (failed)",action_data:{action_name:"switch_tab",kwargs:{page_id:h}},feedback:g.message}}}}})}async function Bn(n,l,c,u,h,y){let x=Array.isArray(l)?l:[l];if(x.length===0)throw new Error("No file paths provided for upload");let w=x.map(C=>{if(C.startsWith("/")||C.match(/^[A-Za-z]:\\/))return C;let M=u.testDataDir||process.cwd();return oa.join(M,C)});W.info(`Uploading files: ${w.join(", ")}`);let g=c.timeout||2e4,E={useFileInput:c.useFileInput||!1,timeout:g};if(c.selector&&typeof c.selector!="string"){let C=c.selector;await At(n,C,w,E);return}if(c.selector&&typeof c.selector=="string"){let C=c.selector,M=(C.startsWith("xpath="),n.locator(C));await At(n,M,w,E);return}if(h){let C=x.map(H=>`"${H}"`).join(", "),M="";c.targetDescription?M=`Upload ${C} to ${c.targetDescription}`:M=`Upload ${C}`,W.info(`Using AI to handle file upload: ${M}`),await h(n,M,y)}else throw new Error("No selector provided and AI action execution is not available")}async function At(n,l,c,u){let{useFileInput:h,timeout:y,mockShowOpenFilePicker:x}=u;if(x){W.info("Using mockShowOpenFilePicker approach");let w=c.map(g=>({path:g,buffer:new Uint8Array(na.readFileSync(g))}));await n.evaluate(g=>{window.__pw_showOpenFilePicker_mock_files=g},w),await l.click({timeout:y}),await n.waitForTimeout(3e3),await n.evaluate(()=>{delete window.__pw_showOpenFilePicker_mock_files})}else if(h)W.info("Using direct file input approach"),await l.setInputFiles(c,{timeout:y}),await n.waitForTimeout(3e3);else{W.info("Using file chooser approach");let w=n.waitForEvent("filechooser",{timeout:y});w.catch(()=>{}),await l.click({timeout:y}),await(await w).setFiles(c),await n.waitForTimeout(3e3)}W.info(`Successfully uploaded ${c.length} file(s)`)}j();var la=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=[];if(u.kwargs.paths?h=Array.isArray(u.kwargs.paths)?u.kwargs.paths:[u.kwargs.paths]:u.kwargs.path&&(h=Array.isArray(u.kwargs.path)?u.kwargs.path:[u.kwargs.path]),h.length===0)throw new Error("No file paths provided for upload_file action");await c.downloadTestDataFiles(h);let y=h.map(E=>c.getTestDataFilePath(E)),x=V(n,l);if(!x)throw new Error("Missing locator for upload_file action");let w=u.kwargs.use_file_input||!1,g=c.getActionSettings().mock_show_open_file_picker??!1;await At(n,x,y,{useFileInput:w,timeout:z(c,l.action_data?.kwargs?.timeout_ms),mockShowOpenFilePicker:g})}transpile(n){let l=n.action_data?.kwargs||{},c=[],u={};return l.paths?u.paths=l.paths:l.path&&(u.path=l.path),l.use_file_input&&(u.use_file_input=!0),c.push(`action_data: { kwargs: ${JSON.stringify(u)} }`),n.locator?c.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&c.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&c.push(`frame_path: ${JSON.stringify(n.frame_path)}`),['await agent.execAction("upload_file", page, {',...c.map(h=>` ${h},`),"});"]}};async function ha(n,l,c={},u){return{...await X(l,n),action_description:u||"Upload file to element",action_data:{action_name:"upload_file",kwargs:{...c}}}}function ls(n,l){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:"upload_file",kwargs:l},feedback:"Element not found in DOM"}}var ca=oe.object({element_index:oe.number().int().describe("Index of the target element to trigger the file upload dialog"),paths:oe.string().describe("Paths to the files to upload"),timeout_ms:oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function Mn(n,l){n.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:ca,usesElementIndex:!0,async execute(c,u){let{element_index:h,paths:y}=c,{page:x,agentServices:w,actionDescription:g}=u;try{let E=await K(u,h);if(!E)return{success:!1,error:`File input element with index ${h} not found`,actionEntity:ls(g||`Upload file to element ${h}`,{index:h,paths:y})};let C=await ha(E,x,{paths:y},g);return await l.execute(x,C,w),{success:!0,actionEntity:C,message:`Uploaded file to element ${h}`}}catch(E){return{success:!1,error:E.message,actionEntity:ls(g||`Upload file to element ${h}`,{index:h,paths:y})}}}})}var $n=oe.object({element_index:oe.number().int().describe("Index of the file input element"),paths:oe.string().describe("Path to the file to upload (can be relative or absolute)"),timeout_ms:oe.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")}),pa=class{async execute(n,l){let c=l.action_data;if(!c)throw new Error("Action data not found");let u=c.kwargs.seconds||1;await n.waitForTimeout(u*1e3)}transpile(n){return[`await page.waitForTimeout(${(n.action_data?.kwargs?.seconds||1)*1e3});`]}},ua=hs.object({seconds:hs.number().positive().describe("Number of seconds to wait")});function Un(n,l){n.register({name:"wait",description:"Wait for a specified number of seconds before continuing.",schema:ua,async execute(c,u){let{seconds:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Wait ${h} seconds`,action_data:{action_name:"wait",kwargs:{seconds:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Waited ${h} seconds`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||`Wait ${h} seconds`)+" (failed)",action_data:{action_name:"wait",kwargs:{seconds:h}},feedback:g.message}}}}})}var da=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.timeout_seconds||10;await c.waitForDownloadComplete(n,h)}transpile(n){return['await agent.execAction("wait_for_download_complete", page, {',` action_data: { kwargs: { timeout_seconds: ${n.action_data?.kwargs?.timeout_seconds||10} } },`,"});"]}},ma=cs.object({timeout_seconds:cs.number().positive().optional().describe("Maximum time in seconds to wait for download to complete (default: 10)")});function zn(n,l){n.register({name:"wait_for_download_complete",description:"Wait for an in-progress download to complete.",schema:ma,async execute(c,u){let{timeout_seconds:h=10}=c,{page:y,agentServices:x}=u;try{let w={action_description:`Wait for download to complete (timeout: ${h}s)`,action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:h}}};return await l.execute(y,w,x),{success:!0,actionEntity:w,message:"Download completed"}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:"Wait for download to complete (failed)",action_data:{action_name:"wait_for_download_complete",kwargs:{timeout_seconds:h}},feedback:w.message}}}}})}var us=class{async execute(n,l){let c=l.action_data;if(!c)throw new Error("Action data not found");let u=c.kwargs.keys;if(!u||typeof u!="string")throw new Error("Missing or invalid keys for press action");await n.keyboard.press(u),await n.waitForTimeout(500)}transpile(n){let l=n.action_data?.kwargs?.keys;return[`await page.keyboard.press(${JSON.stringify(l)});`]}},fa=ps.object({keys:ps.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 Hn(n,l){n.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:fa,async execute(c,u){let{keys:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Press keys "${h}"`,action_data:{action_name:"press",kwargs:{keys:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Pressed keys "${h}"`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||`Press keys "${h}"`)+" (failed)",action_data:{action_name:"press",kwargs:{keys:h}},feedback:g.message}}}}})}j();var xa=class{async execute(n,l){await n.reload({timeout:ue}),await n.waitForLoadState("load",{timeout:ue}),await n.waitForTimeout(1e3)}transpile(n){return['await agent.execAction("reload_page", page, {});']}},ga=ya.object({});function qn(n,l){n.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:ga,async execute(c,u){let{page:h,agentServices:y}=u;try{let x={action_description:"Reload page",action_data:{action_name:"reload_page",kwargs:{}}};return await l.execute(h,x,y),{success:!0,actionEntity:x,message:`Reloaded ${h.url()}`}}catch(x){return{success:!1,error:x.message,actionEntity:{action_description:"Reload page (failed)",action_data:{action_name:"reload_page",kwargs:{}},feedback:x.message}}}}})}j();var ds=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u)await u.click({button:"right",timeout:h});else throw new Error("No locator found for right_click action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("right_click", page, {});']:['await agent.execAction("right_click", page, {',...l.map(c=>` ${c},`),"});"]}};async function wa(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function ms(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var Aa=ht.object({element_index:ht.number().int().describe("Index of the element to right-click"),timeout_ms:ht.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function Kn(n,l){n.register({name:"right_click",description:"Right-click an interactive element.",schema:Aa,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:ms(`Right-click element ${h}`,"right_click",{index:h})};let E=w||`Right-click element ${h}`,C=await wa("right_click",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Right-clicked element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:ms(`Right-click element ${h}`,"right_click",{index:h})}}}})}var Pa=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.name,y=u.kwargs.value;if(!h||y===void 0)throw new Error("Missing variable name or value for save_variable");h.startsWith("$")&&(h=h.slice(1)),c.saveVariable(h,y)}transpile(n){let l=n.action_data?.kwargs?.name||"",c=n.action_data?.kwargs?.value;return['await agent.execAction("save_variable", page, {',` action_data: { kwargs: { name: ${JSON.stringify(l)}, value: ${JSON.stringify(c)} } },`,"});"]}},ba=ct.object({name:ct.string().describe("Variable name to save"),value:ct.string().describe("Value to save in the variable")});function Yn(n,l){n.register({name:"save_variable",description:"Save a value to a named variable for later use in the test.",schema:ba,async execute(c,u){let{name:h,value:y}=c,{page:x,agentServices:w}=u;try{let g={action_description:`Save variable "${h}" = "${y}"`,action_data:{action_name:"save_variable",kwargs:{name:h,value:y}}};return await l.execute(x,g,w),{success:!0,actionEntity:g,message:`Saved variable "${h}"`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:`Save variable "${h}" (failed)`,action_data:{action_name:"save_variable",kwargs:{name:h,value:y}},feedback:g.message}}}}})}var Be=class{async execute(n,l){let c=l.action_data;if(!c)throw new Error("Action data not found");let u=c.kwargs.down??!0,h=c.kwargs.num_pages??1,y=u?1:-1;await n.evaluate(`window.scrollBy(0, window.innerHeight * ${h} * ${y})`)}transpile(n){let l=n.action_data?.kwargs?.down??!0;return[`await page.evaluate('window.scrollBy(0, window.innerHeight * ${(n.action_data?.kwargs?.num_pages??1)*(l?1:-1)})');`]}};async function Ta(n,l,c={}){return{action_description:l,action_data:{action_name:n,kwargs:{...c}}}}function Ea(n,l,c){return{action_description:`${n} (failed)`,action_data:{action_name:l,kwargs:c},feedback:"Scroll failed!"}}var Ca=pt.object({down:pt.boolean().describe("True to scroll down, False to scroll up"),num_pages:pt.number().nonnegative().describe("Number of pages to scroll (0.5 = half page, 1.0 = one page, etc.)")});function Qn(n,l){n.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:Ca,async execute(c,u){let{down:h,num_pages:y}=c,{page:x,agentServices:w,actionDescription:g}=u;try{let E=g||`Scroll ${h?"down":"up"} ${y} page(s)`,C=await Ta("scroll",E,{down:h,num_pages:y});return await l.execute(x,C,w),{success:!0,actionEntity:C,message:`Scrolled ${h?"down":"up"} ${y} page(s)`}}catch(E){return{success:!1,error:E.message,actionEntity:Ea(g||`Scroll ${h?"down":"up"} ${y} page(s)`,"scroll",{down:h,num_pages:y})}}}})}j();var Sa=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.delta_x||0,y=u.kwargs.delta_y||0,x=V(n,l),w=z(c,l.action_data?.kwargs?.timeout_ms);if(x)await x.hover({timeout:w}),await n.mouse.wheel(h,y);else throw new Error("No locator found for scroll_on_element action")}transpile(n){let l=De(n);if(!l){let h=n.action_data?.kwargs?.delta_x||0,y=n.action_data?.kwargs?.delta_y||0;return['await agent.execAction("scroll_on_element", page, {',` action_data: { kwargs: { delta_x: ${h}, delta_y: ${y} } },`,"});"]}let c=n.action_data?.kwargs?.delta_x||0,u=n.action_data?.kwargs?.delta_y||0;return[`await ${l}.hover({ timeout: ${z()} });`,`await page.mouse.wheel(${c}, ${u});`]}};async function ka(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function fs(n,l,c){return{action_description:`${n} (failed)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var va=Te.object({element_index:Te.number().int().describe("Index of the scrollable element"),delta_x:Te.number().optional().describe("The number of pixels to scroll horizontally. Positive values scroll right, negative values scroll left."),delta_y:Te.number().optional().describe("The number of pixels to scroll vertically. Positive values scroll down, negative values scroll up."),timeout_ms:Te.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function eo(n,l){n.register({name:"scroll_on_element",description:"Scroll on a scrollable element horizontally and vertically.",schema:va,usesElementIndex:!0,async execute(c,u){let{element_index:h,delta_x:y,delta_y:x}=c,{page:w,agentServices:g}=u;try{let E=await K(u,h);if(!E)return{success:!1,error:`Element with index ${h} not found`,actionEntity:fs(`Scroll on element ${h} horizontally: ${y}px, vertically: ${x}px`,"scroll_on_element",{index:h,delta_x:y,delta_y:x})};let C=await ka("scroll_on_element",`Scroll on element ${h} horizontally: ${y}px, vertically: ${x}px`,E,w,{delta_x:y,delta_y:x});return await l.execute(w,C,g),{success:!0,actionEntity:C,message:`Scrolled on element ${h} horizontally: ${y}px, vertically: ${x}px`}}catch(E){return{success:!1,error:E.message,actionEntity:fs(`Scroll on element ${h} horizontally: ${y}px, vertically: ${x}px`,"scroll_on_element",{index:h,delta_x:y,delta_y:x})}}}})}var Ia=class{async execute(n,l){let c=l.action_data;if(!c)throw new Error("Action data not found");let u=c.kwargs.text;if(u)await n.getByText(u,{exact:!1}).first().scrollIntoViewIfNeeded(),await n.waitForTimeout(500);else throw new Error("Missing text for scroll_to_text action")}transpile(n){let l=n.action_data?.kwargs?.text||"";return[`await page.getByText(${JSON.stringify(l)}, { exact: false }).first().scrollIntoViewIfNeeded();`]}},Na=ys.object({text:ys.string().describe("Text to scroll to on the page")});function so(n,l){n.register({name:"scroll_to_text",description:"Scroll the page until specified text becomes visible.",schema:Na,async execute(c,u){let{text:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Scroll to text "${h}"`,action_data:{action_name:"scroll_to_text",kwargs:{text:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Scrolled to text "${h}"`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||`Scroll to text "${h}"`)+" (failed)",action_data:{action_name:"scroll_to_text",kwargs:{text:h}},feedback:g.message}}}}})}var _a=class{async execute(n,l,c){if(!l.xpath)throw new Error("XPath not found in action entity");let u=[];for(let h of n.frames())try{let y=await h.evaluate(x=>{let w=document.evaluate(x,document,null,XPathResult.FIRST_ORDERED_NODE_TYPE,null).singleNodeValue;return w?{options:Array.from(w.options).map(g=>({text:g.text,value:g.value,index:g.index})),id:w.id,name:w.name}:null},l.xpath);if(y){let x=[];for(let w of y.options){let g=JSON.stringify(w.text);x.push(`${w.index}: text=${g}`)}u.push(...x)}}catch{}if(u.length>0){let h=u.join(`
|
|
31
31
|
`);h+=`
|
|
32
|
-
Use the exact text string in select_dropdown_option`,c.addNote(h)}else c.addNote("No options found in any frame for dropdown")}transpile(n){let l=[];return n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...l.map(c=>` ${c},`),"});"]}};async function Da(n,l,c){return{...await X(l,n),action_description:c||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function gs(n,l){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:l},feedback:"Element not found in DOM"}}var Fa=xs.object({element_index:xs.number().int().describe("Index of the dropdown/select element")});function ro(n,l){n.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Fa,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Dropdown element with index ${h} not found`,actionEntity:gs(w||`Get options from dropdown ${h}`,{index:h})};let E=await Da(g,y,w);return await l.execute(y,E,x),{success:!0,actionEntity:E,message:E.feedback||"No options found"}}catch(g){return{success:!1,error:g.message,actionEntity:gs(w||`Get options from dropdown ${h}`,{index:h})}}}})}j();var Ba=class{async execute(n,l){await n.goBack({timeout:ue}),await n.waitForLoadState("load",{timeout:ue}),await n.waitForTimeout(1e3)}transpile(n){return['await agent.execAction("go_back", page, {});']}},Oa=La.object({});function no(n,l){n.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Oa,async execute(c,u){let{page:h,agentServices:y,actionDescription:x}=u;try{let w={action_description:x||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await l.execute(h,w,y),{success:!0,actionEntity:w,message:"Navigated back"}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:(x||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:w.message}}}}})}j();var ws=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.url;if(!h)throw new Error("Missing URL for go_to_url action");let y=u.kwargs.new_tab===!0,x=c.replaceVariables(String(h));if(x.startsWith("/")){let E=n.url(),C=null;try{let M=new URL(E);M.origin&&M.origin!=="null"&&(C=M.origin)}catch{}C&&(x=C+x)}let w=u.kwargs.timeout_seconds?u.kwargs.timeout_seconds*1e3:ue,g=n;y&&(g=await n.context().newPage(),c.setPage(g)),await g.goto(x,{timeout:w})}transpile(n){let l=n.action_data?.kwargs?.url||"",c=n.action_data?.kwargs?.new_tab===!0,u=n.action_data?.kwargs?.timeout_seconds,h=[`url: ${JSON.stringify(l)}`];return c&&h.push("new_tab: true"),u&&h.push(`timeout_seconds: ${u}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${h.join(", ")} } },`,"});"]}},Ma=Oe.object({url:Oe.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Oe.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Oe.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")});function lo(n,l){n.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:Ma,async execute(c,u){let{url:h,new_tab:y,timeout_seconds:x}=c,{page:w,agentServices:g,actionDescription:E}=u,C={url:h,new_tab:y??!1};x!==void 0&&(C.timeout_seconds=x);let M=x?` (timeout: ${x}s)`:"";try{let H=y?`Open ${h} in new tab`:`Navigate to ${h}`,Y={action_description:E||H,action_data:{action_name:"go_to_url",kwargs:C}};return await l.execute(w,Y,g),{success:!0,actionEntity:Y,message:(y?`Opened ${h} in new tab`:`Navigated to ${h}`)+M}}catch(H){let Y=y?`Open ${h} in new tab`:`Navigate to ${h}`;return{success:!1,error:H.message,actionEntity:{action_description:(E||Y)+" (failed)",action_data:{action_name:"go_to_url",kwargs:C},feedback:H.message}}}}})}j();var As=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u){await u.waitFor({state:"attached",timeout:h});let y=await u.elementHandle();if(!y)throw new Error("Unable to obtain element handle for hover action");let x=await y.boundingBox();if(!x)throw new Error("Unable to determine bounding box for hover action");let w=x.x+x.width/2,g=x.y+x.height/2;await n.mouse.move(w,g)}else throw new Error("No locator found for hover action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...l.map(c=>` ${c},`),"});"]}};async function $a(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ps(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var Ra=ut.object({element_index:ut.number().int().describe("Index of the element to hover over"),timeout_ms:ut.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function co(n,l){n.register({name:"hover",description:"Hover over an interactive element.",schema:Ra,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ps(`Hover element ${h}`,"hover",{index:h})};let E=w||`Hover over element ${h}`,C=await $a("hover",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Hovered over element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ps(`Hover element ${h}`,"hover",{index:h})}}}})}j();var bs=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.text??u.kwargs.value??"",y=c.replaceVariables(String(h)),x=V(n,l),w=z(c,l.action_data?.kwargs?.timeout_ms);if(x){await x.evaluate(E=>{E.value&&(E.value="")},null,{timeout:w}),await x.click({timeout:w}),await n.waitForTimeout(200);let g=c.getActionSettings().type_delay;g!==void 0?await n.keyboard.type(y,{delay:g}):await n.keyboard.type(y)}else throw new Error("No locator found for input_text action")}transpile(n){let l=n.action_data?.kwargs?.text??n.action_data?.kwargs?.value??"",c=[];return c.push(`action_data: { kwargs: { text: ${JSON.stringify(l)} } }`),n.locator?c.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&c.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&c.push(`frame_path: ${JSON.stringify(n.frame_path)}`),['await agent.execAction("input_text", page, {',...c.map(u=>` ${u},`),"});"]}};async function Ua(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ts(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var ja=Me.object({element_index:Me.number().int().describe("Index of the input element"),text:Me.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:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function uo(n,l){n.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:ja,usesElementIndex:!0,async execute(c,u){let{element_index:h,text:y}=c,{page:x,agentServices:w,actionDescription:g}=u;try{let E=await K(u,h);if(!E)return{success:!1,error:`Input element with index ${h} not found`,actionEntity:Ts(g||`Input text to element ${h}`,"input_text",{index:h,text:y})};let C=g||`Input text to element ${h}`,M=await Ua("input_text",C,E,x,{text:y});return await l.execute(x,M,w),{success:!0,actionEntity:M,message:`Input text to element ${h}`}}catch(E){return{success:!1,error:E.message,actionEntity:Ts(`Input text to element ${h}`,"input_text",{index:h,text:y})}}}})}var za=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.page_id??u.kwargs.index;if(h===void 0&&(h=n.context().pages().indexOf(n)),typeof h=="number"){if(h===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");c&&await c.closeTab(h)}else throw new Error("Missing page_id for close_tab action")}transpile(n){let l=n.action_data?.kwargs?.page_id;return l=l??n.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${l} } },`,"});"]}},Va=Es.object({index:Es.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")});function fo(n,l){n.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Va,async execute(c,u){let{index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Close tab ${h}`,action_data:{action_name:"close_tab",kwargs:{page_id:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Closed tab ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:g.message}}}}})}var Ha=class{async execute(n,l){}transpile(n){return["// Done - no action needed"]}},Ja=dt.object({success:dt.boolean().describe("Whether the task was completed successfully"),summary:dt.string().describe("Summary of what was accomplished or why it failed")});function xo(n,l){n.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Ja,async execute(c,u){let{page:h,agentServices:y}=u;try{let x={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await l.execute(h,x,y),{success:!0,actionEntity:x,message:"Task marked as complete"}}catch(x){return{success:!1,error:x.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:x.message}}}}})}j();var Cs=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u)await u.dblclick({timeout:h});else throw new Error("No locator found for double_click action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...l.map(c=>` ${c},`),"});"]}};async function qa(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ss(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var Wa=mt.object({element_index:mt.number().int().describe("Index of the element to double-click"),timeout_ms:mt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function wo(n,l){n.register({name:"double_click",description:"Double-click an interactive element.",schema:Wa,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ss(`Double-click element ${h}`,"double_click",{index:h})};let E=w||`Double-click element ${h}`,C=await qa("double_click",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Double-clicked element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ss(`Double-click element ${h}`,"double_click",{index:h})}}}})}var Ka=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.otp_secret_key;if(!h)throw new Error("Missing otp_secret_key for generate_2fa_code");let y=c.replaceVariables(String(h)),x=await c.generate2faCode(y);c.saveVariable("otp_code",x)}transpile(n){let l=n.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(l)} } },`,"});"]}},Xa=ks.object({otp_secret_key:ks.string().describe("The OTP secret key to generate the 2FA code from")});function Po(n,l){n.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:Xa,async execute(c,u){let{otp_secret_key:h}=c,{page:y,agentServices:x}=u;try{let w={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:h}}};return await l.execute(y,w,x),{success:!0,actionEntity:w,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:h}},feedback:w.message}}}}})}var Ya=ss(Mr(),1);function Ga(n){if(!n.trim())return!1;try{return(0,Ya.parse)(n,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var bt={};Zt(bt,{default:()=>Za});es(bt,Qa);var ft=class{async execute(n,l,c){let u=l.action_data?.kwargs,h=typeof u?.code=="string",y=h?u?.statement||l.action_description:l.action_description||u?.statement;if(h&&y){let C=Date.now();try{await this.executeJSAssertion(n,u.code,c),W.info(`[VERIFY:JS] \u2713 ${((Date.now()-C)/1e3).toFixed(1)}s: ${y}`);return}catch(M){let H=((Date.now()-C)/1e3).toFixed(1);W.info(`[VERIFY:JS\u2192AI] JS failed ${H}s (${M instanceof Error?M.message:String(M)}), falling back to AI: ${y}`)}}else if(h){let C=Date.now();await this.executeJSAssertion(n,u.code,c),W.info(`[VERIFY:JS] \u2713 ${((Date.now()-C)/1e3).toFixed(1)}s: ${y||"js-only"}`);return}if(!y)throw new Error("Missing statement or code for verify action");let x=Date.now();W.info(`[VERIFY:AI] Evaluating: ${y}`);let{evaluateStatement:w}=await import("./agentHelpers-CBXDLHMV-FEWOZV7Q.js"),g=await w(y,n,c,{useCleanScreenshotForAssertion:!0}),E=g.explanation||g.error||(g.success?`Assertion passed: ${y}`:"Assertion failed");if(c.addNote(E),!g.success)throw W.info(`[VERIFY:AI] \u2717 ${((Date.now()-x)/1e3).toFixed(1)}s: ${y}`),new Error(g.error||g.explanation||"Assertion failed");W.info(`[VERIFY:AI] \u2713 ${((Date.now()-x)/1e3).toFixed(1)}s: ${y}`)}async executeJSAssertion(n,l,c){try{await new Function("page","expect","agentServices",`
|
|
32
|
+
Use the exact text string in select_dropdown_option`,c.addNote(h)}else c.addNote("No options found in any frame for dropdown")}transpile(n){let l=[];return n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("get_dropdown_options", page, {});']:['await agent.execAction("get_dropdown_options", page, {',...l.map(c=>` ${c},`),"});"]}};async function Da(n,l,c){return{...await X(l,n),action_description:c||"Get dropdown options",action_data:{action_name:"get_dropdown_options",kwargs:{}}}}function gs(n,l){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:"get_dropdown_options",kwargs:l},feedback:"Element not found in DOM"}}var Fa=xs.object({element_index:xs.number().int().describe("Index of the dropdown/select element")});function ro(n,l){n.register({name:"get_dropdown_options",description:"Get all options from a native dropdown",schema:Fa,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Dropdown element with index ${h} not found`,actionEntity:gs(w||`Get options from dropdown ${h}`,{index:h})};let E=await Da(g,y,w);return await l.execute(y,E,x),{success:!0,actionEntity:E,message:E.feedback||"No options found"}}catch(g){return{success:!1,error:g.message,actionEntity:gs(w||`Get options from dropdown ${h}`,{index:h})}}}})}j();var Ba=class{async execute(n,l){await n.goBack({timeout:ue}),await n.waitForLoadState("load",{timeout:ue}),await n.waitForTimeout(1e3)}transpile(n){return['await agent.execAction("go_back", page, {});']}},Oa=La.object({});function no(n,l){n.register({name:"go_back",description:"Navigate back to the previous page in browser history.",schema:Oa,async execute(c,u){let{page:h,agentServices:y,actionDescription:x}=u;try{let w={action_description:x||"Go back",action_data:{action_name:"go_back",kwargs:{}}};return await l.execute(h,w,y),{success:!0,actionEntity:w,message:"Navigated back"}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:(x||"Go back")+" (failed)",action_data:{action_name:"go_back",kwargs:{}},feedback:w.message}}}}})}j();var ws=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.url;if(!h)throw new Error("Missing URL for go_to_url action");let y=u.kwargs.new_tab===!0,x=c.replaceVariables(String(h));if(x.startsWith("/")){let E=n.url(),C=null;try{let M=new URL(E);M.origin&&M.origin!=="null"&&(C=M.origin)}catch{}C&&(x=C+x)}let w=u.kwargs.timeout_seconds?u.kwargs.timeout_seconds*1e3:ue,g=n;y&&(g=await n.context().newPage(),c.setPage(g)),await g.goto(x,{timeout:w})}transpile(n){let l=n.action_data?.kwargs?.url||"",c=n.action_data?.kwargs?.new_tab===!0,u=n.action_data?.kwargs?.timeout_seconds,h=[`url: ${JSON.stringify(l)}`];return c&&h.push("new_tab: true"),u&&h.push(`timeout_seconds: ${u}`),['await agent.execAction("go_to_url", page, {',` action_data: { kwargs: { ${h.join(", ")} } },`,"});"]}},Ma=Oe.object({url:Oe.string().describe("URL to navigate to (must be a valid HTTP/HTTPS URL)"),new_tab:Oe.boolean().optional().describe("If true, open the URL in a new tab instead of the current page. Default is false."),timeout_seconds:Oe.number().positive().optional().describe("Navigation timeout in seconds. Default is 20 seconds.")});function lo(n,l){n.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:Ma,async execute(c,u){let{url:h,new_tab:y,timeout_seconds:x}=c,{page:w,agentServices:g,actionDescription:E}=u,C={url:h,new_tab:y??!1};x!==void 0&&(C.timeout_seconds=x);let M=x?` (timeout: ${x}s)`:"";try{let H=y?`Open ${h} in new tab`:`Navigate to ${h}`,Y={action_description:E||H,action_data:{action_name:"go_to_url",kwargs:C}};return await l.execute(w,Y,g),{success:!0,actionEntity:Y,message:(y?`Opened ${h} in new tab`:`Navigated to ${h}`)+M}}catch(H){let Y=y?`Open ${h} in new tab`:`Navigate to ${h}`;return{success:!1,error:H.message,actionEntity:{action_description:(E||Y)+" (failed)",action_data:{action_name:"go_to_url",kwargs:C},feedback:H.message}}}}})}j();var As=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u){await u.waitFor({state:"attached",timeout:h});let y=await u.elementHandle();if(!y)throw new Error("Unable to obtain element handle for hover action");let x=await y.boundingBox();if(!x)throw new Error("Unable to determine bounding box for hover action");let w=x.x+x.width/2,g=x.y+x.height/2;await n.mouse.move(w,g)}else throw new Error("No locator found for hover action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("hover", page, {});']:['await agent.execAction("hover", page, {',...l.map(c=>` ${c},`),"});"]}};async function $a(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ps(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var Ra=ut.object({element_index:ut.number().int().describe("Index of the element to hover over"),timeout_ms:ut.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function co(n,l){n.register({name:"hover",description:"Hover over an interactive element.",schema:Ra,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ps(`Hover element ${h}`,"hover",{index:h})};let E=w||`Hover over element ${h}`,C=await $a("hover",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Hovered over element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ps(`Hover element ${h}`,"hover",{index:h})}}}})}j();var bs=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.text??u.kwargs.value??"",y=c.replaceVariables(String(h)),x=V(n,l),w=z(c,l.action_data?.kwargs?.timeout_ms);if(x){await x.evaluate(E=>{E.value&&(E.value="")},null,{timeout:w}),await x.click({timeout:w}),await n.waitForTimeout(200);let g=c.getActionSettings().type_delay;g!==void 0?await n.keyboard.type(y,{delay:g}):await n.keyboard.type(y)}else throw new Error("No locator found for input_text action")}transpile(n){let l=n.action_data?.kwargs?.text??n.action_data?.kwargs?.value??"",c=[];return c.push(`action_data: { kwargs: { text: ${JSON.stringify(l)} } }`),n.locator?c.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&c.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&c.push(`frame_path: ${JSON.stringify(n.frame_path)}`),['await agent.execAction("input_text", page, {',...c.map(u=>` ${u},`),"});"]}};async function Ua(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ts(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var ja=Me.object({element_index:Me.number().int().describe("Index of the input element"),text:Me.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:Me.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function uo(n,l){n.register({name:"input_text",description:"Type text into an input field. To replace existing content, use clear_input first.",schema:ja,usesElementIndex:!0,async execute(c,u){let{element_index:h,text:y}=c,{page:x,agentServices:w,actionDescription:g}=u;try{let E=await K(u,h);if(!E)return{success:!1,error:`Input element with index ${h} not found`,actionEntity:Ts(g||`Input text to element ${h}`,"input_text",{index:h,text:y})};let C=g||`Input text to element ${h}`,M=await Ua("input_text",C,E,x,{text:y});return await l.execute(x,M,w),{success:!0,actionEntity:M,message:`Input text to element ${h}`}}catch(E){return{success:!1,error:E.message,actionEntity:Ts(`Input text to element ${h}`,"input_text",{index:h,text:y})}}}})}var za=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.page_id??u.kwargs.index;if(h===void 0&&(h=n.context().pages().indexOf(n)),typeof h=="number"){if(h===0)throw new Error("Cannot close the first tab (page_id 0). Skipping close_tab action.");c&&await c.closeTab(h)}else throw new Error("Missing page_id for close_tab action")}transpile(n){let l=n.action_data?.kwargs?.page_id;return l=l??n.action_data?.kwargs?.index,['await agent.execAction("close_tab", page, {',` action_data: { kwargs: { page_id: ${l} } },`,"});"]}},Va=Es.object({index:Es.number().int().nonnegative().optional().describe("Index of the tab to close (0-based). Defaults to current tab if not specified.")});function fo(n,l){n.register({name:"close_tab",description:"Close a browser tab by index. If no index is specified, closes the current tab.",schema:Va,async execute(c,u){let{index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g={action_description:w||`Close tab ${h}`,action_data:{action_name:"close_tab",kwargs:{page_id:h}}};return await l.execute(y,g,x),{success:!0,actionEntity:g,message:`Closed tab ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:(w||"Close tab")+" (failed)",action_data:{action_name:"close_tab",kwargs:{}},feedback:g.message}}}}})}var Ha=class{async execute(n,l){}transpile(n){return["// Done - no action needed"]}},Ja=dt.object({success:dt.boolean().describe("Whether the task was completed successfully"),summary:dt.string().describe("Summary of what was accomplished or why it failed")});function xo(n,l){n.register({name:"done",description:"Mark the current task as complete. Use when you have finished all requested actions.",schema:Ja,async execute(c,u){let{page:h,agentServices:y}=u;try{let x={action_description:"Task completed",action_data:{action_name:"done",kwargs:{}}};return await l.execute(h,x,y),{success:!0,actionEntity:x,message:"Task marked as complete"}}catch(x){return{success:!1,error:x.message,actionEntity:{action_description:"Task completed (failed)",action_data:{action_name:"done",kwargs:{}},feedback:x.message}}}}})}j();var Cs=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u)await u.dblclick({timeout:h});else throw new Error("No locator found for double_click action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("double_click", page, {});']:['await agent.execAction("double_click", page, {',...l.map(c=>` ${c},`),"});"]}};async function qa(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ss(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var Wa=mt.object({element_index:mt.number().int().describe("Index of the element to double-click"),timeout_ms:mt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function wo(n,l){n.register({name:"double_click",description:"Double-click an interactive element.",schema:Wa,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ss(`Double-click element ${h}`,"double_click",{index:h})};let E=w||`Double-click element ${h}`,C=await qa("double_click",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Double-clicked element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ss(`Double-click element ${h}`,"double_click",{index:h})}}}})}var Ka=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.otp_secret_key;if(!h)throw new Error("Missing otp_secret_key for generate_2fa_code");let y=c.replaceVariables(String(h)),x=await c.generate2faCode(y);c.saveVariable("otp_code",x)}transpile(n){let l=n.action_data?.kwargs?.otp_secret_key||"";return['await agent.execAction("generate_2fa_code", page, {',` action_data: { kwargs: { otp_secret_key: ${JSON.stringify(l)} } },`,"});"]}},Xa=ks.object({otp_secret_key:ks.string().describe("The OTP secret key to generate the 2FA code from")});function Po(n,l){n.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:Xa,async execute(c,u){let{otp_secret_key:h}=c,{page:y,agentServices:x}=u;try{let w={action_description:"Generate 2FA code",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:h}}};return await l.execute(y,w,x),{success:!0,actionEntity:w,message:'Generated 2FA code and saved to variable "otp_code"'}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:"Generate 2FA code (failed)",action_data:{action_name:"generate_2fa_code",kwargs:{otp_secret_key:h}},feedback:w.message}}}}})}var Ya=ss(Mr(),1);function Ga(n){if(!n.trim())return!1;try{return(0,Ya.parse)(n,{sourceType:"module",plugins:["typescript"]}),!0}catch{return!1}}var bt={};Zt(bt,{default:()=>Za});es(bt,Qa);var ft=class{async execute(n,l,c){let u=l.action_data?.kwargs,h=typeof u?.code=="string",y=h?u?.statement||l.action_description:l.action_description||u?.statement;if(h&&y){let C=Date.now();try{await this.executeJSAssertion(n,u.code,c),W.info(`[VERIFY:JS] \u2713 ${((Date.now()-C)/1e3).toFixed(1)}s: ${y}`);return}catch(M){let H=((Date.now()-C)/1e3).toFixed(1);W.info(`[VERIFY:JS\u2192AI] JS failed ${H}s (${M instanceof Error?M.message:String(M)}), falling back to AI: ${y}`)}}else if(h){let C=Date.now();await this.executeJSAssertion(n,u.code,c),W.info(`[VERIFY:JS] \u2713 ${((Date.now()-C)/1e3).toFixed(1)}s: ${y||"js-only"}`);return}if(!y)throw new Error("Missing statement or code for verify action");let x=Date.now();W.info(`[VERIFY:AI] Evaluating: ${y}`);let{evaluateStatement:w}=await import("./agentHelpers-BWIZZVR4-6SA75OLH.js"),g=await w(y,n,c,{useCleanScreenshotForAssertion:!0}),E=g.explanation||g.error||(g.success?`Assertion passed: ${y}`:"Assertion failed");if(c.addNote(E),!g.success)throw W.info(`[VERIFY:AI] \u2717 ${((Date.now()-x)/1e3).toFixed(1)}s: ${y}`),new Error(g.error||g.explanation||"Assertion failed");W.info(`[VERIFY:AI] \u2713 ${((Date.now()-x)/1e3).toFixed(1)}s: ${y}`)}async executeJSAssertion(n,l,c){try{await new Function("page","expect","agentServices",`
|
|
33
33
|
return (async () => {
|
|
34
34
|
${l}
|
|
35
35
|
})();
|
|
36
36
|
`)(n,bt.expect,c)}catch(u){throw new Error(`Assertion failed: ${u instanceof Error?u.message:String(u)}`)}}transpile(n,l){let c=n.action_data?.kwargs,u=typeof c?.code=="string",h=u?c?.statement||n.action_description:n.action_description||c?.statement,y=JSON.stringify(l||"");if(u){let x=c.code;if(!Ga(x))return[`throw new Error("Invalid assertion code syntax: " + ${JSON.stringify(x)});`];if(h){let w=x.split(`
|
|
37
37
|
`),g=JSON.stringify(h);return["{ const _t = Date.now(); try {",...w.map(E=>` ${E}`),` console.log(\`[VERIFY:JS] \u2713 \${((Date.now()-_t)/1000).toFixed(1)}s: ${g}\`);`,"} 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: ${g}\`);`,` await agent.assert(page, ${g}, ${y});`,"} }"]}return x.split(`
|
|
38
|
-
`)}return h?[`await agent.assert(page, ${JSON.stringify(h)}, ${y});`]:["// Skipping verify: missing statement or code"]}},en=vs.object({statement:vs.string().describe('The nature language statement to verify (e.g., "The login was successful")')});function Eo(n,l){n.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:en,async execute(c,u){let{statement:h}=c,{page:y,agentServices:x}=u;try{let w={action_description:`${h}`,action_data:{action_name:"verify",kwargs:{statement:h}}};return await l.execute(y,w,x),{success:!0,actionEntity:w,message:`Assertion verified: ${h}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Verify: ${h} (failed)`,action_data:{action_name:"verify",kwargs:{statement:h}},feedback:w.message}}}},availability:{openai:!0,mcp:!0}})}var tn=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.element_description,y=u.kwargs.variable_name;if(!h||!y)throw new Error("Missing element_description or variable_name for ai_extract");let x=`Extract ${h} and save to ${y}`,{executeStep:w}=await import("./agentHelpers-CBXDLHMV-FEWOZV7Q.js"),g=await w(x,n,c);if(g.status!=="success")throw new Error(g.error||"Extraction failed")}transpile(n,l){let c=n.action_data?.kwargs?.element_description,u=n.action_data?.kwargs?.variable_name;if(!c||!u)return["// Skipping ai_extract: missing element_description or variable_name"];let h=JSON.stringify(c),y=JSON.stringify(u);return[`await agent.extract(page, ${h}, ${y}, '${l||""}');`]}},sn=yt.object({element_description:yt.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:yt.string().describe("Name of the variable to store the extracted value")});function So(n,l){n.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:sn,async execute(c,u){let{element_description:h,variable_name:y}=c,{page:x,agentServices:w}=u;try{let g={action_description:`Extract ${h} to ${y}`,action_data:{action_name:"ai_extract",kwargs:{element_description:h,variable_name:y}}};return await l.execute(x,g,w),{success:!0,actionEntity:g,message:`Extracted ${h} to ${y}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:`Extract ${h} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:h,variable_name:y}},feedback:g.message}}}},availability:{openai:!1,mcp:!0}})}j();var rn=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u)await u.click({timeout:h}),await n.keyboard.press("ControlOrMeta+a"),await n.waitForTimeout(200),await n.keyboard.press("Backspace"),await n.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...l.map(c=>` ${c},`),"});"]}};async function an(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Is(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var nn=xt.object({element_index:xt.number().int().describe("Index of the input element to clear"),timeout_ms:xt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function vo(n,l){n.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:nn,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Input element with index ${h} not found`,actionEntity:Is(w||`Clear element ${h}`,"clear_input",{index:h})};let E=w||`Clear element ${h}`,C=await an("clear_input",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Cleared element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Is(`Clear element ${h}`,"clear_input",{index:h})}}}})}j();var wt=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u){await u.click({timeout:h});try{await n.waitForTimeout(1e3)}catch{}}else throw new Error("No locator found for click action")}transpile(n){let l=De(n);if(!l)return['await agent.execAction("click", page, {});'];let c=z();return[`await ${l}.click({ timeout: ${c} });`]}};async function on(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ns(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var ln=gt.object({element_index:gt.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:gt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function No(n,l){n.register({name:"click",description:"Click an interactive element.",schema:ln,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ns(`Click element ${h}`,"click",{index:h})};let E=w||`Click element ${h}`,C=await on("click",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Clicked element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ns(`Click element ${h}`,"click",{index:h})}}}})}var hn=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],cn=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],_s=class{static isAiAction(n){let l=n.action_data?.action_name;return!l||(l==="verify"||l==="ai_assert"||l==="assert")&&n.action_data?.kwargs?.code?!1:hn.includes(l)}static getAiStatement(n){let l=n.action_data?.action_name;if(!l)return null;let c=n.action_data?.kwargs||{};switch(l){case"ai_action":case"ai_step":return c.statement||null;case"verify":case"ai_assert":case"assert":return c.statement||n.action_description||null;case"ai_extract":let u=c.element_description,h=c.variable_name;return u&&h?`Extract ${u} and save to ${h}`:null;case"ai_wait_until":return c.condition||null;default:return null}}static canSelfHeal(n){let l=n.action_data?.action_name;return!l||(l==="verify"||l==="ai_assert"||l==="assert")&&n.action_data?.kwargs?.code?!1:!cn.includes(l)}},Pt=class I{static registerAction(l,c){I.actions.set(l,c)}constructor(){I.initialized||(this.registerBuiltinActions(),I.initialized=!0)}registerBuiltinActions(){I.registerAction("go_to_url",new ws),I.registerAction("go_back",new Ba),I.registerAction("reload_page",new xa),I.registerAction("close_tab",new za),I.registerAction("switch_tab",new ra),I.registerAction("click",new wt),I.registerAction("hover",new As),I.registerAction("right_click",new ds),I.registerAction("double_click",new Cs),I.registerAction("click_by_coordinates",new Hr),I.registerAction("right_click_by_coordinates",new jr),I.registerAction("double_click_by_coordinates",new Jr),I.registerAction("drag_drop",new qr),I.registerAction("input_text",new bs),I.registerAction("clear_input",new rn),I.registerAction("press",new us),I.registerAction("send_keys_on_element",new $r),I.registerAction("scroll_on_element",new Sa),I.registerAction("scroll_to_text",new Ia),I.registerAction("scroll",new Be),I.registerAction("upload_file",new la),I.registerAction("wait_for_download_complete",new da),I.registerAction("get_dropdown_options",new _a),I.registerAction("select_dropdown_option",new Qr),I.registerAction("set_date_for_native_date_picker",new ta),I.registerAction("verify",new ft),I.registerAction("ai_action",new Kr),I.registerAction("ai_extract",new tn),I.registerAction("ai_step",new Xr),I.registerAction("ai_wait_until",new Yr),I.registerAction("generate_2fa_code",new Ka),I.registerAction("wait",new pa),I.registerAction("wait_for_page_ready",new Ur),I.registerAction("save_variable",new Pa),I.registerAction("js_code",new Vr),I.registerAction("js_action",new zr),I.registerAction("function",new Wr),I.registerAction("done",new Ha),I.registerAction("click_element",new wt),I.registerAction("click_element_by_index",new wt),I.registerAction("hover_element_by_index",new As),I.registerAction("right_click_on_element",new ds),I.registerAction("double_click_on_element",new Cs),I.registerAction("scroll_down",new Be),I.registerAction("scroll_up",new Be),I.registerAction("scroll_element",new Be),I.registerAction("send_keys",new us),I.registerAction("open_tab",new ws),I.registerAction("fill",new bs),I.registerAction("ai_assert",new ft),I.registerAction("assert",new ft)}getAction(l){return I.actions.get(l)}hasAction(l){return I.actions.has(l)}getActionNames(){return Array.from(I.actions.keys())}async execute(l,c,u){if(!u)throw new Error("AgentServices not found");let h=c.action_data?.action_name;if(!h)throw new Error("Action name not found in action_data");let y=this.getAction(h);if(!y)throw new Error(`Unknown action: ${h}`);await y.execute(l,c,u)}transpile(l,c,u){let{sanitizeForComment:h}=(j(),at(nt)),y=l.action_description||"",x=l.action_data?.action_name||"",w=this.getAction(x);if(!w)return[`// ${c}: Unknown action: ${x}`];let g=w.transpile(l,c);if(_s.isAiAction(l))return[`// ${c}: ${h(y)}`,"page = agent.agentServices.validatePage(page);",...g];let E=JSON.stringify(y),C=g.map(Y=>` ${Y}`),M=_s.canSelfHeal(l),H=u?JSON.stringify(u):"undefined";return[`// ${c}: ${h(y)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...C,`}, ${E}, '${c}', ${H}, ${M});`]}transpileUncachedAction(l,c,u=!1,h=!1,y){let{sanitizeForComment:x}=(j(),at(nt));if(!l)return[`// ${c}: Skipping - no description`];let w=JSON.stringify(l);if(h){let g=y?`, { stmtUid: ${JSON.stringify(y)} }`:"";return[`// ${c}: ${x(l)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${w}, '${c}'${g});`]}return[`// ${c}: ${x(l)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${w}, '${c}', ${u});`]}};Pt.actions=new Map,Pt.initialized=!1;var pn=Pt,_o=pn;export{Sn as a,vn as b,Nn as c,Dn as d,Bn as e,Mn as f,Un as g,zn as h,Hn as i,qn as j,Kn as k,Yn as l,Qn as m,eo as n,so as o,ro as p,no as q,lo as r,co as s,uo as t,fo as u,xo as v,wo as w,Po as x,Eo as y,So as z,vo as A,No as B,_s as C,pn as D,_o as E};
|
|
38
|
+
`)}return h?[`await agent.assert(page, ${JSON.stringify(h)}, ${y});`]:["// Skipping verify: missing statement or code"]}},en=vs.object({statement:vs.string().describe('The nature language statement to verify (e.g., "The login was successful")')});function Eo(n,l){n.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:en,async execute(c,u){let{statement:h}=c,{page:y,agentServices:x}=u;try{let w={action_description:`${h}`,action_data:{action_name:"verify",kwargs:{statement:h}}};return await l.execute(y,w,x),{success:!0,actionEntity:w,message:`Assertion verified: ${h}`}}catch(w){return{success:!1,error:w.message,actionEntity:{action_description:`Verify: ${h} (failed)`,action_data:{action_name:"verify",kwargs:{statement:h}},feedback:w.message}}}},availability:{openai:!0,mcp:!0}})}var tn=class{async execute(n,l,c){let u=l.action_data;if(!u)throw new Error("Action data not found");let h=u.kwargs.element_description,y=u.kwargs.variable_name;if(!h||!y)throw new Error("Missing element_description or variable_name for ai_extract");let x=`Extract ${h} and save to ${y}`,{executeStep:w}=await import("./agentHelpers-BWIZZVR4-6SA75OLH.js"),g=await w(x,n,c);if(g.status!=="success")throw new Error(g.error||"Extraction failed")}transpile(n,l){let c=n.action_data?.kwargs?.element_description,u=n.action_data?.kwargs?.variable_name;if(!c||!u)return["// Skipping ai_extract: missing element_description or variable_name"];let h=JSON.stringify(c),y=JSON.stringify(u);return[`await agent.extract(page, ${h}, ${y}, '${l||""}');`]}},sn=yt.object({element_description:yt.string().describe('Description of the element to extract (e.g., "the price of the product")'),variable_name:yt.string().describe("Name of the variable to store the extracted value")});function So(n,l){n.register({name:"ai_extract",description:"Use AI to extract information from the page and save it to a variable. MCP-only tool.",schema:sn,async execute(c,u){let{element_description:h,variable_name:y}=c,{page:x,agentServices:w}=u;try{let g={action_description:`Extract ${h} to ${y}`,action_data:{action_name:"ai_extract",kwargs:{element_description:h,variable_name:y}}};return await l.execute(x,g,w),{success:!0,actionEntity:g,message:`Extracted ${h} to ${y}`}}catch(g){return{success:!1,error:g.message,actionEntity:{action_description:`Extract ${h} (failed)`,action_data:{action_name:"ai_extract",kwargs:{element_description:h,variable_name:y}},feedback:g.message}}}},availability:{openai:!1,mcp:!0}})}j();var rn=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u)await u.click({timeout:h}),await n.keyboard.press("ControlOrMeta+a"),await n.waitForTimeout(200),await n.keyboard.press("Backspace"),await n.waitForTimeout(200);else throw new Error("No locator found for clear_input action")}transpile(n){let l=[];return n.locator?l.push(`locator: ${JSON.stringify(n.locator)}`):n.xpath&&l.push(`xpath: ${JSON.stringify(n.xpath)}`),n.frame_path&&n.frame_path.length>0&&l.push(`frame_path: ${JSON.stringify(n.frame_path)}`),l.length===0?['await agent.execAction("clear_input", page, {});']:['await agent.execAction("clear_input", page, {',...l.map(c=>` ${c},`),"});"]}};async function an(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Is(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var nn=xt.object({element_index:xt.number().int().describe("Index of the input element to clear"),timeout_ms:xt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function vo(n,l){n.register({name:"clear_input",description:"Clear the contents of an input field, textarea, or other editable element.",schema:nn,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Input element with index ${h} not found`,actionEntity:Is(w||`Clear element ${h}`,"clear_input",{index:h})};let E=w||`Clear element ${h}`,C=await an("clear_input",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Cleared element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Is(`Clear element ${h}`,"clear_input",{index:h})}}}})}j();var wt=class{async execute(n,l,c){let u=V(n,l),h=z(c,l.action_data?.kwargs?.timeout_ms);if(u){await u.click({timeout:h});try{await n.waitForTimeout(1e3)}catch{}}else throw new Error("No locator found for click action")}transpile(n){let l=De(n);if(!l)return['await agent.execAction("click", page, {});'];let c=z();return[`await ${l}.click({ timeout: ${c} });`]}};async function on(n,l,c,u,h={}){return{...await X(u,c),action_description:l,action_data:{action_name:n,kwargs:{...h}}}}function Ns(n,l,c){return{action_description:`${n} (failed - element not found)`,action_data:{action_name:l,kwargs:c},feedback:"Element not found in DOM"}}var ln=gt.object({element_index:gt.number().int().describe("Index of the element to click (0-based). Return -1 if no element found"),timeout_ms:gt.number().optional().describe("Per-action timeout in ms. Overrides the default 5s action timeout.")});function No(n,l){n.register({name:"click",description:"Click an interactive element.",schema:ln,usesElementIndex:!0,async execute(c,u){let{element_index:h}=c,{page:y,agentServices:x,actionDescription:w}=u;try{let g=await K(u,h);if(!g)return{success:!1,error:`Element with index ${h} not found.`,actionEntity:Ns(`Click element ${h}`,"click",{index:h})};let E=w||`Click element ${h}`,C=await on("click",E,g,y);return await l.execute(y,C,x),{success:!0,actionEntity:C,message:`Clicked element ${h}`}}catch(g){return{success:!1,error:g.message,actionEntity:Ns(`Click element ${h}`,"click",{index:h})}}}})}var hn=["ai_action","ai_step","ai_assert","ai_extract","ai_wait_until","verify","assert"],cn=["js_code","function","wait","wait_for_download_complete","wait_for_page_ready","extract_email_content","extract_activation_code"],_s=class{static isAiAction(n){let l=n.action_data?.action_name;return!l||(l==="verify"||l==="ai_assert"||l==="assert")&&n.action_data?.kwargs?.code?!1:hn.includes(l)}static getAiStatement(n){let l=n.action_data?.action_name;if(!l)return null;let c=n.action_data?.kwargs||{};switch(l){case"ai_action":case"ai_step":return c.statement||null;case"verify":case"ai_assert":case"assert":return c.statement||n.action_description||null;case"ai_extract":let u=c.element_description,h=c.variable_name;return u&&h?`Extract ${u} and save to ${h}`:null;case"ai_wait_until":return c.condition||null;default:return null}}static canSelfHeal(n){let l=n.action_data?.action_name;return!l||(l==="verify"||l==="ai_assert"||l==="assert")&&n.action_data?.kwargs?.code?!1:!cn.includes(l)}},Pt=class I{static registerAction(l,c){I.actions.set(l,c)}constructor(){I.initialized||(this.registerBuiltinActions(),I.initialized=!0)}registerBuiltinActions(){I.registerAction("go_to_url",new ws),I.registerAction("go_back",new Ba),I.registerAction("reload_page",new xa),I.registerAction("close_tab",new za),I.registerAction("switch_tab",new ra),I.registerAction("click",new wt),I.registerAction("hover",new As),I.registerAction("right_click",new ds),I.registerAction("double_click",new Cs),I.registerAction("click_by_coordinates",new Hr),I.registerAction("right_click_by_coordinates",new jr),I.registerAction("double_click_by_coordinates",new Jr),I.registerAction("drag_drop",new qr),I.registerAction("input_text",new bs),I.registerAction("clear_input",new rn),I.registerAction("press",new us),I.registerAction("send_keys_on_element",new $r),I.registerAction("scroll_on_element",new Sa),I.registerAction("scroll_to_text",new Ia),I.registerAction("scroll",new Be),I.registerAction("upload_file",new la),I.registerAction("wait_for_download_complete",new da),I.registerAction("get_dropdown_options",new _a),I.registerAction("select_dropdown_option",new Qr),I.registerAction("set_date_for_native_date_picker",new ta),I.registerAction("verify",new ft),I.registerAction("ai_action",new Kr),I.registerAction("ai_extract",new tn),I.registerAction("ai_step",new Xr),I.registerAction("ai_wait_until",new Yr),I.registerAction("generate_2fa_code",new Ka),I.registerAction("wait",new pa),I.registerAction("wait_for_page_ready",new Ur),I.registerAction("save_variable",new Pa),I.registerAction("js_code",new Vr),I.registerAction("js_action",new zr),I.registerAction("function",new Wr),I.registerAction("done",new Ha),I.registerAction("click_element",new wt),I.registerAction("click_element_by_index",new wt),I.registerAction("hover_element_by_index",new As),I.registerAction("right_click_on_element",new ds),I.registerAction("double_click_on_element",new Cs),I.registerAction("scroll_down",new Be),I.registerAction("scroll_up",new Be),I.registerAction("scroll_element",new Be),I.registerAction("send_keys",new us),I.registerAction("open_tab",new ws),I.registerAction("fill",new bs),I.registerAction("ai_assert",new ft),I.registerAction("assert",new ft)}getAction(l){return I.actions.get(l)}hasAction(l){return I.actions.has(l)}getActionNames(){return Array.from(I.actions.keys())}async execute(l,c,u){if(!u)throw new Error("AgentServices not found");let h=c.action_data?.action_name;if(!h)throw new Error("Action name not found in action_data");let y=this.getAction(h);if(!y)throw new Error(`Unknown action: ${h}`);await y.execute(l,c,u)}transpile(l,c,u){let{sanitizeForComment:h}=(j(),at(nt)),y=l.action_description||"",x=l.action_data?.action_name||"",w=this.getAction(x);if(!w)return[`// ${c}: Unknown action: ${x}`];let g=w.transpile(l,c);if(_s.isAiAction(l))return[`// ${c}: ${h(y)}`,"page = agent.agentServices.validatePage(page);",...g];let E=JSON.stringify(y),C=g.map(Y=>` ${Y}`),M=_s.canSelfHeal(l),H=u?JSON.stringify(u):"undefined";return[`// ${c}: ${h(y)}`,"page = agent.agentServices.validatePage(page);","await agent.step(page, async () => {",...C,`}, ${E}, '${c}', ${H}, ${M});`]}transpileUncachedAction(l,c,u=!1,h=!1,y){let{sanitizeForComment:x}=(j(),at(nt));if(!l)return[`// ${c}: Skipping - no description`];let w=JSON.stringify(l);if(h){let g=y?`, { stmtUid: ${JSON.stringify(y)} }`:"";return[`// ${c}: ${x(l)}`,"page = agent.agentServices.validatePage(page);",`await agent.run(page, ${w}, '${c}'${g});`]}return[`// ${c}: ${x(l)}`,"page = agent.agentServices.validatePage(page);",`await agent.execute(page, ${w}, '${c}', ${u});`]}};Pt.actions=new Map,Pt.initialized=!1;var pn=Pt,_o=pn;export{Sn as a,vn as b,Nn as c,Dn as d,Bn as e,Mn as f,Un as g,zn as h,Hn as i,qn as j,Kn as k,Yn as l,Qn as m,eo as n,so as o,ro as p,no as q,lo as r,co as s,uo as t,fo as u,xo as v,wo as w,Po as x,Eo as y,So as z,vo as A,No as B,_s as C,pn as D,_o as E};
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { createRequire as __createRequire } from "module";
|
|
3
|
+
const require = __createRequire(import.meta.url);
|
|
4
|
+
import{A as B,B as C,C as D,D as E,E as F,F as G,G as H,H as I,I as J,J as K,K as L,L as M,M as N,N as O,O as P,P as Q,Q as R,R as S,S as T,T as U,U as V,V as W,W as X,a as b,b as c,c as d,d as e,e as f,f as g,g as h,h as i,i as j,j as k,k as l,l as m,m as n,n as o,o as p,p as q,q as r,r as s,s as t,t as u,u as v,v as w,w as x,x as y,y as z,z as A}from"./chunk-JTLVXRYI.js";import"./chunk-7W6YLS2E.js";import"./chunk-VBI4DDSS.js";import{r as a}from"./chunk-F2VF6EGN.js";import"./chunk-R4J6G5GI.js";import"./chunk-2BZVD336.js";import"./chunk-HHCLRZRA.js";import"./chunk-67R4GP2H.js";import"./chunk-GTYDC5DF.js";import"./chunk-KG3IU2VV.js";import"./chunk-UBUBM7F7.js";import"./chunk-B7PRQ6ZM.js";import"./chunk-RONU7WUE.js";import"./chunk-X5NUVPAF.js";import"./chunk-HBXQFJ2K.js";import"./chunk-ETDHHU35.js";import"./chunk-LM633YUO.js";export{l as ACT_SUPPORTED_ACTIONS,b as ActionEntitySchema,R as BrowserTools,U as DataTools,S as DebugTools,g as ExtensionRelayServer,X as LocalTestTools,h as PROMPTS,m as RESOURCES,t as RelayTools,e as SessionManager,s as SessionTools,c as StatementSchema,V as TestCaseTools,d as TestFlowSchema,W as TestResultTools,f as TokenApiClient,k as ToolRegistry,a as WebAgent,z as actHandler,x as actSchema,F as clearExecutionHistoryHandler,D as clearExecutionHistorySchema,E as clearExecutionHistoryToolMeta,P as getActSchema,Q as getActToolDefinition,y as getActToolMeta,p as getActionEntitySchemaResource,O as getLocatorsHandler,M as getLocatorsSchema,N as getLocatorsToolMeta,I as getPageInfoHandler,G as getPageInfoSchema,H as getPageInfoToolMeta,i as getPrompt,r as getResource,n as getTestFlowJsonSchemaResource,o as getTestFlowYamlSchemaResource,L as inspectPageHandler,J as inspectPageSchema,K as inspectPageToolMeta,j as listPrompts,q as listResources,T as missingApiTokenError,w as navigateHandler,u as navigateSchema,v as navigateToolMeta,C as updateVariablesHandler,A as updateVariablesSchema,B as updateVariablesToolMeta};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { createRequire as __createRequire } from "module";
|
|
3
3
|
const require = __createRequire(import.meta.url);
|
|
4
|
-
import{a as O,b as P,c as Q,d as R,e as S,f as T,g as U,h as V,i as W,j as X,k as Y,l as Z,m as _,n as $,o as aa,p as ba,q as ca,r as da,s as ea,t as fa,u as ga}from"./chunk-
|
|
4
|
+
import{a as O,b as P,c as Q,d as R,e as S,f as T,g as U,h as V,i as W,j as X,k as Y,l as Z,m as _,n as $,o as aa,p as ba,q as ca,r as da,s as ea,t as fa,u as ga}from"./chunk-F2VF6EGN.js";import{j as l,k as m,l as n,m as o}from"./chunk-R4J6G5GI.js";import{a as f,c as g,d as h,e as i,f as j,g as k}from"./chunk-2BZVD336.js";import{b as J,e as K,f as L,g as M,h as N}from"./chunk-GTYDC5DF.js";import{a as p,b as q,c as r,d as s,e as t,f as u,g as v,h as w,i as x,j as y,k as z,l as A,m as B}from"./chunk-KG3IU2VV.js";import"./chunk-UBUBM7F7.js";import"./chunk-B7PRQ6ZM.js";import{C as H,E as I}from"./chunk-RONU7WUE.js";import{g as C,h as D,i as E,k as F,l as G}from"./chunk-X5NUVPAF.js";import{a,b,c,d,j as e}from"./chunk-HBXQFJ2K.js";import"./chunk-ETDHHU35.js";import"./chunk-LM633YUO.js";export{I as ActionHandler,H as ActionHelper,da as Agent,aa as AgentServices,ba as AgentStepEventTypes,ca as AgentTaskFailedError,_ as BrowserManager,w as DEFAULT_EVENT_LISTENER_LIMIT,A as DomService,v as EVENT_LISTENER_CANDIDATE_SELECTORS,B as HistoryTreeProcessor,f as INIT_SCRIPT,u as INTERACTION_EVENT_TYPES,t as INTERACTIVE_ROLES,e as LogLevel,l as LoginType,Y as MCPToolProvider,J as OpenAIToolProvider,ga as SDK_VERSION,p as ToolRegistry,m as TwoFactorAuthType,o as VariableStore,da as WebAgent,a as configureSdk,fa as createAgent,ea as createAgentContext,V as createToolRegistry,W as createToolRegistryWithCapabilities,T as ensureToolsRegistered,M as evaluateStatement,L as executeStep,Z as exportMCPTools,z as filterInteractionListeners,K as generateActionStep,G as getActionEntityLocatorInfo,h as getBrowserCdpUrl,X as getCapabilitySummary,F as getFramePath,r as getModel,j as getPageInfo,i as getPageWsUrl,$ as getPlatformFromDeviceName,s as getProviderOptions,b as getSdkConfig,U as getToolRegistry,O as injectUserFunction,y as isInteractionEventType,x as isInteractiveRole,R as loadKnowledgeMappings,Q as loadKnowledges,P as loadUserFunctions,d as logger,g as newBrowserContext,S as parseSSEStream,c as parseSdkLogLevelFromEnv,C as pickBestLocator,D as pickBestLocatorForElement,E as pickBestLocators,n as replaceVariables,N as runTask,k as setWindowBounds,q as toolRegistry};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { createRequire as __createRequire } from "module";
|
|
3
3
|
const require = __createRequire(import.meta.url);
|
|
4
|
-
import{D as r,E as e}from"./chunk-
|
|
4
|
+
import{D as r,E as e}from"./chunk-RONU7WUE.js";import"./chunk-X5NUVPAF.js";import"./chunk-HBXQFJ2K.js";import"./chunk-ETDHHU35.js";import"./chunk-LM633YUO.js";import{createRequire as t}from"module";var a=t(import.meta.url);export{r as ActionHandler,e as default};
|
package/dist/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { createRequire as __createRequire } from "module";
|
|
3
3
|
const require = __createRequire(import.meta.url);
|
|
4
|
-
var e="0.1.
|
|
4
|
+
var e="0.1.57",o=process.argv[2];if(process.argv.includes("--version")||process.argv.includes("-v")||o==="version"){let s=e==="unknown"||process.argv[1]?.includes("/monots");process.stdout.write(`shiplight-mcp ${s?`${e}-local`:e}
|
|
5
5
|
`),process.exit(0)}if(process.argv.includes("--chrome-extension-path")){let s=new URL("../chrome-extension",import.meta.url).pathname;process.stdout.write(s+`
|
|
6
6
|
`),process.exit(0)}(process.argv.includes("--help")||process.argv.includes("-h")||o==="help")&&(process.stdout.write(`shiplight-mcp ${e}
|
|
7
7
|
|
|
@@ -21,4 +21,4 @@ Environment variables:
|
|
|
21
21
|
GOOGLE_API_KEY Google API key (for Gemini models)
|
|
22
22
|
API_BASE_URL Shiplight API base URL (default: https://api.shiplight.ai)
|
|
23
23
|
TERMINATION_TIMEOUT Session termination timeout in ms
|
|
24
|
-
`),process.exit(0));var{startServer:t}=await import("./server-
|
|
24
|
+
`),process.exit(0));var{startServer:t}=await import("./server-HRQ65FLP.js");await t();
|
package/dist/{relayBrowserCache-QL6LD4JJ-AD6FFB2L.js → relayBrowserCache-QL6LD4JJ-7EUDH6YT.js}
RENAMED
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
import { createRequire as __createRequire } from "module";
|
|
3
3
|
const require = __createRequire(import.meta.url);
|
|
4
|
-
import{a as e,b as o,c as t}from"./chunk-VBI4DDSS.js";import"./chunk-
|
|
4
|
+
import{a as e,b as o,c as t}from"./chunk-VBI4DDSS.js";import"./chunk-F2VF6EGN.js";import"./chunk-R4J6G5GI.js";import"./chunk-2BZVD336.js";import"./chunk-GTYDC5DF.js";import"./chunk-KG3IU2VV.js";import"./chunk-UBUBM7F7.js";import"./chunk-B7PRQ6ZM.js";import"./chunk-RONU7WUE.js";import"./chunk-X5NUVPAF.js";import"./chunk-HBXQFJ2K.js";import"./chunk-ETDHHU35.js";import"./chunk-LM633YUO.js";export{e as connectBrowser,o as forceDisconnect,t as getCacheStatus};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
import { createRequire as __createRequire } from "module";
|
|
3
|
+
const require = __createRequire(import.meta.url);
|
|
4
|
+
import{U as _,e as S,h as I,i as O,j as A,p as C,q as k}from"./chunk-JTLVXRYI.js";import"./chunk-7W6YLS2E.js";import"./chunk-VBI4DDSS.js";import"./chunk-F2VF6EGN.js";import"./chunk-R4J6G5GI.js";import"./chunk-2BZVD336.js";import"./chunk-HHCLRZRA.js";import"./chunk-67R4GP2H.js";import"./chunk-GTYDC5DF.js";import"./chunk-KG3IU2VV.js";import"./chunk-UBUBM7F7.js";import"./chunk-B7PRQ6ZM.js";import"./chunk-RONU7WUE.js";import"./chunk-X5NUVPAF.js";import{a as x,d as f}from"./chunk-HBXQFJ2K.js";import"./chunk-ETDHHU35.js";import"./chunk-LM633YUO.js";import{Server as se}from"@modelcontextprotocol/sdk/server/index.js";import{StdioServerTransport as te}from"@modelcontextprotocol/sdk/server/stdio.js";import{CallToolRequestSchema as oe,ListToolsRequestSchema as re,ListResourcesRequestSchema as ne,ReadResourceRequestSchema as ie,ListPromptsRequestSchema as ae,GetPromptRequestSchema as le,ErrorCode as v,McpError as E}from"@modelcontextprotocol/sdk/types.js";import $ from"axios";import ce from"dotenv";var U=new Set(["click","double_click","right_click","hover"]),V=new Set(["press","send_keys_on_element"]),q=`
|
|
5
|
+
@keyframes _sl_ripple {
|
|
6
|
+
0% { transform: translate(-50%,-50%) scale(1.0); opacity: 1; }
|
|
7
|
+
60% { transform: translate(-50%,-50%) scale(1.8); opacity: 0.9; }
|
|
8
|
+
100% { transform: translate(-50%,-50%) scale(4.0); opacity: 0; }
|
|
9
|
+
}
|
|
10
|
+
@keyframes _sl_dot {
|
|
11
|
+
0% { transform: translate(-50%,-50%) scale(1.0); opacity: 1; }
|
|
12
|
+
40% { transform: translate(-50%,-50%) scale(1.0); opacity: 1; }
|
|
13
|
+
100% { transform: translate(-50%,-50%) scale(0.0); opacity: 0; }
|
|
14
|
+
}
|
|
15
|
+
@keyframes _sl_key_pop {
|
|
16
|
+
0% { opacity: 0; transform: scale(0.6); }
|
|
17
|
+
15% { opacity: 1; transform: scale(1.15); }
|
|
18
|
+
25% { transform: scale(1.0); }
|
|
19
|
+
75% { opacity: 1; transform: scale(1.0); }
|
|
20
|
+
100% { opacity: 0; transform: scale(0.9); }
|
|
21
|
+
}
|
|
22
|
+
`;async function P(o,s,a,r,e){if(await o.evaluate(t=>{if(document.getElementById("_sl_styles"))return;let n=document.createElement("style");n.id="_sl_styles",n.textContent=t,document.head.appendChild(n)},q).catch(()=>{}),U.has(s)){let t=a.element_index;if(typeof t=="number"){let n=null;if(r){let i=r.selectorMap.get(t),l=i?.viewportCoordinates?.center;if(l)n=l;else if(i?.xpath)try{let p=i.xpath.startsWith("//")?i.xpath:`//${i.xpath}`,u=await o.locator(`xpath=${p}`).first().boundingBox({timeout:2e3});u&&(n={x:u.x+u.width/2,y:u.y+u.height/2})}catch{}}if(n){let{x:i,y:l}=n,p=s==="double_click";f.debug(`[indicator] ${s} at (${Math.round(i)}, ${Math.round(l)})`),await o.evaluate(({x:u,y:b,isDouble:D})=>{let m=window;m._sl_timers&&(m._sl_timers.forEach(c=>clearTimeout(c)),document.querySelectorAll("._sl_indicator").forEach(c=>c.remove())),m._sl_timers=[];function h(c){let T=document.createElement("div");T.className="_sl_indicator",T.style.cssText=["position:fixed",`left:${u}px`,`top:${b}px`,"width:80px","height:80px","border-radius:50%","background:rgba(255,30,30,0.25)","border:5px solid rgba(255,30,30,0.9)","pointer-events:none","z-index:2147483647",`animation:_sl_ripple 0.9s ${c}ms ease-out forwards`].join(";"),document.body.appendChild(T),m._sl_timers.push(setTimeout(()=>T.remove(),1e3+c))}function H(){let c=document.createElement("div");c.className="_sl_indicator",c.style.cssText=["position:fixed",`left:${u}px`,`top:${b}px`,"width:28px","height:28px","border-radius:50%","background:rgba(255,30,30,0.95)","pointer-events:none","z-index:2147483647","animation:_sl_dot 0.8s ease-in forwards"].join(";"),document.body.appendChild(c),m._sl_timers.push(setTimeout(()=>c.remove(),850))}h(0),h(200),H(),D&&(h(400),h(600))},{x:i,y:l,isDouble:p}),e&&await o.waitForTimeout(300)}else f.debug(`[indicator] ${s}: no coords for element_index ${t}`)}}else if(V.has(s)){let t=a.keys;typeof t=="string"&&(f.debug(`[indicator] ${s}: keys="${t}"`),await o.evaluate(({keysText:n})=>{let i=window;i._sl_timers&&(i._sl_timers.forEach(p=>clearTimeout(p)),document.querySelectorAll("._sl_indicator").forEach(p=>p.remove())),i._sl_timers=[];let l=document.createElement("div");l.className="_sl_indicator",l.style.cssText=["position:fixed","bottom:32px","left:0","right:0","width:fit-content","margin:0 auto","background:#1a1a1a","color:#fff","padding:14px 28px","border-radius:12px","font-size:28px","font-family:ui-monospace,monospace","font-weight:800","letter-spacing:0.04em","pointer-events:none","z-index:2147483647","border:3px solid rgba(255,255,255,0.25)","box-shadow:0 4px 32px rgba(0,0,0,0.5)","animation:_sl_key_pop 1.4s ease-out forwards"].join(";"),l.textContent="\u2328\uFE0F "+n,document.body.appendChild(l),i._sl_timers.push(setTimeout(()=>l.remove(),1500))},{keysText:t}),e&&await o.waitForTimeout(300))}}var y=class o{static _instance;_logLevel;constructor(){switch(process.env.LOG_LEVEL?.toUpperCase()){case"ERROR":this._logLevel=1;break;case"WARN":this._logLevel=2;break;case"INFO":this._logLevel=3;break;case"DEBUG":this._logLevel=4;break;default:this._logLevel=3}}static getInstance(){return o._instance||(o._instance=new o),o._instance}setLevel(s){this._logLevel=s}debug(...s){this._logLevel>=4&&console.error("[DEBUG]",...s)}info(...s){this._logLevel>=3&&console.error("[INFO]",...s)}warn(...s){this._logLevel>=2&&console.error("[WARN]",...s)}error(...s){this._logLevel>=1&&console.error("[ERROR]",...s)}log(...s){this.info(...s)}},F=y.getInstance(),d=F;import{createHash as W}from"node:crypto";import{hostname as K,userInfo as Y,platform as M,arch as j}from"node:os";import{PostHog as z}from"posthog-node";var J="phc_5Va2dHamGwJWX9qZqyRka5Lann5ATsg3LL4uyU63qin",X="https://us.i.posthog.com",Z=process.env.SHIPLIGHT_TELEMETRY==="0"||process.env.DO_NOT_TRACK==="1",g=null,G=!1;function Q(){return Z?null:(g||(g=new z(J,{host:X,flushAt:1,flushInterval:3e4})),g)}function ee(){let o=`${K()}:${Y().username}:${M()}:${j()}`;return W("sha256").update(o).digest("hex")}function N(o,s){let a=Q();if(a){G||(d.info("Anonymous usage telemetry enabled. Set SHIPLIGHT_TELEMETRY=0 to disable."),G=!0);try{a.capture({distinctId:ee(),event:"mcp_new_session",properties:{product:"mcp-server",version:o,platform:M(),nodeVersion:process.version,cloudMode:s,$geoip_disable:!0,$ip:null}}),a.flush().catch(()=>{})}catch{}}}process.env.PWDEBUG="console";var R=(...o)=>console.error(...o);console.log=R;console.info=R;console.debug=R;process.on("uncaughtException",o=>{console.error("[MCP] Uncaught exception (non-fatal):",o)});process.on("unhandledRejection",o=>{console.error("[MCP] Unhandled rejection (non-fatal):",o)});ce.config({override:!1});async function w(){let{SessionTools:o,RelayTools:s,BrowserTools:a,DebugTools:r,LocalTestTools:e,SessionManager:t,ExtensionRelayServer:n}=await import("./dist-CT5TSYOS.js");return{SessionTools:o,RelayTools:s,BrowserTools:a,DebugTools:r,LocalTestTools:e,SessionManager:t,ExtensionRelayServer:n}}var pe="SHIPLIGHT_API_TOKEN";function B(){return process.env[pe]||null}var L=class{constructor(s=!1,a=null){this.debugMode=s;this.relayPort=a;x({stderrOnly:!0});let r=process.env.API_BASE_URL||"https://api.shiplight.ai";this.server=new se({name:"shiplight-mcp",version:"1.0.0"},{capabilities:{tools:{},resources:{},prompts:{}}}),this.registry=new A;let e=B();if(this.apiClient=e?new S({apiBaseUrl:r,getApiToken:()=>B()}):null,this.apiClient){let t=new _(this.apiClient);this.testCaseTools=t,this.registry.registerTools(_,t,["getTestCase","getTemplate","getFunction","saveTestCase","saveTestAccount","saveTemplate","saveFunction"])}}server;registry;sessionBackend=null;apiClient;sessionTools=null;browserTools=null;debugTools=null;testCaseTools=null;localTestTools=null;relayTools=null;relayServer=null;async initBrowserTools(){let s=process.env.TERMINATION_TIMEOUT?parseInt(process.env.TERMINATION_TIMEOUT,10):null,{SessionTools:a,BrowserTools:r,DebugTools:e,LocalTestTools:t,SessionManager:n}=await w();this.sessionBackend=new n({terminationTimeout:s,onBeforeAction:process.env.SHIPLIGHT_ACTION_INDICATORS==="1"?P:void 0}),this.sessionTools=new a(this.sessionBackend,this.apiClient),this.browserTools=new r(this.sessionBackend),this.debugTools=new e(this.sessionBackend),this.localTestTools=new t(this.sessionBackend,this.apiClient);let{RelayTools:i}=await w();this.relayTools=new i(this.sessionBackend),this.registry.registerAll(a,this.sessionTools).registerAll(r,this.browserTools).registerAll(e,this.debugTools).registerAll(t,this.localTestTools).registerAll(i,this.relayTools),this.apiClient&&this.registry.registerAll({toolDefinitions:t.cloudToolDefinitions},this.localTestTools)}async startRelayServer(){if(this.relayPort===null)return!1;let s=this.relayPort,{RelayTools:a,ExtensionRelayServer:r}=await w();if(this.relayServer=new r,!this.sessionBackend||!this.relayTools)return d.error("[MCP] Cannot start relay server: session backend not initialized"),!1;try{return await this.relayServer.start(s),d.info(`[MCP] Chrome Extension Relay ready on port ${s}`),this.relayTools.setRelayServer(this.relayServer),this.debugMode&&this.registry.registerAll({toolDefinitions:a.debugToolDefinitions},this.relayTools),!0}catch(e){let t=e;return t.message&&t.message.includes("EADDRINUSE")?d.warn(`[MCP] Port ${s} already in use. Relay disabled for this instance.`):d.error("[MCP] Failed to start relay server:",e),this.relayServer=null,!1}}setupHandlers(){let{tools:s,handleToolCall:a}=this.registry.build();this.server.setRequestHandler(re,async()=>({tools:s})),this.server.setRequestHandler(oe,async r=>{try{let{name:e,arguments:t}=r.params,n=await a(e,t);return e==="new_session"&&N("0.1.57",!!this.apiClient),{content:[{type:"text",text:n}]}}catch(e){let t=e instanceof Error?e.message:String(e);if($.isAxiosError(e)){let n=e.config?.url,i=e.config?.baseURL,l=e.response?.status;t=`${e.code||"AxiosError"}: ${e.message}`,(i||n)&&(t+=` (${i||""}${n||""})`),l&&(t+=` [${l}]`),console.error(`[MCP] API error: ${t}`)}throw $.isAxiosError(e)&&e.response?.status===401&&(t="Authentication required. Contact info@shiplight.ai to get access to cloud services and advanced features."),new E(v.InternalError,t)}}),this.server.setRequestHandler(ne,async()=>({resources:C()})),this.server.setRequestHandler(ie,async r=>{let{uri:e}=r.params,t=await k(e);if(!t)throw new E(v.InvalidRequest,`Unknown resource: ${e}`);return{contents:[{uri:e,mimeType:"text/markdown",text:t}]}}),this.server.setRequestHandler(ae,async()=>({prompts:O().map(e=>({name:e.name,description:e.description}))})),this.server.setRequestHandler(le,async r=>{let{name:e}=r.params,t=I(e);if(!t)throw new E(v.InvalidRequest,`Unknown prompt: ${e}`);return{messages:[{role:"user",content:{type:"text",text:t}}]}})}async run(){await this.initBrowserTools(),await this.startRelayServer(),this.setupHandlers();let s=new te;await this.server.connect(s),d.info("Shiplight MCP Server running on stdio")}};async function Ae(){let o=process.argv.includes("--debug"),s=process.env.SHIPLIGHT_RELAY_PORT&&parseInt(process.env.SHIPLIGHT_RELAY_PORT,10)||null;await new L(o,s).run()}export{Ae as startServer};
|