@midscene/playground 1.0.3 → 1.0.4-beta-20251223105123.0
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/package.json +3 -3
- package/static/index.html +1 -1
- package/static/static/js/index.fb126448.js +10 -0
- package/static/static/js/{index.53e8ac1f.js.map → index.fb126448.js.map} +1 -1
- package/static/static/js/index.53e8ac1f.js +0 -10
- /package/static/static/js/{index.53e8ac1f.js.LICENSE.txt → index.fb126448.js.LICENSE.txt} +0 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/*! For license information please see index.fb126448.js.LICENSE.txt */
|
|
2
|
+
(()=>{var A,e,t,r,o,n,i,a={5737(A){function e(A){return Promise.resolve().then(function(){var e=Error("Cannot find module '"+A+"'");throw e.code="MODULE_NOT_FOUND",e})}e.keys=()=>[],e.resolve=e,e.id=5737,A.exports=e},9998(A){function e(A){return Promise.resolve().then(function(){var e=Error("Cannot find module '"+A+"'");throw e.code="MODULE_NOT_FOUND",e})}e.keys=()=>[],e.resolve=e,e.id=9998,A.exports=e},3348(A){function e(A){return Promise.resolve().then(function(){var e=Error("Cannot find module '"+A+"'");throw e.code="MODULE_NOT_FOUND",e})}e.keys=()=>[],e.resolve=e,e.id=3348,A.exports=e},1560(A){function e(A){return Promise.resolve().then(function(){var e=Error("Cannot find module '"+A+"'");throw e.code="MODULE_NOT_FOUND",e})}e.keys=()=>[],e.resolve=e,e.id=1560,A.exports=e},7517(A,e,t){"use strict";var r,o,n=t(5723),i=t(2155),a=t(8997),l=t(3244),s=t.n(l),c=t(3078),d=t.n(c),u=t(1344),p=t.n(u),g=t(7617),f=t.n(g),m=t(5207);let y="MIDSCENE_MODEL_INIT_CONFIG_JSON",h="MIDSCENE_MODEL_NAME",E="MIDSCENE_DEBUG_MODEL_PROFILE",v="MIDSCENE_DEBUG_MODEL_RESPONSE",C="MIDSCENE_MODEL_SOCKS_PROXY",b="MIDSCENE_MODEL_HTTP_PROXY",k="MIDSCENE_MODEL_API_KEY",S="MIDSCENE_MODEL_BASE_URL",I="MIDSCENE_MODEL_TIMEOUT",R="OPENAI_API_KEY",x="OPENAI_BASE_URL",P="MIDSCENE_OPENAI_INIT_CONFIG_JSON",j="MIDSCENE_OPENAI_HTTP_PROXY",w="MIDSCENE_OPENAI_SOCKS_PROXY",O="MIDSCENE_USE_VLM_UI_TARS",N="MIDSCENE_USE_QWEN_VL",K="MIDSCENE_USE_QWEN3_VL",B="MIDSCENE_USE_DOUBAO_VISION",T="MIDSCENE_USE_GEMINI",M="MATCH_BY_POSITION",z="MIDSCENE_RUN_DIR",D="MIDSCENE_INSIGHT_MODEL_NAME",Q="MIDSCENE_INSIGHT_MODEL_SOCKS_PROXY",Z="MIDSCENE_INSIGHT_MODEL_HTTP_PROXY",L="MIDSCENE_INSIGHT_MODEL_BASE_URL",X="MIDSCENE_INSIGHT_MODEL_API_KEY",J="MIDSCENE_INSIGHT_MODEL_INIT_CONFIG_JSON",U="MIDSCENE_INSIGHT_MODEL_TIMEOUT",F="MIDSCENE_PLANNING_MODEL_NAME",V="MIDSCENE_PLANNING_MODEL_SOCKS_PROXY",q="MIDSCENE_PLANNING_MODEL_HTTP_PROXY",G="MIDSCENE_PLANNING_MODEL_BASE_URL",H="MIDSCENE_PLANNING_MODEL_API_KEY",W="MIDSCENE_PLANNING_MODEL_INIT_CONFIG_JSON",Y="MIDSCENE_PLANNING_MODEL_TIMEOUT",_="MIDSCENE_MODEL_FAMILY",$=["MIDSCENE_DEBUG_MODE",E,v,z],AA=["MIDSCENE_CACHE","MIDSCENE_FORCE_DEEP_THINK","MIDSCENE_MCP_USE_PUPPETEER_MODE","MIDSCENE_MCP_ANDROID_MODE","MIDSCENE_LANGSMITH_DEBUG","MIDSCENE_LANGFUSE_DEBUG"],Ae=["MIDSCENE_CACHE_MAX_FILENAME_LENGTH","MIDSCENE_REPLANNING_CYCLE_LIMIT"],At=["MIDSCENE_MODEL_MAX_TOKENS","OPENAI_MAX_TOKENS","MIDSCENE_ADB_PATH","MIDSCENE_ADB_REMOTE_HOST","MIDSCENE_ADB_REMOTE_PORT","MIDSCENE_ANDROID_IME_STRATEGY","MIDSCENE_IOS_DEVICE_UDID","MIDSCENE_IOS_SIMULATOR_UDID","MIDSCENE_REPORT_TAG_NAME","MIDSCENE_PREFERRED_LANGUAGE",M,"MIDSCENE_MCP_CHROME_PATH","DOCKER_CONTAINER"],Ar=[...AA,...Ae,...At],Ao=[h,y,k,S,C,b,I,O,N,K,B,T,"MIDSCENE_USE_VL_MODEL",R,x,P,j,w,D,Q,Z,L,X,J,U,F,V,q,G,H,W,Y,_],An=["MIDSCENE_DANGEROUSLY_PRINT_ALL_CONFIG",...$,...Ar,...Ao],Ai=["doubao-vision","gemini","qwen2.5-vl","qwen3-vl","vlm-ui-tars","vlm-ui-tars-doubao","vlm-ui-tars-doubao-1.5"];var Aa=((r={}).V1_0="1.0",r.V1_5="1.5",r.DOUBAO_1_5_15B="doubao-1.5-15B",r.DOUBAO_1_5_20B="doubao-1.5-20B",r),Al=t(5409);let As=A=>{if(!$.includes(A))throw Error(`getBasicEnvValue with key ${A} is not supported.`);return Al.env[A]};t(7086);var Ac=t(3961),Ad=t(5409);let Au=void 0!==Ad&&(null==(o=Ad.versions)?void 0:o.node);var Ap=t(5409);let Ag="midscene_run",Af="midscene",Am=new Map,Ay=new Map;function Ah(A){let e=`${Af}:${A}`;if(!Ay.has(e)){let t=f()(e);Ay.set(e,function(){for(var e=arguments.length,r=Array(e),o=0;o<e;o++)r[o]=arguments[o];Au&&function(A,e){if(!Au)return;let t=function(A){let e=A.replace(/:/g,"-");if(!Am.has(e)){let A=d().join((A=>{if(!Au)return"";let e=(()=>{if(!Au)return"";let A=d().resolve(Ap.cwd(),Au?As(z)||Ag:"");if(!(0,l.existsSync)(A))try{(0,l.mkdirSync)(A,{recursive:!0})}catch(e){A=d().join((0,m.tmpdir)(),Ag),(0,l.mkdirSync)(A,{recursive:!0})}return A})(),t=d().join(e,A);return(0,l.existsSync)(t)||(0,l.mkdirSync)(t,{recursive:!0}),t})("log"),`${e}.log`),t=s().createWriteStream(A,{flags:"a"});Am.set(e,t)}return Am.get(e)}(A),r=new Date,o=r.toLocaleDateString("sv-SE"),n=r.toLocaleTimeString("sv-SE"),i=r.getMilliseconds().toString().padStart(3,"0"),a=r.getTimezoneOffset(),c=Math.floor(Math.abs(a)/60).toString().padStart(2,"0"),u=(Math.abs(a)%60).toString().padStart(2,"0"),p=`${a<=0?"+":"-"}${c}:${u}`,g=`${o}T${n}.${i}${p}`;t.write(`[${g}] ${e}
|
|
3
|
+
`)}(A,p().format(...r)),t(...r)})}return Ay.get(e)}let AE=()=>{var A;let e=As(E),t="";e&&(console.warn("MIDSCENE_DEBUG_MODEL_PROFILE is deprecated, use DEBUG=midscene:ai:profile instead"),t="ai:profile"),As(v)&&(console.warn("MIDSCENE_DEBUG_MODEL_RESPONSE is deprecated, use DEBUG=midscene:ai:response instead"),t=t?"ai:*":"ai:call"),t&&(A=t,Au||f().enable(`${Af}:${A}`))};var Av=t(5409);function AC(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let Ab=function(A){let e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"*";if("string"!=typeof A||0===A.length)return A;if(A.length<=6)return A;let t=A.substring(0,3),r=A.substring(A.length-3),o=A.length-6,n=e.repeat(o);return`${t}${n}${r}`},Ak=A=>Object.fromEntries(Object.entries(A).map(A=>{let[e,t]=A;if(!t)return[e,t];if("string"==typeof t&&/key/i.test(e))return[e,Ab(t)];if("object"==typeof t){let A=JSON.stringify(t);if(/key/i.test(A))return[e,Ab(A)]}return[e,t]})),AS={insight:{modelName:D,socksProxy:Q,httpProxy:Z,openaiBaseURL:L,openaiApiKey:X,openaiExtraConfig:J,modelFamily:"THERE_IS_NO_MODEL_FAMILY_FOR_INSIGHT",timeout:U},planning:{modelName:F,socksProxy:V,httpProxy:q,openaiBaseURL:G,openaiApiKey:H,openaiExtraConfig:W,modelFamily:"THERE_IS_NO_MODEL_FAMILY_FOR_PLANNING",timeout:Y},default:{modelName:h,socksProxy:C,httpProxy:b,openaiBaseURL:S,openaiApiKey:k,openaiExtraConfig:y,modelFamily:_,timeout:I}},AI=(A,e)=>{let t=Ah("ai:config");t("will decideModelConfig base on agent.modelConfig()",A,Ak(e));let r=AS[A];if(!e[r.modelName])return void t("no modelName found for intent",A);let o=(A=>{let{keys:e,provider:t,useLegacyLogic:r=!1}=A;AE(),Ah("ai:config")("enter parseOpenaiSdkConfig with keys:",e);let o=r?t[R]:void 0,n=r?t[x]:void 0,i=r?t[w]:void 0,a=r?t[j]:void 0,l=r?t[P]:void 0,s=r?(A=>{let e=A[B],t=A[N],r=A[K],o=A[O],n=A[T],i=[e&&B,t&&N,r&&K,o&&O,n&&T].filter(Boolean);if(i.length>1)throw Error(`Only one vision mode can be enabled at a time. Currently enabled modes: ${i.join(", ")}. Please disable all but one mode.`);if(r)return"qwen3-vl";if(t)return"qwen2.5-vl";if(e)return"doubao-vision";if(n)return"gemini";if(o)if("1"===o)return"vlm-ui-tars";else if("DOUBAO"===o||"DOUBAO-1.5"===o)return"vlm-ui-tars-doubao-1.5";else return"vlm-ui-tars-doubao"})(t):void 0,c=t[e.modelFamily]||s,d=t[e.openaiApiKey]||o,u=t[e.openaiBaseURL]||n,p=t[e.socksProxy]||i,g=t[e.httpProxy]||a,f=t[e.modelName],m=t[e.openaiExtraConfig],y=((A,e)=>{if(e)try{return JSON.parse(e)}catch(e){throw Error(`Failed to parse ${A} as a JSON. ${e.message}`,{cause:e})}})(e.openaiExtraConfig,m||l),{vlMode:h,uiTarsVersion:E}=(A=>{if(!A)return{vlMode:void 0,uiTarsVersion:void 0};if("vlm-ui-tars"===A)return{vlMode:"vlm-ui-tars",uiTarsVersion:Aa.V1_0};if("vlm-ui-tars-doubao"===A||"vlm-ui-tars-doubao-1.5"===A)return{vlMode:"vlm-ui-tars",uiTarsVersion:Aa.DOUBAO_1_5_20B};if(!Ai.includes(A))throw Error(`Invalid MIDSCENE_MODEL_FAMILY value: ${A}`);return{vlMode:A,uiTarsVersion:void 0}})(c),v=((A,e)=>{if(A)if(e)return`UI-TARS=${e}`;else return`${A} mode`;return""})(h,E);return{socksProxy:p,httpProxy:g,vlModeRaw:h,openaiBaseURL:u,openaiApiKey:d,openaiExtraConfig:y,vlMode:h,uiTarsModelVersion:E,modelName:f,modelDescription:v,intent:"-",timeout:t[e.timeout]?Number(t[e.timeout]):void 0}})({keys:r,provider:e,useLegacyLogic:"default"===A});o.intent=A,t("decideModelConfig result by agent.modelConfig() with intent",A,Ak({...o}));var n=o.openaiBaseURL,i=`failed to get base URL of model (intent=${A}). See https://midscenejs.com/model-strategy`;if(!n)throw Error(i||"Assertion failed");return o.modelName||console.warn(`modelName is not set for intent ${A}, this may cause unexpected behavior. See https://midscenejs.com/model-strategy`),o};function AR(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let Ax=new class{initialize(){var A;let e;if(this.isInitialized)return;this.modelConfig?(this.isolatedMode=!0,e=this.normalizeModelConfig(this.modelConfig)):e=(null==(A=this.globalConfigManager)?void 0:A.getAllEnvConfig())||{};let t=AI("default",e);if(!t)throw Error("default model config is not found, which should not happen");let r=AI("insight",e),o=AI("planning",e);this.modelConfigMap={default:{...t,createOpenAIClient:this.createOpenAIClientFn},insight:{...r||t,createOpenAIClient:this.createOpenAIClientFn},planning:{...o||t,createOpenAIClient:this.createOpenAIClientFn}},this.isInitialized=!0}normalizeModelConfig(A){return Object.entries(A).reduce((A,e)=>{let[t,r]=e;return null==r||(A[t]=String(r)),A},Object.create(null))}clearModelConfigMap(){if(this.isolatedMode)throw Error("ModelConfigManager work in isolated mode, so clearModelConfigMap should not be called");this.isInitialized=!1}getModelConfig(A){if(this.isInitialized||this.initialize(),!this.modelConfigMap)throw Error("modelConfigMap is not initialized, which should not happen");return this.modelConfigMap[A]}getUploadTestServerUrl(){let{openaiExtraConfig:A}=this.getModelConfig("default");return null==A?void 0:A.REPORT_SERVER_URL}registerGlobalConfigManager(A){this.globalConfigManager=A}throwErrorIfNonVLModel(){if(!this.getModelConfig("default").vlMode)throw Error("MIDSCENE_MODEL_FAMILY is not set to a visual language model (VL model), the element localization can not be achieved. Check your model configuration. See https://midscenejs.com/model-strategy.html")}constructor(A,e){AR(this,"modelConfigMap",void 0),AR(this,"isInitialized",!1),AR(this,"isolatedMode",!1),AR(this,"globalConfigManager",void 0),AR(this,"modelConfig",void 0),AR(this,"createOpenAIClientFn",void 0),this.modelConfig=A,this.createOpenAIClientFn=e}},AP=new class{getAllEnvConfig(){let A=An.reduce((A,e)=>(A[e]=Av.env[e],A),Object.create(null));if(!this.override)return A;{let{newConfig:e,extendMode:t}=this.override;return t?{...A,...e}:{...e}}}getEnvConfigValue(A){let e=this.getAllEnvConfig();if(A===M)throw Error("MATCH_BY_POSITION is discarded, use MIDSCENE_MODEL_FAMILY instead");if(!At.includes(A))throw Error(`getEnvConfigValue with key ${A} is not supported.`);let t=e[A];return(this.keysHaveBeenRead[A]=!0,"string"==typeof t)?t.trim():t}getEnvConfigInNumber(A){let e=this.getAllEnvConfig();if(!Ae.includes(A))throw Error(`getEnvConfigInNumber with key ${A} is not supported`);let t=e[A];return this.keysHaveBeenRead[A]=!0,Number(t||"")}getEnvConfigInBoolean(A){let e=this.getAllEnvConfig();if(!AA.includes(A))throw Error(`getEnvConfigInBoolean with key ${A} is not supported`);let t=e[A];return this.keysHaveBeenRead[A]=!0,!!t&&(!!/^(true|1)$/i.test(t)||!/^(false|0)$/i.test(t)&&!!t.trim())}registerModelConfigManager(A){this.globalModelConfigManager=A}overrideAIConfig(A){var e;let t=arguments.length>1&&void 0!==arguments[1]&&arguments[1];for(let e in A){if(![...Ar,...Ao].includes(e))throw Error(`Failed to override AI config, invalid key: ${e}`);let t=A[e];if("string"!=typeof t)throw Error(`Failed to override AI config, value for key ${e} must be a string, but got with type ${typeof t}`);this.keysHaveBeenRead[e]&&console.warn(`Warning: try to override AI config with key ${e} ,but it has been read.`)}let r=t?{...null==(e=this.override)?void 0:e.newConfig,...A}:A;if(this.override={newConfig:{...r},extendMode:t},!this.globalModelConfigManager)throw Error("globalModelConfigManager is not registered, which should not happen");this.globalModelConfigManager.clearModelConfigMap()}constructor(){AC(this,"override",void 0),AC(this,"keysHaveBeenRead",{}),AC(this,"globalModelConfigManager",void 0),AE()}};AP.registerModelConfigManager(Ax),Ax.registerGlobalConfigManager(AP);let Aj=function(A){let e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];AP.overrideAIConfig(A,e)};t(6990),t(5678),t(6732),t(8963),t(5592),t(8408),Ah("img");var Aw=t(6244);Ah("ai:common");let AO=Aw.z.object({left:Aw.z.number(),top:Aw.z.number()}),AN=Aw.z.object({width:Aw.z.number(),height:Aw.z.number(),dpr:Aw.z.number().optional()}),AK=AO.and(AN).and(Aw.z.object({zoom:Aw.z.number().optional()})),AB=Aw.z.object({images:Aw.z.array(Aw.z.object({name:Aw.z.string(),url:Aw.z.string()})).optional(),convertHttpImage2Base64:Aw.z.boolean().optional()}),AT=Aw.z.union([Aw.z.string(),Aw.z.object({prompt:Aw.z.string()}).and(AB.partial())]),AM="midscene_location_field_flag",Az=Aw.z.object({prompt:AT,deepThink:Aw.z.boolean().optional(),cacheable:Aw.z.boolean().optional(),xpath:Aw.z.union([Aw.z.string(),Aw.z.boolean()]).optional()}).passthrough();Aw.z.object({[AM]:Aw.z.literal(!0),prompt:AT,deepThink:Aw.z.boolean().optional(),cacheable:Aw.z.boolean().optional(),xpath:Aw.z.boolean().optional(),center:Aw.z.tuple([Aw.z.number(),Aw.z.number()]),rect:AK}).passthrough();let AD=(A,e)=>{var t;return A&&(null==(t=A._def)?void 0:t.typeName)==="ZodObject"&&A.shape?Object.keys(A.shape).filter(t=>{var r;let o=A.shape[t];return!!(A=>{var e,t;let r=A;if((null==(e=r._def)?void 0:e.typeName)==="ZodOptional"&&(r=r._def.innerType),(null==(t=r._def)?void 0:t.typeName)==="ZodObject"){let A=r._def.shape();if(AM in A||"prompt"in A&&A.prompt)return!0}return!1})(o)&&(!e||(null==(r=o._def)?void 0:r.typeName)!=="ZodOptional")}):[]};Ah("ai:inspect"),Ah("ai:section"),Ah("planning");var AQ=t(5409);let AZ={0:{keyCode:48,key:"0",code:"Digit0"},1:{keyCode:49,key:"1",code:"Digit1"},2:{keyCode:50,key:"2",code:"Digit2"},3:{keyCode:51,key:"3",code:"Digit3"},4:{keyCode:52,key:"4",code:"Digit4"},5:{keyCode:53,key:"5",code:"Digit5"},6:{keyCode:54,key:"6",code:"Digit6"},7:{keyCode:55,key:"7",code:"Digit7"},8:{keyCode:56,key:"8",code:"Digit8"},9:{keyCode:57,key:"9",code:"Digit9"},Power:{key:"Power",code:"Power"},Eject:{key:"Eject",code:"Eject"},Abort:{keyCode:3,code:"Abort",key:"Cancel"},Help:{keyCode:6,code:"Help",key:"Help"},Backspace:{keyCode:8,code:"Backspace",key:"Backspace"},Tab:{keyCode:9,code:"Tab",key:"Tab"},Numpad5:{keyCode:12,shiftKeyCode:101,key:"Clear",code:"Numpad5",shiftKey:"5",location:3},NumpadEnter:{keyCode:13,code:"NumpadEnter",key:"Enter",text:"\r",location:3},Enter:{keyCode:13,code:"Enter",key:"Enter",text:"\r"},"\r":{keyCode:13,code:"Enter",key:"Enter",text:"\r"},"\n":{keyCode:13,code:"Enter",key:"Enter",text:"\r"},ShiftLeft:{keyCode:16,code:"ShiftLeft",key:"Shift",location:1},ShiftRight:{keyCode:16,code:"ShiftRight",key:"Shift",location:2},ControlLeft:{keyCode:17,code:"ControlLeft",key:"Control",location:1},ControlRight:{keyCode:17,code:"ControlRight",key:"Control",location:2},AltLeft:{keyCode:18,code:"AltLeft",key:"Alt",location:1},AltRight:{keyCode:18,code:"AltRight",key:"Alt",location:2},Pause:{keyCode:19,code:"Pause",key:"Pause"},CapsLock:{keyCode:20,code:"CapsLock",key:"CapsLock"},Escape:{keyCode:27,code:"Escape",key:"Escape"},Convert:{keyCode:28,code:"Convert",key:"Convert"},NonConvert:{keyCode:29,code:"NonConvert",key:"NonConvert"},Space:{keyCode:32,code:"Space",key:" "},Numpad9:{keyCode:33,shiftKeyCode:105,key:"PageUp",code:"Numpad9",shiftKey:"9",location:3},PageUp:{keyCode:33,code:"PageUp",key:"PageUp"},Numpad3:{keyCode:34,shiftKeyCode:99,key:"PageDown",code:"Numpad3",shiftKey:"3",location:3},PageDown:{keyCode:34,code:"PageDown",key:"PageDown"},End:{keyCode:35,code:"End",key:"End"},Numpad1:{keyCode:35,shiftKeyCode:97,key:"End",code:"Numpad1",shiftKey:"1",location:3},Home:{keyCode:36,code:"Home",key:"Home"},Numpad7:{keyCode:36,shiftKeyCode:103,key:"Home",code:"Numpad7",shiftKey:"7",location:3},ArrowLeft:{keyCode:37,code:"ArrowLeft",key:"ArrowLeft"},Numpad4:{keyCode:37,shiftKeyCode:100,key:"ArrowLeft",code:"Numpad4",shiftKey:"4",location:3},Numpad8:{keyCode:38,shiftKeyCode:104,key:"ArrowUp",code:"Numpad8",shiftKey:"8",location:3},ArrowUp:{keyCode:38,code:"ArrowUp",key:"ArrowUp"},ArrowRight:{keyCode:39,code:"ArrowRight",key:"ArrowRight"},Numpad6:{keyCode:39,shiftKeyCode:102,key:"ArrowRight",code:"Numpad6",shiftKey:"6",location:3},Numpad2:{keyCode:40,shiftKeyCode:98,key:"ArrowDown",code:"Numpad2",shiftKey:"2",location:3},ArrowDown:{keyCode:40,code:"ArrowDown",key:"ArrowDown"},Select:{keyCode:41,code:"Select",key:"Select"},Open:{keyCode:43,code:"Open",key:"Execute"},PrintScreen:{keyCode:44,code:"PrintScreen",key:"PrintScreen"},Insert:{keyCode:45,code:"Insert",key:"Insert"},Numpad0:{keyCode:45,shiftKeyCode:96,key:"Insert",code:"Numpad0",shiftKey:"0",location:3},Delete:{keyCode:46,code:"Delete",key:"Delete"},NumpadDecimal:{keyCode:46,shiftKeyCode:110,code:"NumpadDecimal",key:"\0",shiftKey:".",location:3},Digit0:{keyCode:48,code:"Digit0",shiftKey:")",key:"0"},Digit1:{keyCode:49,code:"Digit1",shiftKey:"!",key:"1"},Digit2:{keyCode:50,code:"Digit2",shiftKey:"@",key:"2"},Digit3:{keyCode:51,code:"Digit3",shiftKey:"#",key:"3"},Digit4:{keyCode:52,code:"Digit4",shiftKey:"$",key:"4"},Digit5:{keyCode:53,code:"Digit5",shiftKey:"%",key:"5"},Digit6:{keyCode:54,code:"Digit6",shiftKey:"^",key:"6"},Digit7:{keyCode:55,code:"Digit7",shiftKey:"&",key:"7"},Digit8:{keyCode:56,code:"Digit8",shiftKey:"*",key:"8"},Digit9:{keyCode:57,code:"Digit9",shiftKey:"(",key:"9"},KeyA:{keyCode:65,code:"KeyA",shiftKey:"A",key:"a"},KeyB:{keyCode:66,code:"KeyB",shiftKey:"B",key:"b"},KeyC:{keyCode:67,code:"KeyC",shiftKey:"C",key:"c"},KeyD:{keyCode:68,code:"KeyD",shiftKey:"D",key:"d"},KeyE:{keyCode:69,code:"KeyE",shiftKey:"E",key:"e"},KeyF:{keyCode:70,code:"KeyF",shiftKey:"F",key:"f"},KeyG:{keyCode:71,code:"KeyG",shiftKey:"G",key:"g"},KeyH:{keyCode:72,code:"KeyH",shiftKey:"H",key:"h"},KeyI:{keyCode:73,code:"KeyI",shiftKey:"I",key:"i"},KeyJ:{keyCode:74,code:"KeyJ",shiftKey:"J",key:"j"},KeyK:{keyCode:75,code:"KeyK",shiftKey:"K",key:"k"},KeyL:{keyCode:76,code:"KeyL",shiftKey:"L",key:"l"},KeyM:{keyCode:77,code:"KeyM",shiftKey:"M",key:"m"},KeyN:{keyCode:78,code:"KeyN",shiftKey:"N",key:"n"},KeyO:{keyCode:79,code:"KeyO",shiftKey:"O",key:"o"},KeyP:{keyCode:80,code:"KeyP",shiftKey:"P",key:"p"},KeyQ:{keyCode:81,code:"KeyQ",shiftKey:"Q",key:"q"},KeyR:{keyCode:82,code:"KeyR",shiftKey:"R",key:"r"},KeyS:{keyCode:83,code:"KeyS",shiftKey:"S",key:"s"},KeyT:{keyCode:84,code:"KeyT",shiftKey:"T",key:"t"},KeyU:{keyCode:85,code:"KeyU",shiftKey:"U",key:"u"},KeyV:{keyCode:86,code:"KeyV",shiftKey:"V",key:"v"},KeyW:{keyCode:87,code:"KeyW",shiftKey:"W",key:"w"},KeyX:{keyCode:88,code:"KeyX",shiftKey:"X",key:"x"},KeyY:{keyCode:89,code:"KeyY",shiftKey:"Y",key:"y"},KeyZ:{keyCode:90,code:"KeyZ",shiftKey:"Z",key:"z"},MetaLeft:{keyCode:91,code:"MetaLeft",key:"Meta",location:1},MetaRight:{keyCode:92,code:"MetaRight",key:"Meta",location:2},ContextMenu:{keyCode:93,code:"ContextMenu",key:"ContextMenu"},NumpadMultiply:{keyCode:106,code:"NumpadMultiply",key:"*",location:3},NumpadAdd:{keyCode:107,code:"NumpadAdd",key:"+",location:3},NumpadSubtract:{keyCode:109,code:"NumpadSubtract",key:"-",location:3},NumpadDivide:{keyCode:111,code:"NumpadDivide",key:"/",location:3},F1:{keyCode:112,code:"F1",key:"F1"},F2:{keyCode:113,code:"F2",key:"F2"},F3:{keyCode:114,code:"F3",key:"F3"},F4:{keyCode:115,code:"F4",key:"F4"},F5:{keyCode:116,code:"F5",key:"F5"},F6:{keyCode:117,code:"F6",key:"F6"},F7:{keyCode:118,code:"F7",key:"F7"},F8:{keyCode:119,code:"F8",key:"F8"},F9:{keyCode:120,code:"F9",key:"F9"},F10:{keyCode:121,code:"F10",key:"F10"},F11:{keyCode:122,code:"F11",key:"F11"},F12:{keyCode:123,code:"F12",key:"F12"},F13:{keyCode:124,code:"F13",key:"F13"},F14:{keyCode:125,code:"F14",key:"F14"},F15:{keyCode:126,code:"F15",key:"F15"},F16:{keyCode:127,code:"F16",key:"F16"},F17:{keyCode:128,code:"F17",key:"F17"},F18:{keyCode:129,code:"F18",key:"F18"},F19:{keyCode:130,code:"F19",key:"F19"},F20:{keyCode:131,code:"F20",key:"F20"},F21:{keyCode:132,code:"F21",key:"F21"},F22:{keyCode:133,code:"F22",key:"F22"},F23:{keyCode:134,code:"F23",key:"F23"},F24:{keyCode:135,code:"F24",key:"F24"},NumLock:{keyCode:144,code:"NumLock",key:"NumLock"},ScrollLock:{keyCode:145,code:"ScrollLock",key:"ScrollLock"},AudioVolumeMute:{keyCode:173,code:"AudioVolumeMute",key:"AudioVolumeMute"},AudioVolumeDown:{keyCode:174,code:"AudioVolumeDown",key:"AudioVolumeDown"},AudioVolumeUp:{keyCode:175,code:"AudioVolumeUp",key:"AudioVolumeUp"},MediaTrackNext:{keyCode:176,code:"MediaTrackNext",key:"MediaTrackNext"},MediaTrackPrevious:{keyCode:177,code:"MediaTrackPrevious",key:"MediaTrackPrevious"},MediaStop:{keyCode:178,code:"MediaStop",key:"MediaStop"},MediaPlayPause:{keyCode:179,code:"MediaPlayPause",key:"MediaPlayPause"},Semicolon:{keyCode:186,code:"Semicolon",shiftKey:":",key:";"},Equal:{keyCode:187,code:"Equal",shiftKey:"+",key:"="},NumpadEqual:{keyCode:187,code:"NumpadEqual",key:"=",location:3},Comma:{keyCode:188,code:"Comma",shiftKey:"<",key:","},Minus:{keyCode:189,code:"Minus",shiftKey:"_",key:"-"},Period:{keyCode:190,code:"Period",shiftKey:">",key:"."},Slash:{keyCode:191,code:"Slash",shiftKey:"?",key:"/"},Backquote:{keyCode:192,code:"Backquote",shiftKey:"~",key:"`"},BracketLeft:{keyCode:219,code:"BracketLeft",shiftKey:"{",key:"["},Backslash:{keyCode:220,code:"Backslash",shiftKey:"|",key:"\\"},BracketRight:{keyCode:221,code:"BracketRight",shiftKey:"}",key:"]"},Quote:{keyCode:222,code:"Quote",shiftKey:'"',key:"'"},AltGraph:{keyCode:225,code:"AltGraph",key:"AltGraph"},Props:{keyCode:247,code:"Props",key:"CrSel"},Cancel:{keyCode:3,key:"Cancel",code:"Abort"},Clear:{keyCode:12,key:"Clear",code:"Numpad5",location:3},Shift:{keyCode:16,key:"Shift",code:"ShiftLeft",location:1},Control:{keyCode:17,key:"Control",code:"ControlLeft",location:1},Alt:{keyCode:18,key:"Alt",code:"AltLeft",location:1},Accept:{keyCode:30,key:"Accept"},ModeChange:{keyCode:31,key:"ModeChange"}," ":{keyCode:32,key:" ",code:"Space"},Print:{keyCode:42,key:"Print"},Execute:{keyCode:43,key:"Execute",code:"Open"},"\0":{keyCode:46,key:"\0",code:"NumpadDecimal",location:3},a:{keyCode:65,key:"a",code:"KeyA"},b:{keyCode:66,key:"b",code:"KeyB"},c:{keyCode:67,key:"c",code:"KeyC"},d:{keyCode:68,key:"d",code:"KeyD"},e:{keyCode:69,key:"e",code:"KeyE"},f:{keyCode:70,key:"f",code:"KeyF"},g:{keyCode:71,key:"g",code:"KeyG"},h:{keyCode:72,key:"h",code:"KeyH"},i:{keyCode:73,key:"i",code:"KeyI"},j:{keyCode:74,key:"j",code:"KeyJ"},k:{keyCode:75,key:"k",code:"KeyK"},l:{keyCode:76,key:"l",code:"KeyL"},m:{keyCode:77,key:"m",code:"KeyM"},n:{keyCode:78,key:"n",code:"KeyN"},o:{keyCode:79,key:"o",code:"KeyO"},p:{keyCode:80,key:"p",code:"KeyP"},q:{keyCode:81,key:"q",code:"KeyQ"},r:{keyCode:82,key:"r",code:"KeyR"},s:{keyCode:83,key:"s",code:"KeyS"},t:{keyCode:84,key:"t",code:"KeyT"},u:{keyCode:85,key:"u",code:"KeyU"},v:{keyCode:86,key:"v",code:"KeyV"},w:{keyCode:87,key:"w",code:"KeyW"},x:{keyCode:88,key:"x",code:"KeyX"},y:{keyCode:89,key:"y",code:"KeyY"},z:{keyCode:90,key:"z",code:"KeyZ"},Meta:{keyCode:91,key:"Meta",code:"MetaLeft",location:1},"*":{keyCode:106,key:"*",code:"NumpadMultiply",location:3},"+":{keyCode:107,key:"+",code:"NumpadAdd",location:3},"-":{keyCode:109,key:"-",code:"NumpadSubtract",location:3},"/":{keyCode:111,key:"/",code:"NumpadDivide",location:3},";":{keyCode:186,key:";",code:"Semicolon"},"=":{keyCode:187,key:"=",code:"Equal"},",":{keyCode:188,key:",",code:"Comma"},".":{keyCode:190,key:".",code:"Period"},"`":{keyCode:192,key:"`",code:"Backquote"},"[":{keyCode:219,key:"[",code:"BracketLeft"},"\\":{keyCode:220,key:"\\",code:"Backslash"},"]":{keyCode:221,key:"]",code:"BracketRight"},"'":{keyCode:222,key:"'",code:"Quote"},Attn:{keyCode:246,key:"Attn"},CrSel:{keyCode:247,key:"CrSel",code:"Props"},ExSel:{keyCode:248,key:"ExSel"},EraseEof:{keyCode:249,key:"EraseEof"},Play:{keyCode:250,key:"Play"},ZoomOut:{keyCode:251,key:"ZoomOut"},")":{keyCode:48,key:")",code:"Digit0"},"!":{keyCode:49,key:"!",code:"Digit1"},"@":{keyCode:50,key:"@",code:"Digit2"},"#":{keyCode:51,key:"#",code:"Digit3"},$:{keyCode:52,key:"$",code:"Digit4"},"%":{keyCode:53,key:"%",code:"Digit5"},"^":{keyCode:54,key:"^",code:"Digit6"},"&":{keyCode:55,key:"&",code:"Digit7"},"(":{keyCode:57,key:"(",code:"Digit9"},A:{keyCode:65,key:"A",code:"KeyA"},B:{keyCode:66,key:"B",code:"KeyB"},C:{keyCode:67,key:"C",code:"KeyC"},D:{keyCode:68,key:"D",code:"KeyD"},E:{keyCode:69,key:"E",code:"KeyE"},F:{keyCode:70,key:"F",code:"KeyF"},G:{keyCode:71,key:"G",code:"KeyG"},H:{keyCode:72,key:"H",code:"KeyH"},I:{keyCode:73,key:"I",code:"KeyI"},J:{keyCode:74,key:"J",code:"KeyJ"},K:{keyCode:75,key:"K",code:"KeyK"},L:{keyCode:76,key:"L",code:"KeyL"},M:{keyCode:77,key:"M",code:"KeyM"},N:{keyCode:78,key:"N",code:"KeyN"},O:{keyCode:79,key:"O",code:"KeyO"},P:{keyCode:80,key:"P",code:"KeyP"},Q:{keyCode:81,key:"Q",code:"KeyQ"},R:{keyCode:82,key:"R",code:"KeyR"},S:{keyCode:83,key:"S",code:"KeyS"},T:{keyCode:84,key:"T",code:"KeyT"},U:{keyCode:85,key:"U",code:"KeyU"},V:{keyCode:86,key:"V",code:"KeyV"},W:{keyCode:87,key:"W",code:"KeyW"},X:{keyCode:88,key:"X",code:"KeyX"},Y:{keyCode:89,key:"Y",code:"KeyY"},Z:{keyCode:90,key:"Z",code:"KeyZ"},":":{keyCode:186,key:":",code:"Semicolon"},"<":{keyCode:188,key:"<",code:"Comma"},_:{keyCode:189,key:"_",code:"Minus"},">":{keyCode:190,key:">",code:"Period"},"?":{keyCode:191,key:"?",code:"Slash"},"~":{keyCode:192,key:"~",code:"Backquote"},"{":{keyCode:219,key:"{",code:"BracketLeft"},"|":{keyCode:220,key:"|",code:"Backslash"},"}":{keyCode:221,key:"}",code:"BracketRight"},'"':{keyCode:222,key:'"',code:"Quote"},SoftLeft:{key:"SoftLeft",code:"SoftLeft",location:4},SoftRight:{key:"SoftRight",code:"SoftRight",location:4},Camera:{keyCode:44,key:"Camera",code:"Camera",location:4},Call:{key:"Call",code:"Call",location:4},EndCall:{keyCode:95,key:"EndCall",code:"EndCall",location:4},VolumeDown:{keyCode:182,key:"VolumeDown",code:"VolumeDown",location:4},VolumeUp:{keyCode:183,key:"VolumeUp",code:"VolumeUp",location:4}};Object.entries(AZ).reduce((A,e)=>{let[t,r]=e,o=t.toLowerCase();return o!==t&&(A[o]=r),A},{});let AL="undefined"!=typeof window?/Mac|iPod|iPhone|iPad/.test(window.navigator.platform):"darwin"===AQ.platform;AZ.Enter.key,AZ.Enter.key,AL?AZ.Meta.key:AZ.Control.key,AZ.Shift.key,AZ.Alt.key,AZ.Space.key,AZ.PageDown.key,AZ.PageDown.key,AZ.PageUp.key,AZ.PageUp.key,t(2788),Ah("ui-tars-planning"),t(3612),t(9383),t(5409);let AX=Ah("yaml:utils");function AJ(A,e){let t;AX("will call buildDetailedLocateParam",A,e);let r=A||(null==e?void 0:e.prompt)||(null==e?void 0:e.locate),o=!1,n=!0;return("object"==typeof e&&null!==e&&(o=e.deepThink??!1,n=e.cacheable??!0,t=e.xpath,A&&e.prompt&&A!==e.prompt&&console.warn("conflict prompt for item",A,e,"maybe you put the prompt in the wrong place"),r=r||e.prompt),r)?{prompt:r,deepThink:o,cacheable:n,xpath:t}:void AX("no prompt, will return undefined in buildDetailedLocateParam",e)}t(5409),Ah("yaml-player");let AU=["aiQuery","aiBoolean","aiNumber","aiString","aiAsk","aiAssert","aiWaitFor"];async function AF(A,e){let t=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!(null==A?void 0:A.paramSchema)||!("shape"in A.paramSchema))return[e.prompt||"",t];let r=A.paramSchema,o=r&&"shape"in r?Object.keys(r.shape):[],{deviceOptions:n,...i}=t,a={...i,...t.deviceOptions||{}};return o.forEach(A=>{void 0!==e[A]&&null!==e[A]&&""!==e[A]&&(a[A]=e[A])}),r&&AD(r).forEach(A=>{let r=e[A];if(r&&"string"==typeof r){let e=AJ(r,{deepThink:t.deepThink,cacheable:!0});e&&(a[A]=e)}}),[a]}async function AV(A,e,t,r,o){let n=null==t?void 0:t.find(A=>A.interfaceAlias===e||A.name===e);if(n&&"function"==typeof A.callActionInActionSpace)if(r.params){let e=await AF(n,r.params,o);return await A.callActionInActionSpace(n.name,e[0])}else{let e=r.prompt?AJ(r.prompt,{deepThink:o.deepThink,cacheable:!0}):void 0,{deviceOptions:t,...i}=o,a={locate:e,...i,...o.deviceOptions||{}};return await A.callActionInActionSpace(n.name,a)}{let t=r.prompt;if("aiAssert"===e){var i;let{pass:e,thought:r}=await (null==A||null==(i=A.aiAssert)?void 0:i.call(A,t||"",void 0,{keepRawResponse:!0,...o}))||{};return{pass:e||!1,thought:r||""}}if(A&&"function"==typeof A[e])return await A[e](t,o);throw Error(`Unknown action type: ${e}`)}}class Aq{async getActionSpace(A){return[]}validateParams(A,e){if(!(null==e?void 0:e.paramSchema)||!this.actionNeedsStructuredParams(e))return{valid:!0};if(!A.params)return{valid:!1,errorMessage:"Parameters are required"};try{let t=this.prepareParamsForValidation(A.params,e);return e.paramSchema.parse(t),{valid:!0}}catch(A){return this.handleValidationError(A)}}createDisplayContent(A,e,t){return e&&A.params&&(null==t?void 0:t.paramSchema)?this.buildParamsDisplayList(A.params,t).join("\n")||A.prompt||"":A.prompt||""}formatBasicErrorMessage(A){return(null==A?void 0:A.message)||"Unknown error"}getSchemaKeys(A){if(!(null==A?void 0:A.paramSchema)||!("shape"in A.paramSchema))return[];let e=A.paramSchema;return e&&"shape"in e?Object.keys(e.shape):[]}filterValidParams(A){let e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],t={};return Object.keys(A).forEach(r=>{e.includes(r)||void 0===A[r]||null===A[r]||""===A[r]||(t[r]=A[r])}),t}actionNeedsStructuredParams(A){return"object"!=typeof A.paramSchema||!("shape"in A.paramSchema)||Object.keys(A.paramSchema.shape||{}).length>0}prepareParamsForValidation(A,e){let t={...A};return e.paramSchema&&AD(e.paramSchema).forEach(A=>{"string"==typeof t[A]&&(t[A]={midscene_location_field_flag:!0,prompt:t[A],center:[0,0],rect:{left:0,top:0,width:0,height:0}})}),t}handleValidationError(A){if(A.errors&&A.errors.length>0){let e=A.errors.filter(A=>{let e=A.path.join(".");return!e.includes("center")&&!e.includes("rect")&&!e.includes("midscene_location_field_flag")}).map(A=>{let e=A.path.join(".");return`${e}: ${A.message}`});if(e.length>0)return{valid:!1,errorMessage:`Validation error: ${e.join(", ")}`}}let e=A instanceof Error?A.message:"Unknown validation error";return{valid:!1,errorMessage:`Parameter validation failed: ${e}`}}buildParamsDisplayList(A,e){let t=[],r=e.paramSchema;if(!(r&&"shape"in r))return t;let o=AD(r);return Object.keys(r.shape).forEach(e=>{let r=A[e];if(this.isValidParamValue(r)){let A=this.capitalizeFirstLetter(e),n=this.formatParamValue(e,r,o.includes(e));t.push(`${A}: ${n}`)}}),t}isValidParamValue(A){return null!=A&&""!==A}capitalizeFirstLetter(A){return A.charAt(0).toUpperCase()+A.slice(1)}formatParamValue(A,e,t){return t||"string"==typeof e?`"${e}"`:"number"==typeof e&&"distance"===A?`${e}px`:`${e}`}}function AG(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class AH extends Aq{get id(){return this._id}onDumpUpdate(A){this.dumpUpdateCallback=void 0,this.dumpUpdateCallback=A}setProgressCallback(A){this.progressCallback=void 0,this.progressCallback=A}async parseStructuredParams(A,e,t){return await AF(A,e,t)}formatErrorMessage(A){return((null==A?void 0:A.message)||"").includes("of different extension")?"Conflicting extension detected. Please disable the suspicious plugins and refresh the page. Guide: https://midscenejs.com/quick-experience.html#faq":this.formatBasicErrorMessage(A)}async getActionSpace(A){var e;if(null==(e=this.agent)?void 0:e.getActionSpace)return await this.agent.getActionSpace();if(this.agent&&"interface"in this.agent&&"object"==typeof this.agent.interface){let A=this.agent.interface;if(null==A?void 0:A.actionSpace)return A.actionSpace()}return A&&"object"==typeof A&&"actionSpace"in A?A.actionSpace():[]}async checkStatus(){return!0}async overrideConfig(A){Aj(A)}async detachDebuggerSafely(){try{var A,e;let t=null==(A=this.agent)?void 0:A.interface;await (null==t||null==(e=t.detachDebugger)?void 0:e.call(t))}catch(A){console.warn("Failed to detach debugger:",A)}}async executeAction(A,e,t){var r,o,n;let i,a=await this.getActionSpace();try{null==(r=(o=this.agent).resetDump)||r.call(o)}catch(A){console.warn("Failed to reset dump before execution:",A)}t.requestId&&this.agent&&(this.currentRequestId=t.requestId,i=this.agent.addDumpUpdateListener((A,e)=>{this.currentRequestId===t.requestId&&this.dumpUpdateCallback&&this.dumpUpdateCallback(A,e)}));try{let r=null,o=null;try{r=await AV(this.agent,A,a,e,t)}catch(A){o=A}let i={result:r,dump:null,reportHTML:null,error:o?o instanceof Error?o.message:String(o):null};try{if(this.agent.dumpDataString){let A=this.agent.dumpDataString();A&&(i.dump=(null==(n=JSON.parse(A).executions)?void 0:n[0])||null)}this.agent.reportHTMLString&&(i.reportHTML=this.agent.reportHTMLString()||null),this.agent.writeOutActionDumps&&this.agent.writeOutActionDumps()}catch(A){console.error("Failed to get dump/reportHTML from agent:",A)}return i}finally{i&&i()}}async cancelTask(A){if(!this.agent)return{error:"No active agent found for this requestId"};try{var e,t;return await (null==(e=(t=this.agent).destroy)?void 0:e.call(t)),{success:!0}}catch(e){let A=e instanceof Error?e.message:"Unknown error";return console.error(`Failed to cancel agent: ${A}`),{error:`Failed to cancel: ${A}`}}}async getCurrentExecutionData(){let A={dump:null,reportHTML:null};try{if(this.agent.dumpDataString){let t=this.agent.dumpDataString();if(t){var e;A.dump=(null==(e=JSON.parse(t).executions)?void 0:e[0])||null}}this.agent.reportHTMLString&&(A.reportHTML=this.agent.reportHTMLString()||null)}catch(A){console.error("Failed to get current execution data:",A)}return A}async getInterfaceInfo(){var A,e,t;if(!(null==(A=this.agent)?void 0:A.interface))return null;try{let A=this.agent.interface.interfaceType||"Unknown",r=(null==(e=(t=this.agent.interface).describe)?void 0:e.call(t))||void 0;return{type:A,description:r}}catch(A){return console.error("Failed to get interface info:",A),null}}constructor(A){super(),AG(this,"agent",void 0),AG(this,"dumpUpdateCallback",void 0),AG(this,"progressCallback",void 0),AG(this,"_id",void 0),AG(this,"currentRequestId",void 0),this.agent=A,this._id=(0,Ac.A)()}}function AW(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class AY extends Aq{onDumpUpdate(A){this.dumpUpdateCallback=void 0,this.dumpUpdateCallback=A}get id(){return this._id}validateParams(A,e){if(!(null==e?void 0:e.paramSchema)||!this.actionNeedsStructuredParams(e))return{valid:!0};if(!A.params)return{valid:!1,errorMessage:"Parameters are required"};if(e.paramSchema&&"object"==typeof e.paramSchema){let t=e.paramSchema;if(t.shape||"ZodObject"===t.type){let e=t.shape||{},r=Object.keys(e).filter(t=>{var r,o;let n=e[t];return!((null==n?void 0:n.isOptional)||(null==n||null==(r=n._def)?void 0:r.innerType)||(null==n||null==(o=n._def)?void 0:o.typeName)==="ZodOptional")&&(void 0===A.params[t]||""===A.params[t])});if(r.length>0)return{valid:!1,errorMessage:`Missing required parameters: ${r.join(", ")}`}}}return{valid:!0}}async parseStructuredParams(A,e,t){return await AF(A,e,t)}formatErrorMessage(A){let e=(null==A?void 0:A.message)||"",t=[{keyword:"adb",message:"ADB connection error. Please ensure device is connected and USB debugging is enabled."},{keyword:"UIAutomator",message:"UIAutomator error. Please ensure the UIAutomator server is running on the device."}].find(A=>{let{keyword:t}=A;return e.includes(t)});return t?t.message:this.formatBasicErrorMessage(A)}async executeAction(A,e,t){if(this.serverUrl&&"undefined"!=typeof window)return this.executeViaServer(A,e,t);throw Error("Remote execution adapter requires server URL for execution")}async executeViaServer(A,e,t){let r={type:A,prompt:e.prompt,...this.buildOptionalPayloadParams(t,e)};t.context&&(r.context=t.context),t.requestId&&this.dumpUpdateCallback&&this.startProgressPolling(t.requestId);try{let A=await fetch(`${this.serverUrl}/execute`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(r)});if(!A.ok){let e=await A.text().catch(()=>"Unknown error");throw Error(`Server request failed (${A.status}): ${e}`)}return await A.json()}catch(A){throw console.error("Execute via server failed:",A),A}finally{this.stopProgressPolling()}}buildOptionalPayloadParams(A,e){let t={};return[{key:"requestId",value:A.requestId},{key:"deepThink",value:A.deepThink},{key:"screenshotIncluded",value:A.screenshotIncluded},{key:"domIncluded",value:A.domIncluded},{key:"deviceOptions",value:A.deviceOptions},{key:"params",value:e.params}].forEach(A=>{let{key:e,value:r}=A;null!=r&&""!==r&&(t[e]=r)}),t}async getActionSpace(A){if(this.serverUrl&&"undefined"!=typeof window)try{let e=await fetch(`${this.serverUrl}/action-space`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({context:A})});if(!e.ok)throw Error(`Failed to get action space: ${e.statusText}`);let t=await e.json();return Array.isArray(t)?t:[]}catch(A){console.error("Failed to get action space from server:",A)}if(A&&"object"==typeof A&&"actionSpace"in A)try{let e=A.actionSpace,t=await e();return Array.isArray(t)?t:[]}catch(A){console.error("Failed to get action space from context:",A)}return[]}async checkStatus(){if(!this.serverUrl)return!1;try{let A=await fetch(`${this.serverUrl}/status`);if(200===A.status){try{let e=await A.json();e.id&&"string"==typeof e.id&&(this._id=e.id)}catch(A){console.debug("Failed to parse status response:",A)}return!0}return!1}catch(A){return console.warn("Server status check failed:",A),!1}}async overrideConfig(A){if(!this.serverUrl)throw Error("Server URL not configured");try{let e=await fetch(`${this.serverUrl}/config`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({aiConfig:A})});if(!e.ok)throw Error(`Failed to override server config: ${e.statusText}`)}catch(A){throw console.error("Failed to override server config:",A),A}}async getTaskProgress(A){if(!this.serverUrl)return{};if(!(null==A?void 0:A.trim()))return console.warn("Invalid requestId provided for task progress"),{};try{let e=await fetch(`${this.serverUrl}/task-progress/${encodeURIComponent(A)}`);if(!e.ok)return console.warn(`Task progress request failed: ${e.statusText}`),{};return await e.json()}catch(A){return console.error("Failed to poll task progress:",A),{}}}startProgressPolling(A){this.stopProgressPolling(),this.pollingIntervalId=setInterval(async()=>{try{let e=await this.getTaskProgress(A);e.executionDump&&this.dumpUpdateCallback&&this.dumpUpdateCallback("",e.executionDump)}catch(A){console.error("Error polling task progress:",A)}},500)}stopProgressPolling(){this.pollingIntervalId&&(clearInterval(this.pollingIntervalId),this.pollingIntervalId=void 0)}async cancelTask(A){if(!this.serverUrl)return{error:"No server URL configured"};if(!(null==A?void 0:A.trim()))return{error:"Invalid request ID"};try{let e=await fetch(`${this.serverUrl}/cancel/${encodeURIComponent(A)}`,{method:"POST"});if(!e.ok)return{error:`Cancel request failed: ${e.statusText}`};let t=await e.json();return{success:!0,...t}}catch(A){return console.error("Failed to cancel task:",A),{error:"Failed to cancel task"}}}async getScreenshot(){if(!this.serverUrl)return null;try{let A=await fetch(`${this.serverUrl}/screenshot`);if(!A.ok)return console.warn(`Screenshot request failed: ${A.statusText}`),null;return await A.json()}catch(A){return console.error("Failed to get screenshot:",A),null}}async getInterfaceInfo(){if(!this.serverUrl)return null;try{let A=await fetch(`${this.serverUrl}/interface-info`);if(!A.ok)return console.warn(`Interface info request failed: ${A.statusText}`),null;return await A.json()}catch(A){return console.error("Failed to get interface info:",A),null}}constructor(A){super(),AW(this,"serverUrl",void 0),AW(this,"_id",void 0),AW(this,"dumpUpdateCallback",void 0),AW(this,"pollingIntervalId",void 0),this.serverUrl=A}}class A_{createAdapter(A,e,t){switch(A){case"local-execution":if(!t)throw Error("Agent is required for local execution");return new AH(t);case"remote-execution":return new AY(e||("undefined"!=typeof window&&window.location.protocol.includes("http")?window.location.origin:"http://localhost:5800"));default:throw Error(`Unsupported execution type: ${A}`)}}async executeAction(A,e,t){return await this.adapter.executeAction(A,e,t)}async getActionSpace(A){return this.adapter.getActionSpace(A)}validateStructuredParams(A,e){return this.adapter.validateParams(A,e)}formatErrorMessage(A){return this.adapter.formatErrorMessage(A)}createDisplayContent(A,e,t){return this.adapter.createDisplayContent(A,e,t)}get id(){if(this.adapter instanceof AY||this.adapter instanceof AH)return this.adapter.id}async checkStatus(){return!(this.adapter instanceof AY)||this.adapter.checkStatus()}async overrideConfig(A){if(this.adapter instanceof AY)return this.adapter.overrideConfig(A)}async getTaskProgress(A){return this.adapter instanceof AY?this.adapter.getTaskProgress(A):{}}async cancelTask(A){return this.adapter instanceof AY?this.adapter.cancelTask(A):{error:"Cancel task not supported in local execution mode"}}onDumpUpdate(A){this.adapter instanceof AH?this.adapter.onDumpUpdate(A):this.adapter instanceof AY&&this.adapter.onDumpUpdate(A)}onProgressUpdate(A){this.adapter instanceof AH&&this.adapter.setProgressCallback(A)}async cancelExecution(A){if(this.adapter instanceof AY){let e=await this.adapter.cancelTask(A);if(e.success)return{dump:e.dump||null,reportHTML:e.reportHTML||null}}else this.adapter instanceof AH&&console.warn("Local execution cancellation not fully implemented");return null}async getCurrentExecutionData(){return this.adapter instanceof AH&&this.adapter.getCurrentExecutionData?await this.adapter.getCurrentExecutionData():{dump:null,reportHTML:null}}async getScreenshot(){return this.adapter instanceof AY?this.adapter.getScreenshot():null}async getInterfaceInfo(){return this.adapter instanceof AH||this.adapter instanceof AY?this.adapter.getInterfaceInfo():null}getServiceMode(){return this.adapter instanceof AH?"In-Browser-Extension":"Server"}constructor(A){!function(A,e,t){e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t}(this,"adapter",void 0),this.adapter=this.createAdapter(A.type,A.serverUrl,A.agent)}}let A$=["#01204E"];function A0(A){return"searchArea"===A?"#028391":"#fd5907"}function A1(){return{token:{colorPrimary:"#2B83FF"},components:{Layout:{headerHeight:60,headerPadding:"0 30px",headerBg:"#FFF",bodyBg:"#FFF"}}}}let A3=A=>{let{hideLogo:e=!1}=A,{isDarkMode:t}=function(){let[A,e]=(0,i.useState)(!1);return(0,i.useEffect)(()=>{let A=()=>{var A;e("dark"===(null==(A=document.querySelector("[data-theme]"))?void 0:A.getAttribute("data-theme")))};A();let t=new MutationObserver(A),r=document.querySelector("[data-theme]")||document.documentElement;return t.observe(r,{attributes:!0,attributeFilter:["data-theme"]}),()=>t.disconnect()},[]),{isDarkMode:A}}();return e?null:(0,n.jsx)("div",{className:"logo",children:(0,n.jsx)("a",{href:"https://midscenejs.com/",target:"_blank",rel:"noreferrer",children:(0,n.jsx)("img",{alt:"Midscene_logo",src:t?"https://lf3-static.bytednsdoc.com/obj/eden-cn/nupipfups/Midscene/midscene_with_text_dark.png":"https://lf3-static.bytednsdoc.com/obj/eden-cn/nupipfups/Midscene/midscene_with_text_light.png"})})})};var A5=t(4177),A7=t(6766),A9=t(6419),A2=t(8594),A6=t(89),A8=t(894),A4=t(4174),eA=t(8926),ee={};ee.d=(A,e)=>{for(var t in e)ee.o(e,t)&&!ee.o(A,t)&&Object.defineProperty(A,t,{enumerable:!0,get:e[t]})},ee.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),ee.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})};var et={};ee.r(et),ee.d(et,{create:()=>eA.vt});let{create:er}=et,eo="midscene-auto-zoom",en="midscene-background-visible",ei="midscene-elements-visible",ea="midscene-model-call-details",el="midscene-dark-mode",es=A=>{if("undefined"==typeof window)return;var e=new URLSearchParams(window.location.search).get(A);if(null===e)return;let t=e.trim().toLowerCase();return!!["1","true","yes","on"].includes(t)||!["0","false","no","off"].includes(t)&&void 0},ec=er(A=>{let e="false"!==localStorage.getItem(eo),t="false"!==localStorage.getItem(en),r="false"!==localStorage.getItem(ei),o="true"===localStorage.getItem(ea),n="true"===localStorage.getItem(el),i=es("focusOnCursor"),a=es("showElementMarkers"),l=es("darkMode"),s=void 0===l?n:l;return void 0!==l&&localStorage.setItem(el,s.toString()),{backgroundVisible:t,elementsVisible:void 0===a?r:a,autoZoom:void 0===i?e:i,modelCallDetailsEnabled:o,darkModeEnabled:s,setBackgroundVisible:e=>{A({backgroundVisible:e}),localStorage.setItem(en,e.toString())},setElementsVisible:e=>{A({elementsVisible:e}),localStorage.setItem(ei,e.toString())},setAutoZoom:e=>{A({autoZoom:e}),localStorage.setItem(eo,e.toString())},setModelCallDetailsEnabled:e=>{A({modelCallDetailsEnabled:e}),localStorage.setItem(ea,e.toString())},setDarkModeEnabled:e=>{A({darkModeEnabled:e}),localStorage.setItem(el,e.toString())}}}),ed="midscene-env-config",eu="midscene-service-mode",ep="midscene-tracking-active-tab",eg="midscene-deep-think",ef="midscene-screenshot-included",em="midscene-dom-included",ey="midscene-ime-strategy",eh="midscene-auto-dismiss-keyboard",eE="midscene-keyboard-dismiss-strategy",ev="midscene-always-refresh-screen-info",eC=()=>localStorage.getItem(ed)||"",eb=A=>{let e=A.split("\n"),t={};return e.forEach(A=>{let e=A.trim();if(e.startsWith("#"))return;let r=e.replace(/^export\s+/i,"").replace(/;$/,"").trim().match(/^(\w+)=(.*)$/);if(r){let[,A,e]=r,o=e.trim();(o.startsWith("'")&&o.endsWith("'")||o.startsWith('"')&&o.endsWith('"'))&&(o=o.slice(1,-1)),t[A]=o}}),t},ek=er((A,e)=>{let t=eC(),r=eb(t),o=window.location.href.startsWith("chrome-extension"),n=localStorage.getItem(eu),i="false"!==localStorage.getItem(ep),a="true"===localStorage.getItem(eg),l="false"!==localStorage.getItem(ef),s=localStorage.getItem(em)||"false";return{serviceMode:o?"In-Browser-Extension":n||"Server",setServiceMode:e=>{if(o)throw Error("serviceMode cannot be set in extension");A({serviceMode:e}),localStorage.setItem(eu,e)},config:r,configString:t,setConfig:e=>A({config:e}),loadConfig:e=>{A({config:eb(e),configString:e}),localStorage.setItem(ed,e)},syncFromStorage:()=>{let e=eC();A({config:eb(e),configString:e})},forceSameTabNavigation:i,setForceSameTabNavigation:e=>{A({forceSameTabNavigation:e}),localStorage.setItem(ep,e.toString())},deepThink:a,setDeepThink:e=>{A({deepThink:e}),localStorage.setItem(eg,e.toString())},screenshotIncluded:l,setScreenshotIncluded:e=>{A({screenshotIncluded:e}),localStorage.setItem(ef,e.toString())},domIncluded:"visible-only"===s?"visible-only":"true"===s,setDomIncluded:e=>{A({domIncluded:e}),localStorage.setItem(em,e.toString())},popupTab:"playground",setPopupTab:e=>{A({popupTab:e})},imeStrategy:localStorage.getItem(ey)||"yadb-for-non-ascii",setImeStrategy:e=>{A({imeStrategy:e}),localStorage.setItem(ey,e)},autoDismissKeyboard:"false"!==localStorage.getItem(eh),setAutoDismissKeyboard:e=>{A({autoDismissKeyboard:e}),localStorage.setItem(eh,e.toString())},keyboardDismissStrategy:localStorage.getItem(eE)||"esc-first",setKeyboardDismissStrategy:e=>{A({keyboardDismissStrategy:e}),localStorage.setItem(eE,e)},alwaysRefreshScreenInfo:"true"===localStorage.getItem(ev),setAlwaysRefreshScreenInfo:e=>{A({alwaysRefreshScreenInfo:e}),localStorage.setItem(ev,e.toString())}}});function eS(A){let{showTooltipWhenEmpty:e=!0,showModelName:t=!0,tooltipPlacement:r="bottom",mode:o="icon"}=A,{config:a,configString:l,loadConfig:s,syncFromStorage:c}=ek(),[d,u]=(0,i.useState)(!1),[p,g]=(0,i.useState)(l),f=a.MIDSCENE_MODEL_NAME,m=(0,i.useRef)(null),y=A=>{c(),u(!0),A.preventDefault(),A.stopPropagation()};return(0,i.useEffect)(()=>{d&&g(l)},[d,l]),(0,n.jsxs)("div",{style:{display:"flex",justifyContent:"flex-end",gap:"10px",alignItems:"center",height:"100%",minHeight:"32px"},ref:m,children:[t?f:null,(0,n.jsx)(A6.A,{title:"Please set up your environment variables before using.",placement:r,align:{offset:[-10,5]},getPopupContainer:()=>m.current,open:!d&&(e?0===Object.keys(a).length:void 0),children:"icon"===o?(0,n.jsx)(A2.A,{onClick:y}):(0,n.jsx)("span",{onClick:y,style:{color:"#006AFF",cursor:"pointer"},children:"set up"})}),(0,n.jsxs)(A8.A,{title:"Model Env Config",open:d,onOk:()=>{u(!1),s(p)},onCancel:()=>{u(!1)},okText:"Save",style:{width:"800px",height:"100%",marginTop:"10%"},destroyOnClose:!0,maskClosable:!0,centered:!0,children:[(0,n.jsx)(A4.A.TextArea,{rows:7,placeholder:"OPENAI_API_KEY=sk-...\nMIDSCENE_MODEL_NAME=gpt-4o-2024-08-06\n...",value:p,onChange:A=>g(A.target.value),style:{whiteSpace:"nowrap",wordWrap:"break-word"}}),(0,n.jsxs)("div",{children:[(0,n.jsx)("p",{children:"The format is KEY=VALUE and separated by new lines."}),(0,n.jsxs)("p",{children:["These data will be saved ",(0,n.jsx)("strong",{children:"locally in your browser"}),"."]})]})]})]})}function eI(A){let{showEnvConfig:e=!0,showTooltipWhenEmpty:t=!1,showModelName:r=!1,githubUrl:o="https://github.com/web-infra-dev/midscene",helpUrl:i="https://midscenejs.com/quick-experience.html",className:a=""}=A;return(0,n.jsxs)("div",{className:`nav-actions ${a}`,children:[(0,n.jsx)(A9.A.Link,{href:o,target:"_blank",children:(0,n.jsx)(A5.A,{className:"nav-icon"})}),(0,n.jsx)(A9.A.Link,{href:i,target:"_blank",children:(0,n.jsx)(A7.A,{className:"nav-icon"})}),e&&(0,n.jsx)(eS,{showTooltipWhenEmpty:t,showModelName:r})]})}var eR=t(4707),ex=t(9870),eP=t(9877),ej=t(3147),ew=t(6620),eO=t(5810),eN=t(5359),eK=t(5584),eB=t(638);function eT(A){return A.subType||A.type}function eM(A){if(!A)return"";if("string"==typeof A)return A;if("object"==typeof A){if("object"==typeof A.prompt&&null!==A.prompt&&A.prompt.prompt)return A.prompt.prompt;if("string"==typeof A.prompt)return A.prompt;if("string"==typeof A.description)return A.description}return""}function ez(A){var e,t,r,o,n,i,a,l,s,c;let d;if("Planning"===A.type&&(d="Locate"===A.subType?eM(null==A?void 0:A.param):(null==(e=A.output)?void 0:e.log)||(null==(t=A.param)?void 0:t.userInstruction)),"Insight"===A.type&&(d=function(A){if(!A)return{content:""};let e=A=>{var e;return(null==A||null==(e=A.multimodalPrompt)?void 0:e.images)&&Array.isArray(A.multimodalPrompt.images)?A.multimodalPrompt.images:void 0},t=A=>"string"==typeof A?A:JSON.stringify(A);if(A.demand)return{content:t(A.demand),images:e(A)};if(A.assertion)return{content:t(A.assertion),images:e(A)};if(A.dataDemand){let{dataDemand:r}=A;if("string"==typeof r)return{content:r};if("object"==typeof r)return{content:t(r.demand||r),images:e(r)}}return{content:""}}(null==A?void 0:A.param).content),"Action Space"===A.type){let e=null==A||null==(r=A.param)?void 0:r.locate,t=e?eM(e):"";(d=A.thought||"","number"==typeof(null==A||null==(o=A.param)?void 0:o.timeMs))?d=`${null==A||null==(n=A.param)?void 0:n.timeMs}ms`:"string"==typeof(null==A||null==(i=A.param)?void 0:i.scrollType)?d=(c=null==A?void 0:A.param)?`${c.direction||"down"}, ${c.scrollType||"singleAction"}, ${c.distance||"distance-not-set"}`:"":"string"==typeof(null==A||null==(a=A.param)?void 0:a.direction)&&(null==A?void 0:A.subType)==="AndroidPull"?d=function(A){if(!A)return"";let e=[];return e.push(`direction: ${A.direction||"down"}`),A.distance&&e.push(`distance: ${A.distance}`),A.duration&&e.push(`duration: ${A.duration}ms`),e.join(", ")}(null==A?void 0:A.param):void 0!==(null==A||null==(l=A.param)?void 0:l.value)?d=null==A||null==(s=A.param)?void 0:s.value:(null==A?void 0:A.param)&&"object"==typeof(null==A?void 0:A.param)&&Object.keys((null==A?void 0:A.param)||{}).length>0&&(d=null==A?void 0:A.param),t&&(d=d&&"object"!=typeof d?`${t} - ${d}`:t)}if(void 0===d)return"";if("string"==typeof d)return d;if("object"==typeof d){let A=eM(d);return A||JSON.stringify(d,void 0,2)}return String(d)}Ah("ai:service"),Ah("task-runner"),t(3009),t(6970),t(8963).Buffer,t(5409),Aw.z.object({locate:Az.describe("The element to be tapped")}),Aw.z.object({locate:Az.describe("The element to be right clicked")}),Aw.z.object({locate:Az.describe("The element to be double clicked")}),Aw.z.object({locate:Az.describe("The element to be hovered")}),Aw.z.object({value:Aw.z.union([Aw.z.string(),Aw.z.number()]).transform(A=>String(A)).describe("The text to input. Provide the final content for replace/append modes, or an empty string when using clear mode to remove existing text."),locate:Az.describe("the position of the placeholder or text content in the target input field. If there is no content, locate the center of the input field.").optional(),mode:Aw.z.enum(["replace","clear","append"]).default("replace").optional().describe('Input mode: "replace" (default) - clear the field and input the value; "append" - append the value to existing content; "clear" - clear the field without inputting new text.')}),Aw.z.object({locate:Az.describe("The element to be clicked before pressing the key").optional(),keyName:Aw.z.string().describe("The key to be pressed. Use '+' for key combinations, e.g., 'Control+A', 'Shift+Enter'")}),Aw.z.object({direction:Aw.z.enum(["down","up","right","left"]).default("down").describe("The direction to scroll"),scrollType:Aw.z.enum(["singleAction","scrollToBottom","scrollToTop","scrollToRight","scrollToLeft"]).default("singleAction").describe('The scroll behavior: "singleAction" for a single scroll action, "scrollToBottom" for scrolling to the bottom, "scrollToTop" for scrolling to the top, "scrollToRight" for scrolling to the right, "scrollToLeft" for scrolling to the left'),distance:Aw.z.number().nullable().optional().describe("The distance in pixels to scroll"),locate:Az.optional().describe("The target element to be scrolled")}),Aw.z.object({from:Az.describe("The position to be dragged"),to:Az.describe("The position to be dropped")}),Aw.z.object({locate:Az.describe("The element to be long pressed"),duration:Aw.z.number().default(500).optional().describe("Long press duration in milliseconds")}),Aw.z.object({start:Az.optional().describe("Starting point of the swipe gesture, if not specified, the center of the page will be used"),direction:Aw.z.enum(["up","down","left","right"]).optional().describe("The direction to swipe (required when using distance). The direction means the direction of the finger swipe."),distance:Aw.z.number().optional().describe("The distance in pixels to swipe (mutually exclusive with end)"),end:Az.optional().describe("Ending point of the swipe gesture (mutually exclusive with distance)"),duration:Aw.z.number().default(300).describe("Duration of the swipe gesture in milliseconds"),repeat:Aw.z.number().optional().describe("The number of times to repeat the swipe gesture. 1 for default, 0 for infinite (e.g. endless swipe until the end of the page)")}),Aw.z.object({locate:Az.describe("The input field to be cleared")}),Aw.z.object({condition:Aw.z.string().describe("The condition of the assertion"),thought:Aw.z.string().describe('The thought of the assertion, like "I can see there are A, B, C elements on the page, which means ... , so the assertion is true"'),result:Aw.z.boolean().describe("The result of the assertion, true or false")}),t(9140),t(8586),t(9300),t(5409),Ah("web:tool:profile"),t(8963).Buffer,Ah("cache"),Ah("agent:task-builder"),Ah("device-task-executor"),Ah("agent"),["read-only","read-write","write-only"].map(A=>`"${A}"`).join(", ");let eD="Auto dismiss keyboard",eQ={aiAct:{group:"interaction",title:"Auto Planning: plan the steps and execute"},aiTap:{group:"interaction",title:"Click an element"},aiDoubleClick:{group:"interaction",title:"Double-click an element"},aiHover:{group:"interaction",title:"Hover over an element"},aiInput:{group:"interaction",title:"Input text into an element"},aiRightClick:{group:"interaction",title:"Right-click an element"},aiKeyboardPress:{group:"interaction",title:"Press keyboard keys"},aiScroll:{group:"interaction",title:"Scroll the page or element"},aiLocate:{group:"interaction",title:"Locate an element on the page"},aiQuery:{group:"extraction",title:"Extract data directly from the UI"},aiBoolean:{group:"extraction",title:"Get true/false answer"},aiNumber:{group:"extraction",title:"Extract numeric value"},aiString:{group:"extraction",title:"Extract text value"},aiAsk:{group:"extraction",title:"Ask a question about the UI"},aiAssert:{group:"validation",title:"Assert a condition is true"},aiWaitFor:{group:"validation",title:"Wait for a condition to be met"}},eZ=["aiAct","aiTap","aiQuery","aiAssert"],eL={type:"system",content:`
|
|
4
|
+
Welcome to Midscene.js Playground!
|
|
5
|
+
|
|
6
|
+
This is a panel for experimenting and testing Midscene.js features. You can use natural language instructions to operate the web page, such as clicking buttons, filling in forms, querying information, etc.
|
|
7
|
+
|
|
8
|
+
Please enter your instructions in the input box below to start experiencing.
|
|
9
|
+
`,loading:!1,result:void 0,replayScriptsInfo:null,replayCounter:0,loadingProgressText:"",verticalMode:!1},eX={result:void 0,dump:null,reportHTML:null,error:null},eJ="",eU="",eF=(A,e,t)=>{let r,o=(r=A.width/A.height>=e/t?A.width:A.height/t*e)>400?.1:r>50?.2:.3,n=Math.min(e,r+e*o*2),i=Math.min(A.left-e*o,e-n);i=Math.max(i,0);let a=Math.min(A.top-t*o,t-t/e*n);return{left:Math.round(i),top:Math.round(a=Math.max(a,0)),width:Math.round(n)}};function eV(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function eq(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){eV(n,r,o,i,a,"next",A)}function a(A){eV(n,r,o,i,a,"throw",A)}i(void 0)})}}function eG(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}function eH(A,e){return e=null!=e?e:{},Object.getOwnPropertyDescriptors?Object.defineProperties(A,Object.getOwnPropertyDescriptors(e)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(e)).forEach(function(t){Object.defineProperty(A,t,Object.getOwnPropertyDescriptor(e,t))}),A}function eW(A){if(!A)return"";if("string"==typeof A)return A;if(A.message)return String(A.message);try{return JSON.stringify(A)}catch(e){return String(A)}}function eY(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class e_{initDB(){return new Promise((A,e)=>{let t=indexedDB.open(this.dbName,this.version);t.onerror=()=>e(t.error),t.onsuccess=()=>A(t.result),t.onupgradeneeded=A=>{let e=A.target.result;this.storeConfigs.forEach(A=>{let{name:t,keyPath:r}=A;e.objectStoreNames.contains(t)||e.createObjectStore(t,{keyPath:r}).createIndex("timestamp","timestamp",{unique:!1})})}})}async withTransaction(A,e,t){let r=(await this.dbPromise).transaction(A,e);return t(Array.isArray(A)?A.map(A=>r.objectStore(A)):r.objectStore(A))}promisifyRequest(A){return new Promise((e,t)=>{A.onsuccess=()=>e(A.result),A.onerror=()=>t(A.error)})}async put(A,e){await this.withTransaction(A,"readwrite",async A=>{await this.promisifyRequest(A.put(e))})}async get(A,e){return this.withTransaction(A,"readonly",async A=>this.promisifyRequest(A.get(e)))}async getAll(A){let e=!(arguments.length>1)||void 0===arguments[1]||arguments[1];return this.withTransaction(A,"readonly",async A=>{let t=e?await this.promisifyRequest(A.index("timestamp").getAll()):await this.promisifyRequest(A.getAll());return e?t.sort((A,e)=>A.timestamp-e.timestamp):t})}async clear(A){await this.withTransaction(A,"readwrite",async A=>{await this.promisifyRequest(A.clear())})}async delete(A,e){await this.withTransaction(A,"readwrite",async A=>{await this.promisifyRequest(A.delete(e))})}async count(A){return this.withTransaction(A,"readonly",async A=>this.promisifyRequest(A.count()))}getDBPromise(){return this.dbPromise}constructor(A,e,t){eY(this,"dbPromise",void 0),eY(this,"dbName",void 0),eY(this,"version",void 0),eY(this,"storeConfigs",void 0),this.dbName=A,this.version=e,this.storeConfigs=t,this.dbPromise=this.initDB()}}let e$=async(A,e,t,r)=>{try{return await A()}catch(A){return console.error(e,A),A instanceof Error&&"QuotaExceededError"===A.name&&r&&(console.log("Storage quota exceeded, running cleanup..."),await r()),t}},e0=(A,e,t)=>async()=>{try{let r=await A.getAll(e);if(r.length>t){let o=r.sort((A,e)=>A.timestamp-e.timestamp).slice(0,r.length-t);await Promise.all(o.map(t=>A.delete(e,t.id)))}}catch(A){console.error(`Failed to cleanup ${e}:`,A)}};function e1(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function e3(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){e1(n,r,o,i,a,"next",A)}function a(A){e1(n,r,o,i,a,"throw",A)}i(void 0)})}}function e5(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}function e7(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){e5(A,e,t[e])})}return A}function e9(A,e){return e=null!=e?e:{},Object.getOwnPropertyDescriptors?Object.defineProperties(A,Object.getOwnPropertyDescriptors(e)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(e)).forEach(function(t){Object.defineProperty(A,t,Object.getOwnPropertyDescriptor(e,t))}),A}let e2="playground_messages",e6="playground_results";class e8{saveMessages(A){return e3(function*(){yield e$(()=>e3(function*(){yield this.dbManager.clear(e2);let e=A.slice(-100);yield Promise.all(e.map((A,e)=>{let t=e9(e7({},A),{result:"result"===A.type?void 0:A.result}),r={id:A.id||`msg-${e}`,data:t,timestamp:A.timestamp?A.timestamp.getTime():Date.now()+e};return this.dbManager.put(e2,r)}))}).call(this),"Failed to save messages to IndexedDB",void 0,this.messagesCleanup)}).call(this)}loadMessages(){return e3(function*(){return(yield e$(()=>e3(function*(){let A=yield this.dbManager.getAll(e2,!0);return 0===A.length?[]:Promise.all(A.map(A=>e3(function*(){let e=A.data,t=e9(e7({},e),{timestamp:new Date(e.timestamp)});if("result"===e.type&&e.id){let A=yield this.loadResult(e.id);A&&(t.result=A.result,t.replayScriptsInfo=A.replayScriptsInfo,t.replayCounter=A.replayCounter,t.verticalMode=A.verticalMode)}return t}).call(this)))}).call(this),"Failed to load messages from IndexedDB",[],this.messagesCleanup))||[]}).call(this)}clearMessages(){return e3(function*(){yield e$(()=>e3(function*(){yield Promise.all([this.dbManager.clear(e2),this.dbManager.clear(e6)])}).call(this),"Failed to clear messages from IndexedDB")}).call(this)}saveResult(A,e){return e3(function*(){yield e$(()=>e3(function*(){let t=this.compressResultForStorage(e),r={id:A,data:t,timestamp:Date.now(),size:JSON.stringify(t).length};yield this.dbManager.put(e6,r)}).call(this),"Failed to save result to IndexedDB",void 0,this.resultsCleanup)}).call(this)}loadResult(A){return e3(function*(){return(yield e$(()=>e3(function*(){let e=yield this.dbManager.get(e6,A);return(null==e?void 0:e.data)||null}).call(this),"Failed to load result from IndexedDB",null))||null}).call(this)}compressResultForStorage(A){var e,t;if(!(null==(t=A.result)||null==(e=t.dump)?void 0:e.tasks))return A;let r=A.result.dump.tasks.map(A=>{var e,t;return e9(e7({},A),{uiContext:A.uiContext?e9(e7({},A.uiContext),{screenshotBase64:null!=(t=this.compressScreenshotIfNeeded(A.uiContext.screenshotBase64))?t:A.uiContext.screenshotBase64}):A.uiContext,recorder:null==(e=A.recorder)?void 0:e.map(A=>e9(e7({},A),{screenshot:this.compressScreenshotIfNeeded(A.screenshot)}))})});return e9(e7({},A),{result:e9(e7({},A.result),{dump:e9(e7({},A.result.dump),{tasks:r})})})}compressScreenshotIfNeeded(A){if(!A)return A;if(A.length>1048576){let e=Math.round(A.length/1024);return`[COMPRESSED: ${e}KB screenshot removed for storage]`}return A}getStorageStats(){return e3(function*(){return(yield e$(()=>e3(function*(){let[A,e]=yield Promise.all([this.dbManager.count(e2),this.dbManager.count(e6)]);return{messageCount:A,resultCount:e}}).call(this),"Failed to get storage statistics",{messageCount:0,resultCount:0}))||{messageCount:0,resultCount:0}}).call(this)}cleanup(){return e3(function*(){yield Promise.all([this.messagesCleanup(),this.resultsCleanup()])}).call(this)}constructor(A="playground"){e5(this,"dbManager",void 0),e5(this,"namespace",void 0),e5(this,"messagesCleanup",void 0),e5(this,"resultsCleanup",void 0),this.namespace=A,this.dbManager=new e_(`midscene_playground_${A}`,1,[{name:e2,keyPath:"id"},{name:e6,keyPath:"id"}]),this.messagesCleanup=e0(this.dbManager,e2,100),this.resultsCleanup=e0(this.dbManager,e6,50)}}function e4(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function tA(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){e4(n,r,o,i,a,"next",A)}function a(A){e4(n,r,o,i,a,"throw",A)}i(void 0)})}}function te(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}function tt(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){te(A,e,t[e])})}return A}function tr(A,e){return e=null!=e?e:{},Object.getOwnPropertyDescriptors?Object.defineProperties(A,Object.getOwnPropertyDescriptors(e)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(e)).forEach(function(t){Object.defineProperty(A,t,Object.getOwnPropertyDescriptor(e,t))}),A}class to{checkStorageSpace(){try{let A="storage-test",e="x".repeat(102400);return localStorage.setItem(A,e),localStorage.removeItem(A),!0}catch(A){return!1}}saveMessages(A){return tA(function*(){try{this.checkStorageSpace()||(console.warn("Low storage space detected, clearing old data..."),yield this.handleQuotaExceeded());let e=A.slice(-this.maxStorageItems).map(A=>tr(tt({},A),{result:"result"===A.type?void 0:A.result})),t=JSON.stringify(e);localStorage.setItem(this.messagesKey,t)}catch(e){if(e instanceof DOMException&&"QuotaExceededError"===e.name){console.warn("LocalStorage quota exceeded, attempting to clear old data and retry..."),yield this.handleQuotaExceeded();try{let e=A.slice(-10).map(A=>tr(tt({},A),{result:"result"===A.type?void 0:A.result})),t=JSON.stringify(e);localStorage.setItem(this.messagesKey,t),console.info("Successfully saved recent messages after clearing storage")}catch(A){console.error("Failed to save even after clearing storage:",A),yield this.clearMessages()}}else console.error("Failed to save messages to localStorage:",e)}}).call(this)}loadMessages(){return tA(function*(){try{let A=localStorage.getItem(this.messagesKey);if(!A)return[];let e=JSON.parse(A);return yield Promise.all(e.map(A=>tA(function*(){if("result"===A.type&&A.id){let e=`${this.resultsKey}-${A.id}`,t=localStorage.getItem(e);if(t)try{let e=JSON.parse(t);return tt({},A,e)}catch(A){console.warn("Failed to parse stored result:",A)}}return A}).call(this)))}catch(A){return console.error("Failed to load messages from localStorage:",A),[]}}).call(this)}clearMessages(){return tA(function*(){try{localStorage.removeItem(this.messagesKey),Object.keys(localStorage).forEach(A=>{A.startsWith(this.resultsKey)&&localStorage.removeItem(A)})}catch(A){console.error("Failed to clear messages from localStorage:",A)}}).call(this)}saveResult(A,e){return tA(function*(){try{let t=`${this.resultsKey}-${A}`;localStorage.setItem(t,JSON.stringify(e))}catch(t){if(t instanceof DOMException&&"QuotaExceededError"===t.name){console.warn("LocalStorage quota exceeded when saving result, clearing old results..."),yield this.handleQuotaExceeded();try{let t=`${this.resultsKey}-${A}`;localStorage.setItem(t,JSON.stringify(e))}catch(A){console.error("Failed to save result even after clearing storage:",A)}}else console.error("Failed to save result to localStorage:",t)}}).call(this)}handleQuotaExceeded(){return tA(function*(){try{let A=Object.keys(localStorage),e=A.filter(A=>A.startsWith(this.resultsKey)),t=e.slice(0,Math.max(1,Math.floor(e.length/2)));t.forEach(A=>{localStorage.removeItem(A)}),console.info(`Cleared ${t.length} old result entries to free up storage space`);let r=A.filter(A=>A.includes("playground")||A.includes("agent")||A.startsWith("midscene"));if(r.length>10){let A=r.slice(0,Math.floor(r.length/3));A.forEach(A=>{A!==this.messagesKey&&localStorage.removeItem(A)}),console.info(`Cleared ${A.length} additional playground-related entries`)}}catch(A){console.error("Failed to handle quota exceeded:",A)}}).call(this)}constructor(A="playground"){te(this,"messagesKey",void 0),te(this,"resultsKey",void 0),te(this,"maxStorageItems",50),this.messagesKey=`${A}-messages`,this.resultsKey=`${A}-results`}}class tn{saveMessages(A){return tA(function*(){this.messages=[...A]}).call(this)}loadMessages(){return tA(function*(){return[...this.messages]}).call(this)}clearMessages(){return tA(function*(){this.messages=[],this.results.clear()}).call(this)}saveResult(A,e){return tA(function*(){this.results.set(A,e)}).call(this)}constructor(){te(this,"messages",[]),te(this,"results",new Map)}}class ti{saveMessages(A){return tA(function*(){})()}loadMessages(){return tA(function*(){return[]})()}clearMessages(){return tA(function*(){})()}saveResult(A,e){return tA(function*(){})()}}function ta(){let A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"indexeddb",e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"playground";switch(A){case"indexeddb":if("undefined"!=typeof indexedDB)return new e8(e);return console.warn("IndexedDB not available, falling back to localStorage"),ta("localStorage",e);case"localStorage":if("undefined"!=typeof localStorage)return new to(e);return console.warn("localStorage not available, falling back to memory storage"),ta("memory",e);case"memory":return new tn;case"none":return new ti;default:throw Error(`Unknown storage type: ${A}`)}}function tl(){if("undefined"!=typeof indexedDB)try{return indexedDB.open("test",1).onerror=()=>{},"indexeddb"}catch(A){}if("undefined"!=typeof localStorage)try{return localStorage.setItem("test","test"),localStorage.removeItem("test"),"localStorage"}catch(A){}return"memory"}function ts(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function tc(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){ts(n,r,o,i,a,"next",A)}function a(A){ts(n,r,o,i,a,"throw",A)}i(void 0)})}}function td(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}function tu(A,e){return e=null!=e?e:{},Object.getOwnPropertyDescriptors?Object.defineProperties(A,Object.getOwnPropertyDescriptors(e)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(e)).forEach(function(t){Object.defineProperty(A,t,Object.getOwnPropertyDescriptor(e,t))}),A}t(2982);var tp=t(565),tg=t(8513);function tf(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}let tm=(A,e,t)=>{let r,{left:o,top:n,width:i,height:a}=A;r="element"===t?A$[function(A){A||(A="unnamed");let e=5381;for(let t=0;t<A.length;t++)e=(e<<5)+e+A.charCodeAt(t);return e>>>0}(e)%A$.length]:"searchArea"===t?A0("searchArea"):A0("element");let l=new tp.A1g;if(l.beginFill(r,.4),l.lineStyle(1,r,1),l.drawRect(o,n,i,a),l.endFill(),l.filters=[new tg.GD({blur:2,quality:3,alpha:.4,offset:{x:4,y:4},color:3355443})],!e)return[l];let s=new tp.EYj(e,{fontSize:18,fill:0});return s.x=o,s.y=Math.max(n-22,0),[l,s]},ty=A=>{let e=A.highlightElements||[];e.map(A=>A.id);let t=A.highlightRect,r=A.highlightPoints,{size:o,screenshotBase64:a}=A.uiContext,l=o.width,s=o.height,c=(0,i.useRef)(null),d=(0,i.useMemo)(()=>new tp.lgM,[]),[u,p]=(0,i.useState)(!1),g=(0,i.useMemo)(()=>new tp.mcf,[]),f=(0,i.useMemo)(()=>new tp.mcf,[]),[m,y]=(0,i.useState)(null),h=(0,i.useRef)(void 0),E=(0,i.useRef)(null),v=(0,i.useRef)([]),C=(0,i.useRef)([]);(0,i.useEffect)(()=>{var A;return Promise.resolve((A=function*(){if(!c.current||!l)return;yield d.init({width:l,height:s,background:0xffffff});let A=c.current;c.current.appendChild(d.canvas);let{clientWidth:e}=c.current.parentElement,t=.6*window.innerHeight;if(l/s<=e/t){let e=t/s;A.style.width=`${Math.floor(l*e)}px`,A.style.height=`${Math.floor(s*e)}px`}d.stage.addChild(g),d.stage.addChild(f),p(!0)},function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){tf(n,r,o,i,a,"next",A)}function a(A){tf(n,r,o,i,a,"throw",A)}i(void 0)})})()),()=>{console.log("will destroy"),null!==E.current&&(cancelAnimationFrame(E.current),E.current=null);try{d.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}},[d,l,s]),(0,i.useEffect)(()=>u?(d.stage.eventMode="static",d.stage.hitArea=new tp.M_G(0,0,l,s),d.stage.on("click",e=>{var t;console.log("pixi click",e);let{x:r,y:o}=e.data.global;null==(t=A.onCanvasClick)||t.call(A,[Math.round(r),Math.round(o)])}),()=>{var A;null==d||null==(A=d.stage)||A.off("click")}):void 0,[u,A.onCanvasClick,l,s]),(0,i.useEffect)(()=>{if(!u)return;let A=new Image;A.onload=()=>{if(!d.stage)return;let e=tp.gPd.from(A),t=new tp.kxk(e);t.x=0,t.y=0,t.width=l,t.height=s,t.eventMode="passive",d.stage.addChildAt(t,0),h.current=t,t.visible=!0},A.onerror=A=>{console.error("load screenshot failed",A)},A.src=a},[d.stage,u,l,s]);let{highlightElementRects:b}=(0,i.useMemo)(()=>{if(g.removeChildren(),f.removeChildren(),g.eventMode="passive",f.eventMode="passive",v.current=[],C.current=[],t){let[A]=tm(t,"Search Area","searchArea");g.addChild(A)}return e.length&&e.forEach(A=>{let{rect:e,content:t,id:r}=A,o=tm(e,t,"highlight"),n=o[0],i=new tg.qx({distance:30,outerStrength:3,innerStrength:0,color:0xfd5907,quality:.5}),a=n.filters;Array.isArray(a)?n.filters=[...a,i]:a?n.filters=[a,i]:n.filters=[i],o.forEach(A=>g.addChild(A)),v.current.push(n),C.current.push(i)}),(null==r?void 0:r.length)&&r.forEach(A=>{let e=((A,e)=>{let[t,r]=A,o=A0("element"),n=new tp.A1g;return n.beginFill(o,.4),n.drawCircle(t,r,10),n.endFill(),n})(A,0),t=new tg.qx({distance:25,outerStrength:2.5,innerStrength:0,color:0xfd5907,quality:.5});e.filters=[t],g.addChild(e),v.current.push(e),C.current.push(t)}),f.visible=!0,{highlightElementRects:[]}},[d,u,e,m,t,r]);(0,i.useEffect)(()=>{if(!u||0===v.current.length)return void console.log("Animation skipped:",{appInitialed:u,graphicsCount:v.current.length});console.log("Starting pulsing animation for",v.current.length,"graphics");let A=v.current,e=C.current,t=performance.now(),r=()=>{let o=(Math.sin((performance.now()-t)%1200/1200*Math.PI*2)+1)/2,n=.4+.6*o,i=2+3*o;A.forEach((A,t)=>{A.alpha=n,e[t]&&(e[t].outerStrength=i)}),E.current=requestAnimationFrame(r)};return r(),()=>{console.log("Stopping pulsing animation"),null!==E.current&&(cancelAnimationFrame(E.current),E.current=null)}},[u,e,r]);let k=null;return 1===b.length?k=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(b[0])]})}):b.length>1&&(k=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(b)]})})),(0,n.jsxs)("div",{className:"blackboard",children:[(0,n.jsx)("div",{className:"blackboard-main-content",style:{width:"100%"},ref:c}),(0,n.jsx)("div",{className:"bottom-tip",style:{display:A.hideController?"none":"block"},children:k})]})};var th=t(9783),tE=t(7294),tv=t(4985),tC=t(1090),tb=t(2946),tk=t(90),tS=t(3776);let tI=A=>{let{text:e,disabled:t=!1,speed:r=5,className:o="",colorTheme:i="blue"}=A,a={"--animation-duration":`${r}s`},l=`theme-${i}`;return(0,n.jsx)("div",{className:`shiny-text ${l} ${t?"disabled":""} ${o}`,style:a,children:e})},tR=(0,n.jsxs)("span",{children:["Don't worry, just one more step to launch the playground server.",(0,n.jsx)("br",{}),"Please run one of the commands under the midscene project directory:",(0,n.jsx)("br",{}),"a. ",(0,n.jsx)("strong",{children:"npx midscene-playground"}),(0,n.jsx)("br",{}),"b. ",(0,n.jsx)("strong",{children:"npx --yes @midscene/web"})]}),tx=function(){let A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:tR;return(0,n.jsx)("div",{className:"server-tip",children:(0,n.jsx)(ew.A,{message:"Playground Server Not Ready",description:A,type:"warning"})})},tP=(0,n.jsx)("div",{className:"result-empty-tip",style:{textAlign:"center"},children:(0,n.jsx)(tI,{disabled:!0,text:"The result will be shown here"})});var tj=JSON.parse('{"content":[{"content":"Swag Labs","rect":{"left":895,"top":38,"width":130,"height":32,"zoom":1},"center":[960,54],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"d6c5e2f100","attributes":{"nodeType":"TEXT Node"},"indexId":0},{"content":"Username","rect":{"left":814,"top":154,"width":292,"height":40,"zoom":1},"center":[960,174],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"[_midscene_retrieve_task_id=\'a9021f480e\']","id":"a9021f480e","attributes":{"class":".input_error.form_input","placeholder":"Username","type":"text","data-test":"username","id":"user-name","name":"user-name","autocorrect":"off","autocapitalize":"none","htmlTagName":"<input>","nodeType":"FORM_ITEM Node"},"indexId":1},{"content":"Password","rect":{"left":814,"top":209,"width":292,"height":40,"zoom":1},"center":[960,229],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"[_midscene_retrieve_task_id=\'580f3b761d\']","id":"580f3b761d","attributes":{"class":".input_error.form_input","placeholder":"Password","type":"password","data-test":"password","id":"password","name":"password","autocorrect":"off","autocapitalize":"none","htmlTagName":"<input>","nodeType":"FORM_ITEM Node"},"indexId":2},{"content":"","rect":{"left":814,"top":253,"width":292,"height":45,"zoom":1},"center":[960,275],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"[_midscene_retrieve_task_id=\'3e1faf0fd6\']","id":"3e1faf0fd6","attributes":{"class":".error-message-container","nodeType":"CONTAINER Node"},"indexId":3},{"content":"Login","rect":{"left":814,"top":303,"width":292,"height":49,"zoom":1},"center":[960,327],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"[_midscene_retrieve_task_id=\'6db0b64062\']","id":"6db0b64062","attributes":{"type":"submit","class":".submit-button.btn_action","data-test":"login-button","id":"login-button","name":"login-button","value":"Login","htmlTagName":"<input>","nodeType":"FORM_ITEM Node"},"indexId":4},{"content":"Accepted usernames are:","rect":{"left":570,"top":435,"width":221,"height":21,"zoom":1},"center":[680,445],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"5ca36a5942","attributes":{"nodeType":"TEXT Node"},"indexId":5},{"content":"standard_user","rect":{"left":570,"top":479,"width":109,"height":19,"zoom":1},"center":[624,488],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"fd2fe54174","attributes":{"nodeType":"TEXT Node"},"indexId":6},{"content":"locked_out_user","rect":{"left":570,"top":503,"width":126,"height":19,"zoom":1},"center":[633,512],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"403daee75b","attributes":{"nodeType":"TEXT Node"},"indexId":7},{"content":"problem_user","rect":{"left":570,"top":527,"width":101,"height":19,"zoom":1},"center":[620,536],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"2b34f1e161","attributes":{"nodeType":"TEXT Node"},"indexId":8},{"content":"performance_glitch_user","rect":{"left":570,"top":551,"width":193,"height":19,"zoom":1},"center":[666,560],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"6ae63a4d9e","attributes":{"nodeType":"TEXT Node"},"indexId":9},{"content":"error_user","rect":{"left":570,"top":575,"width":84,"height":19,"zoom":1},"center":[612,584],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"76030282f1","attributes":{"nodeType":"TEXT Node"},"indexId":10},{"content":"visual_user","rect":{"left":570,"top":599,"width":92,"height":19,"zoom":1},"center":[616,608],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"f34b057726","attributes":{"nodeType":"TEXT Node"},"indexId":11},{"content":"Password for all users:","rect":{"left":960,"top":435,"width":221,"height":21,"zoom":1},"center":[1070,445],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"e693f608cd","attributes":{"nodeType":"TEXT Node"},"indexId":12},{"content":"secret_sauce","rect":{"left":960,"top":477,"width":101,"height":19,"zoom":1},"center":[1010,486],"page":{"page":{"_isDragging":false,"_timeoutSettings":{}},"pageType":"puppeteer"},"locator":"","id":"cde9de9828","attributes":{"nodeType":"TEXT Node"},"indexId":13}],"size":{"width":1920,"height":1080},"screenshotBase64":"","screenshotBase64WithElementMarker":"","url":"https://www.saucedemo.com/"}');let tw=A=>{let{uiContextPreview:e,setUiContextPreview:t,showContextPreview:r}=A;return r?(0,n.jsxs)("div",{className:"form-part context-panel",children:[(0,n.jsx)("h3",{children:"UI Context"}),e?(0,n.jsx)(ty,{uiContext:e,hideController:!0}):(0,n.jsxs)("div",{children:[(A=>{switch(A){case"finished":case"passed":case"success":case"connected":return(0,n.jsx)("span",{style:{color:"#00AD4B"},children:(0,n.jsx)(th.A,{})});case"finishedWithWarning":return(0,n.jsx)("span",{style:{color:"#f7bb05"},children:(0,n.jsx)(tE.A,{})});case"failed":case"closed":case"timedOut":case"interrupted":return(0,n.jsx)("span",{style:{color:"#FF0A0A"},children:(0,n.jsx)(tv.A,{})});case"pending":return(0,n.jsx)(tC.A,{});case"cancelled":case"skipped":return(0,n.jsx)(tb.A,{});case"running":return(0,n.jsx)(tk.A,{});default:return(0,n.jsx)(tS.A,{})}})("failed")," No UI context",(0,n.jsx)(eK.Ay,{type:"link",onClick:A=>{A.preventDefault(),t(tj)},children:"Load Demo"}),(0,n.jsx)("div",{children:"To load the UI context, you can either use the demo data above, or click the 'Send to Playground' in the report page."})]})]}):null};var tO=t(4291);let tN=A=>{let{className:e=""}=A,{config:t}=ek();return Object.keys(t||{}).length>=1?null:(0,n.jsxs)("div",{className:`env-config-reminder ${e}`,children:[(0,n.jsx)(tO.A,{className:"reminder-icon"}),(0,n.jsx)("span",{className:"reminder-text",children:"Please set up your environment variables before using."}),(0,n.jsx)(eS,{mode:"text",showTooltipWhenEmpty:!1})]})};var tK=t(6921),tB=t(2297),tT=t(7062),tM=t(5862),tz=t(1879),tD=t(1269);let tQ=A=>{var e,t;return(0,n.jsx)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16"},A),t=t={children:(0,n.jsx)("path",{fill:"currentColor",d:"M1.333 13v-2.5a.667.667 0 0 1 1.334 0V13c0 .184.149.333.333.333h2.5a.667.667 0 0 1 0 1.334H3c-.92 0-1.667-.746-1.667-1.667m12 0v-2.5a.667.667 0 0 1 1.334 0V13c0 .92-.746 1.667-1.667 1.667h-2.5a.667.667 0 0 1 0-1.334H13a.333.333 0 0 0 .333-.333m-12-7.5V3c0-.92.747-1.667 1.667-1.667h2.5a.667.667 0 0 1 0 1.334H3A.333.333 0 0 0 2.667 3v2.5a.667.667 0 0 1-1.334 0m12 0V3A.333.333 0 0 0 13 2.667h-2.5a.667.667 0 0 1 0-1.334H13c.92 0 1.667.747 1.667 1.667v2.5a.667.667 0 0 1-1.334 0M5.667 10.333h4.666V5.667H5.667zm6 .167c0 .644-.523 1.167-1.167 1.167h-5A1.167 1.167 0 0 1 4.333 10.5v-5c0-.644.523-1.167 1.167-1.167h5c.644 0 1.167.523 1.167 1.167z"})},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))},tZ=A=>{var e,t;return(0,n.jsxs)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16"},A),t=t={children:[(0,n.jsx)("path",{stroke:"currentColor",strokeLinejoin:"round",strokeWidth:1.333,d:"M11.333 13.667 14.667 8l-3.334-5.667H4.667L1.333 8l3.334 5.667z"}),(0,n.jsx)("path",{stroke:"currentColor",strokeLinejoin:"round",strokeWidth:1.333,d:"M8 9.667a1.667 1.667 0 1 0 0-3.334 1.667 1.667 0 0 0 0 3.334Z"})]},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))};function tL(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}let tX=new Map,tJ=A=>{var e;return(e=function*(){if(!tX.has(A))return tp.sP.load(A).then(e=>{tX.set(A,e)})},function(){var A=this,t=arguments;return new Promise(function(r,o){var n=e.apply(A,t);function i(A){tL(n,r,o,i,a,"next",A)}function a(A){tL(n,r,o,i,a,"throw",A)}i(void 0)})})()};function tU(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function tF(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){tU(n,r,o,i,a,"next",A)}function a(A){tU(n,r,o,i,a,"throw",A)}i(void 0)})}}function tV(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}function tq(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){tV(A,e,t[e])})}return A}let tG=A=>new Promise(e=>setTimeout(e,A)),tH="frame cancel (this is an error on purpose)";class tW{start(){let A=new MediaRecorder(this.canvas.captureStream(60),{mimeType:"video/webm"});return A.ondataavailable=A=>{A.data.size>0&&this.chunks.push(A.data)},A.onerror=A=>{console.error("MediaRecorder error:",A),eN.Ay.error("Video recording failed. Please try again."),this.recording=!1,this.mediaRecorder=null},this.mediaRecorder=A,this.recording=!0,this.mediaRecorder.start()}stop(){this.recording&&this.mediaRecorder?(this.mediaRecorder.onstop=()=>{if(0===this.chunks.length){console.error("No video data captured"),eN.Ay.error("Video export failed: No data captured.");return}let A=new Blob(this.chunks,{type:"video/webm"});if(0===A.size){console.error("Video blob is empty"),eN.Ay.error("Video export failed: Empty file.");return}let e=URL.createObjectURL(A),t=document.createElement("a");t.href=e,t.download="midscene_replay.webm",t.click(),URL.revokeObjectURL(e)},this.mediaRecorder.stop(),this.recording=!1,this.mediaRecorder=null):console.warn("not recording")}constructor(A){tV(this,"canvas",void 0),tV(this,"mediaRecorder",null),tV(this,"chunks",void 0),tV(this,"recording",!1),this.canvas=A,this.chunks=[]}}function tY(A){var e;let t,[r,o]=(0,i.useState)(""),[a,l]=(0,i.useState)(""),{autoZoom:s,setAutoZoom:c}=ec();(0,i.useEffect)(()=>{(null==A?void 0:A.autoZoom)!==void 0&&c(A.autoZoom)},[null==A?void 0:A.autoZoom,c]);let d=null==A?void 0:A.replayScripts,u=(null==A?void 0:A.imageWidth)||1920,p=(null==A?void 0:A.imageHeight)||1080,g=(null==A?void 0:A.fitMode)||"height",f=(0,i.useRef)((null==d||null==(e=d[0])?void 0:e.img)||null),m=(0,i.useRef)(null),y=(0,i.useMemo)(()=>new tp.lgM,[]),h=(0,i.useRef)(null),E=(0,i.useRef)(null),[v,C]=(0,i.useState)(0),b=()=>{C(Date.now())},k=(0,i.useMemo)(()=>new tp.mcf,[]),S=(0,i.useMemo)(()=>{let A=new tp.mcf;return A.zIndex=1,A},[]),I={left:0,top:0,width:u,pointerLeft:Math.round(u/2),pointerTop:Math.round(p/2)},[R,x]=(0,i.useState)(-1),P=(0,i.useRef)(!1);(0,i.useEffect)(()=>(P.current=!1,()=>{P.current=!0}),[]);let j=(0,i.useRef)(tq({},I)),w=(A,e)=>tF(function*(){let t=f.current;if(!t)return void console.warn("no image to update");let r=A||u,o=e||p;yield tF(function*(){if(y.screen.width!==r||y.screen.height!==o){if(y.renderer.resize(r,o),m.current){let A=r/o;m.current.style.setProperty("--canvas-aspect-ratio",A.toString())}j.current={left:0,top:0,width:r,pointerLeft:Math.round(r/2),pointerTop:Math.round(o/2)}}})(),tX.get(t)||(console.warn("image not loaded",t),yield tJ(t));let n=tX.get(t);if(!n)throw Error("texture not found");let i=tp.kxk.from(n);if(!i)throw Error("sprite not found");let a="main-img",l=k.getChildByLabel(a);l&&k.removeChild(l),i.label=a,i.zIndex=0,i.width=r,i.height=o,k.addChild(i)})(),O=A=>{var e,t;let r;E.current||(E.current=tp.kxk.from(eU),E.current.zIndex=3,E.current.anchor.set(.5,.5),E.current.scale.set(.5),E.current.label="spinning-pointer"),E.current.x=(null==(e=h.current)?void 0:e.x)||0,E.current.y=(null==(t=h.current)?void 0:t.y)||0,k.addChild(E.current);let o=!1,n=e=>{if(o)return;r||(r=e);let t=(Math.sin((e-r)/500-Math.PI/2)+1)/2*Math.PI*2;E.current&&(E.current.rotation=t),A(n)};return A(n),()=>{E.current&&k.removeChild(E.current),o=!0}},N=(A,e,t)=>tF(function*(){var r,o;tX.get(A)||(console.warn("image not loaded",A),yield tJ(A));let n=tX.get(A);if(!n)throw Error("texture not found");let i=tp.kxk.from(n),a=null==(r=h.current)?void 0:r.x,l=null==(o=h.current)?void 0:o.y;if("number"==typeof e&&(a=e),"number"==typeof t&&(l=t),void 0===a||void 0===l)return void console.warn("invalid pointer position",e,t);if(h.current){let A=k.getChildByLabel("pointer");A&&k.removeChild(A)}h.current=i,h.current.x=a,h.current.y=l,h.current.label="pointer",h.current.zIndex=2,k.addChild(h.current)})(),K=(A,e)=>{j.current=A;let t=e||y.screen.width||u,r=s?Math.max(1,t/A.width):1;k.scale.set(r),k.x=s?Math.round(0-A.left*r):0,k.y=s?Math.round(0-A.top*r):0;let o=k.getChildByLabel("pointer");o&&(o.scale.set(1/r),"number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(o.x=A.pointerLeft,o.y=A.pointerTop))},B=(A,e,t)=>tF(function*(){let r=y.screen.width||u,o=y.screen.height||p;if(!s){let o=tq({},j.current),n=o.pointerLeft,i=o.pointerTop,a=performance.now();if("number"!=typeof A.pointerLeft||"number"!=typeof A.pointerTop||A.pointerLeft===n&&A.pointerTop===i)return;yield new Promise(l=>{let s=c=>{var d,u;let p=c-a,g=Math.min(p/e,1);K((d=tq({},o),u=u={pointerLeft:n+(A.pointerLeft-n)*g,pointerTop:i+(A.pointerTop-i)*g},Object.getOwnPropertyDescriptors?Object.defineProperties(d,Object.getOwnPropertyDescriptors(u)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(u)).forEach(function(A){Object.defineProperty(d,A,Object.getOwnPropertyDescriptor(u,A))}),d),r),p<e?t(s):l()};t(s)});return}let n=tq({},j.current),i=n.left,a=n.top,l=n.pointerLeft,c=n.pointerTop,d=n.width/r,g=performance.now(),f="number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(A.pointerLeft!==l||A.pointerTop!==c),m=f?.375*e:0,h=e-m;yield new Promise(n=>{let s=u=>{let p=tq({},j.current),y=u-g;if(f)if(y<=m){let e=Math.min(y/m,1);p.pointerLeft=l+(A.pointerLeft-l)*e,p.pointerTop=c+(A.pointerTop-c)*e}else p.pointerLeft=A.pointerLeft,p.pointerTop=A.pointerTop;if(y>m){let e=Math.min((y-m)/h,1),t=d+(A.width/r-d)*e,n=r*t;p.width=n;let l=i+(A.left-i)*e,s=a+(A.top-a)*e,c=l+n-r,u=s+o*t-o;p.left=c>0?l+c:l,p.top=u>0?s+u:s}K(p,r),y<e?t(s):n()};t(s)})})(),T=function(A,e,t){let r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:1;return new Promise(o=>{let n=performance.now(),i=a=>{let l=a-n,s=Math.min(l/e,1);A.alpha=0===r?1-s:s,l<e?t(i):o()};t(i)})},M=(A,e,t)=>tF(function*(){return T(A,e,t,0)})(),z=(A,e,t,r,o)=>tF(function*(){S.removeChildren();let n=[...A],i=n.length,a=0;yield new Promise(A=>{let l=performance.now(),s=c=>{var d;let u,p=c-l,g=Math.floor((0*(u=1-(d=Math.min(p/r,1)))*u*u+1.5*d*u*u+1.5*d*d*u+d*d*d)*i);for(;a<g;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0];if(e){let[A]=tm(e.rect,e.content,"element");A.alpha=0,S.addChild(A),a++,T(A,80,o)}}if(p<r)o(s);else{for(;n.length>0;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0],[t]=tm(e.rect,e.content,"element");t.alpha=1,S.addChild(t)}if(t){let[A]=tm(t,"Search Area","searchArea");A.alpha=1,S.addChild(A)}e.map(A=>{let[e]=tm(A.rect,A.content||"","highlight");e.alpha=1,S.addChild(e)}),A()}};o(s)})})(),[D,Q]=(0,i.useState)(!1),Z=(0,i.useRef)(null),L=(0,i.useRef)(null);(0,i.useEffect)(()=>(Promise.resolve(tF(function*(){if(yield tF(function*(){m.current&&d&&(yield y.init({width:u,height:p,background:0xf4f4f4,autoDensity:!0,antialias:!0}),m.current&&(m.current.appendChild(y.canvas),k.x=0,k.y=0,y.stage.addChild(k),S.x=0,S.y=0,k.addChild(S)))})(),m.current&&u&&p){let A=u/p;m.current.style.setProperty("--canvas-aspect-ratio",A.toString()),m.current.setAttribute("data-fit-mode",g);let e=m.current.closest(".player-container");e&&e.setAttribute("data-fit-mode",g)}b()})()),()=>{try{y.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}),[u,p,g]),(0,i.useEffect)(()=>{if(v){let A;return Promise.resolve(tF(function*(){let e;if(!y)throw Error("app is not initialized");if(!d)throw Error("scripts is required");let{frame:t,cancel:r,timeout:n}=(e=!1,{frame:A=>{if(e)throw Error(tH);requestAnimationFrame(()=>{if(e)throw Error(tH);A(performance.now())})},timeout:(A,t)=>{if(e)throw Error(tH);setTimeout(()=>{if(e)throw Error(tH);A()},t)},cancel:()=>{e=!0}});A=r,L.current=r;let i=d.filter(A=>!!A.img).map(A=>A.img);yield Promise.all([...i,eU,eJ].map(tJ)),S.removeChildren(),yield N(eJ,u/2,p/2),yield w(),yield K(tq({},I));let a=d.reduce((A,e)=>A+e.duration+(e.camera&&e.insightCameraDuration?e.insightCameraDuration:0),0),s=performance.now();x(0);let c=()=>{let A=Math.min((performance.now()-s)/a,1);if(x(A),A<1)return n(c,200)};for(let A in t(c),Z.current&&Z.current.start(),d){let e=d[A];if(o(e.title||""),l(e.subTitle||""),"sleep"===e.type)yield tG(e.duration);else if("insight"===e.type){if(!e.img)throw Error("img is required");f.current=e.img,yield w(e.imageWidth,e.imageHeight);let A=e.highlightElement?[e.highlightElement]:[];if(yield z([],A,e.searchArea,e.duration,t),e.camera){if(!e.insightCameraDuration)throw Error("insightCameraDuration is required");yield B(e.camera,e.insightCameraDuration,t)}}else if("clear-insight"===e.type)yield M(S,e.duration,t),S.removeChildren(),S.alpha=1;else if("img"===e.type)e.img&&e.img!==f.current&&(f.current=e.img,yield w(e.imageWidth,e.imageHeight)),e.camera?yield B(e.camera,e.duration,t):yield tG(e.duration);else if("pointer"===e.type){if(!e.img)throw Error("pointer img is required");yield N(e.img)}else if("spinning-pointer"===e.type){let A=O(t);yield tG(e.duration),A()}}Z.current&&(yield tG(1200),Z.current.stop(),Z.current=null,Q(!1))})().catch(A=>{if(console.error("player error",A),(null==A?void 0:A.message)===tH)return void console.log("Animation cancelled (expected behavior)");let e=!!Z.current;if(Z.current){try{Z.current.stop()}catch(A){console.error("Error stopping recorder:",A)}Z.current=null}Q(!1),e&&eN.Ay.error("Failed to export video. Please try again.")})),()=>{null==A||A(),L.current=null}}},[v]);let[X,J]=(0,i.useState)(!1),[U,F]=(0,i.useState)(!1),V=Math.round(100*R),q=1===R;(0,i.useEffect)(()=>{if(q){let A=A=>{" "===A.key&&b()};return window.addEventListener("keydown",A),()=>{window.removeEventListener("keydown",A)}}},[q]);let G=()=>{};return R<1?t=(0,n.jsx)(tK.A,{indicator:(0,n.jsx)(ex.A,{spin:!0,color:"#333"}),size:"default"}):X?(t=(0,n.jsx)(tK.A,{indicator:(0,n.jsx)(tB.A,{color:"#333"}),size:"default"}),G=()=>b()):t=(0,n.jsx)(tK.A,{indicator:(0,n.jsx)(tB.A,{color:"#333"}),size:"default"}),(0,n.jsxs)("div",{className:"player-container",children:[(0,n.jsx)("div",{className:"canvas-container",ref:m}),(0,n.jsx)("div",{className:"player-timeline-wrapper",children:(0,n.jsx)("div",{className:"player-timeline",children:(0,n.jsx)("div",{className:"player-timeline-progress",style:{width:`${V}%`,transition:0===R?"none":"0.3s"}})})}),(0,n.jsx)("div",{className:"player-tools-wrapper",children:(0,n.jsx)("div",{className:"player-tools",children:(0,n.jsxs)("div",{className:"player-control",children:[(0,n.jsxs)("div",{className:"status-text",children:[(0,n.jsx)("div",{className:"title",children:r}),(0,n.jsx)(A6.A,{title:a,children:(0,n.jsx)("div",{className:"subtitle",children:a})})]}),D?null:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>J(!0),onMouseLeave:()=>J(!1),onClick:G,children:t}),(null==A?void 0:A.reportFileContent)&&(null==A?void 0:A.canDownloadReport)!==!1?(0,n.jsx)(A6.A,{title:"Download Report",children:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>J(!0),onMouseLeave:()=>J(!1),onClick:()=>{let e,t,r;return e=new Blob([A.reportFileContent],{type:"text/html"}),t=URL.createObjectURL(e),void((r=document.createElement("a")).href=t,r.download="midscene_report.html",r.click())},children:(0,n.jsx)(tT.A,{color:"#333"})})}):null,(0,n.jsx)(A6.A,{title:D?"Generating...":"Export Video",children:(0,n.jsx)("div",{className:"status-icon",onClick:D?void 0:()=>tF(function*(){Z.current?console.warn("recorderSession exists"):y.canvas?(L.current&&(L.current(),L.current=null,yield new Promise(A=>setTimeout(A,100))),Z.current=new tW(y.canvas),Q(!0),b()):console.warn("canvas is not initialized")})(),style:{opacity:D?.5:1,cursor:D?"not-allowed":"pointer"},children:D?(0,n.jsx)(tK.A,{size:"default",percent:V}):(0,n.jsx)(tM.A,{})})}),(0,n.jsx)(tz.A,{trigger:["hover","click"],placement:"bottomRight",overlayStyle:{minWidth:"148px"},dropdownRender:A=>(0,n.jsx)("div",{style:{borderRadius:"8px",border:"1px solid rgba(0, 0, 0, 0.08)",backgroundColor:"#fff",boxShadow:"0 2px 8px rgba(0, 0, 0, 0.08)",overflow:"hidden"},children:A}),menu:{style:{borderRadius:"8px",padding:0},items:[{key:"autoZoom",style:{height:"39px",margin:0,padding:"0 12px"},label:(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",width:"100%",height:"39px"},children:[(0,n.jsxs)("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[(0,n.jsx)(tQ,{style:{width:"16px",height:"16px"}}),(0,n.jsx)("span",{style:{fontSize:"12px",marginRight:"16px"},children:"Focus on cursor"})]}),(0,n.jsx)(tD.A,{size:"small",checked:s,onChange:A=>{c(A),b()},onClick:(A,e)=>{var t;return null==e||null==(t=e.stopPropagation)?void 0:t.call(e)}})]})}]},children:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>F(!0),onMouseLeave:()=>F(!1),style:{cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",opacity:U?1:.7,transition:"opacity 0.2s"},children:(0,n.jsx)(tZ,{style:{width:"16px",height:"16px"}})})})]})})})]})}let t_=A=>{let{result:e,loading:t,serverValid:r,serviceMode:o,replayScriptsInfo:i,replayCounter:a,loadingProgressText:l,verticalMode:s=!1,notReadyMessage:c,fitMode:d,autoZoom:u,actionType:p,canDownloadReport:g}=A,f="result-wrapper";s&&(f+=" vertical-mode-result"),i&&s&&(f+=" result-wrapper-compact");let m=tP,y=p&&AU.includes(p);if(r||"Server"!==o)if(t)m=(0,n.jsxs)("div",{className:"loading-container",children:[(0,n.jsx)(tK.A,{spinning:t,indicator:(0,n.jsx)(ex.A,{spin:!0})}),(0,n.jsx)("div",{className:"loading-progress-text loading-progress-text-progress",children:(0,n.jsx)(tI,{text:l,speed:3})})]});else if(null==e?void 0:e.error){let A=(0,n.jsx)("pre",{style:{color:"#ff4d4f",whiteSpace:"pre-wrap"},children:null==e?void 0:e.error});m=e.reportHTML||i?(0,n.jsxs)("div",{style:{display:"flex",flexDirection:"column",gap:"16px",height:"100%"},children:[(0,n.jsxs)("div",{style:{flex:"0 0 auto",maxHeight:"40%",overflow:"auto"},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Error:"}),A]}),(0,n.jsxs)("div",{style:{flex:"1 1 auto",minHeight:0},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Report:"}),(0,n.jsx)(tY,{replayScripts:null==i?void 0:i.scripts,imageWidth:null==i?void 0:i.width,imageHeight:null==i?void 0:i.height,reportFileContent:e.reportHTML||null,fitMode:d,autoZoom:u,canDownloadReport:null!=g?g:"In-Browser"!==o},a)]})]}):A}else if(y&&(null==e?void 0:e.result)!==void 0&&i){let A="string"==typeof(null==e?void 0:e.result)?(0,n.jsx)("pre",{children:null==e?void 0:e.result}):(0,n.jsx)("pre",{children:JSON.stringify(null==e?void 0:e.result,null,2)}),t=(null==e?void 0:e.reportHTML)||null;m=(0,n.jsxs)("div",{style:{display:"flex",flexDirection:"column",gap:"16px",height:"100%"},children:[(0,n.jsxs)("div",{style:{flex:"0 0 auto"},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Output:"}),A]}),(0,n.jsxs)("div",{style:{flex:"1 1 auto",minHeight:0},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Report:"}),(0,n.jsx)(tY,{replayScripts:i.scripts,imageWidth:i.width,imageHeight:i.height,reportFileContent:t,fitMode:d,autoZoom:u,canDownloadReport:null!=g?g:"In-Browser"!==o},a)]})]})}else if(i){let A=(null==e?void 0:e.reportHTML)||null;m=(0,n.jsx)(tY,{replayScripts:i.scripts,imageWidth:i.width,imageHeight:i.height,reportFileContent:A,fitMode:d,autoZoom:u,canDownloadReport:null!=g?g:"In-Browser"!==o},a)}else if(y&&(null==e?void 0:e.result)!==void 0&&(null==e?void 0:e.reportHTML)){let A="string"==typeof(null==e?void 0:e.result)?(0,n.jsx)("pre",{children:null==e?void 0:e.result}):(0,n.jsx)("pre",{children:JSON.stringify(null==e?void 0:e.result,null,2)});m=(0,n.jsxs)("div",{style:{display:"flex",flexDirection:"column",gap:"16px",height:"100%"},children:[(0,n.jsxs)("div",{style:{flex:"0 0 auto"},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Output:"}),A]}),(0,n.jsxs)("div",{style:{flex:"1 1 auto",minHeight:0},children:[(0,n.jsx)("div",{style:{fontWeight:"bold",marginBottom:"8px"},children:"Report:"}),(0,n.jsx)(tY,{reportFileContent:e.reportHTML,fitMode:d,autoZoom:u,canDownloadReport:null!=g?g:"In-Browser"!==o},a)]})]})}else y&&(null==e?void 0:e.result)!==void 0?m="string"==typeof(null==e?void 0:e.result)?(0,n.jsx)("pre",{children:null==e?void 0:e.result}):(0,n.jsx)("pre",{children:JSON.stringify(null==e?void 0:e.result,null,2)}):(null==e?void 0:e.reportHTML)?m=(0,n.jsx)(tY,{reportFileContent:e.reportHTML,fitMode:d,autoZoom:u,canDownloadReport:null!=g?g:"In-Browser"!==o},a):(null==e?void 0:e.result)!==void 0&&(m="string"==typeof(null==e?void 0:e.result)?(0,n.jsx)("pre",{children:null==e?void 0:e.result}):(0,n.jsx)("pre",{children:JSON.stringify(null==e?void 0:e.result,null,2)}));else m=tx(c);return(0,n.jsx)("div",{className:f,style:{height:"100%",display:"flex",flexDirection:"column",flex:"1 1 auto",justifyContent:"center"},children:m})},t$=A=>{var e,t;return(0,n.jsxs)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:20,height:20,fill:"none","aria-label":"Playground",viewBox:"0 0 20 20"},A),t=t={children:[(0,n.jsx)("rect",{width:20,height:20,fill:"#2B83FF",rx:10}),(0,n.jsx)("path",{fill:"#2B83FF",stroke:"#fff",strokeLinejoin:"round",strokeWidth:1.125,d:"M6.866 5.882a.56.56 0 0 1 .667-.078l3.248 1.875 3.247 1.875a.563.563 0 0 1 0 .974l-3.247 1.875-3.248 1.875a.563.563 0 0 1-.784-.74l1.749-3.497-1.75-3.498a.56.56 0 0 1 .118-.661Z"})]},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))};var t0=t(8460),t1=t(3896),t3=t(1631),t5=t(4665),t7={};t7.d=(A,e)=>{for(var t in e)t7.o(e,t)&&!t7.o(A,t)&&Object.defineProperty(A,t,{enumerable:!0,get:e[t]})},t7.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),t7.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})};var t9={};function t2(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}t7.r(t9),t7.d(t9,{create:()=>eA.vt});let{create:t6}=t9,t8="midscene-prompt-history-v2",t4="midscene-last-selected-type",rA=t6((A,e)=>{let t;return{history:(t=localStorage.getItem(t8))?JSON.parse(t):{},lastSelectedType:localStorage.getItem(t4)||"aiAct",clearHistory:t=>{let r=t2({},e().history);delete r[t],A({history:r}),localStorage.setItem(t8,JSON.stringify(r))},addHistory:t=>{var r,o;let{type:n}=t,i=e().history,a=i[n]||[],l=JSON.stringify({prompt:t.prompt,params:t.params}),s=[t,...a.filter(A=>JSON.stringify({prompt:A.prompt,params:A.params})!==l)];s.length>10&&(s.length=10);let c=(r=t2({},i),o=o={[n]:s},Object.getOwnPropertyDescriptors?Object.defineProperties(r,Object.getOwnPropertyDescriptors(o)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(o)).forEach(function(A){Object.defineProperty(r,A,Object.getOwnPropertyDescriptor(o,A))}),r);A({history:c}),localStorage.setItem(t8,JSON.stringify(c))},getHistoryForType:A=>e().history[A]||[],setLastSelectedType:e=>{A({lastSelectedType:e}),localStorage.setItem(t4,e)}}}),re="ZodOptional",rt="ZodDefault",rr="ZodNullable",ro="ZodObject",rn="midscene_location_field_flag",ri=A=>"object"==typeof A&&null!==A&&("shape"in A||"ZodObject"===A.type),ra=A=>{var e,t,r;if((null==(e=A._def)?void 0:e.typeName)===ro){let e;if(A._def.shape&&(e="function"==typeof A._def.shape?A._def.shape():A._def.shape),!e&&A.shape&&(e=A.shape),e&&rn in e)return!0;let r=(null==(t=A._def)?void 0:t.description)||A.description||"";if("string"==typeof r&&r.toLowerCase().includes("input field"))return!0}if("object"==typeof A&&null!==A){let e=A.description||(null==(r=A._def)?void 0:r.description)||"";if("string"==typeof e){let A=e.toLowerCase();if(A.includes("input field")||A.includes("element")||A.includes("locate"))return!0}if("ZodObject"===A.typeName||"ZodObject"===A.type)return"string"==typeof e&&e.toLowerCase().includes("input field")}return!1},rl=A=>{var e,t,r,o,n;let i=A,a=!1,l=!1;for(;(null==(e=i._def)?void 0:e.typeName)===re||(null==(t=i._def)?void 0:t.typeName)===rt||(null==(r=i._def)?void 0:r.typeName)===rr;)(null==(o=i._def)?void 0:o.typeName)===re&&(a=!0),(null==(n=i._def)?void 0:n.typeName)===rt&&(l=!0),i=i._def.innerType||i;return{actualField:i,isOptional:a,hasDefault:l}},rs=A=>{let e=A.startsWith("ai")?A.slice(2):A;if(e.startsWith("IOS"))return e.substring(3).replace(/([A-Z])/g," $1").replace(/^/,"IOS").trim();let t=e.replace(/([A-Z])/g," $1").trim(),r=t.split(" ");return r.length>3?r.slice(-3).join(" "):t};var rc=t(6356);let rd=A=>{var e,t;return(0,n.jsx)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:27,height:27,fill:"none",viewBox:"0 0 27 27"},A),t=t={children:(0,n.jsx)("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeOpacity:.85,strokeWidth:1.333,d:"M19.527 8.855h-2M14.86 7.522v2.667M14.86 8.855H7.527M10.194 13.522H7.527M12.86 12.189v2.666M20.193 13.522H12.86M19.527 18.189h-2M14.86 16.855v2.667M14.86 18.189H7.527"})},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))},ru=A=>{let e,{showDeepThinkOption:t=!1,enableTracking:r=!1,showDataExtractionOptions:o=!1,hideDomAndScreenshotOptions:i=!1,deviceType:a}=A,l=ek(A=>A.forceSameTabNavigation),s=ek(A=>A.setForceSameTabNavigation),c=ek(A=>A.deepThink),d=ek(A=>A.setDeepThink),u=ek(A=>A.screenshotIncluded),p=ek(A=>A.setScreenshotIncluded),g=ek(A=>A.domIncluded),f=ek(A=>A.setDomIncluded),m=ek(A=>A.imeStrategy),y=ek(A=>A.setImeStrategy),h=ek(A=>A.autoDismissKeyboard),E=ek(A=>A.setAutoDismissKeyboard),v=ek(A=>A.keyboardDismissStrategy),C=ek(A=>A.setKeyboardDismissStrategy),b=ek(A=>A.alwaysRefreshScreenInfo),k=ek(A=>A.setAlwaysRefreshScreenInfo);if(!r&&!t&&!o&&"android"!==a&&"ios"!==a)return null;let S=(e=[],r&&e.push({label:(0,n.jsx)(rc.A,{onChange:A=>s(A.target.checked),checked:l,children:"limit popup to current tab"}),key:"track-config"}),t&&e.push({label:(0,n.jsx)(rc.A,{onChange:A=>{d(A.target.checked)},checked:c,children:"deep think"}),key:"deep-think-config"}),o&&!i&&(e.push({label:(0,n.jsx)(rc.A,{onChange:A=>{p(A.target.checked)},checked:u,children:"include screenshot in request"}),key:"screenshot-included-config"}),e.push({label:(0,n.jsxs)("div",{style:{padding:"4px 0"},children:[(0,n.jsx)("div",{style:{marginBottom:"4px",fontSize:"14px"},children:"include DOM info in request"}),(0,n.jsxs)(t5.A.Group,{size:"small",value:g,onChange:A=>f(A.target.value),children:[(0,n.jsx)(t5.A,{value:!1,children:"Off"}),(0,n.jsx)(t5.A,{value:!0,children:"All"}),(0,n.jsx)(t5.A,{value:"visible-only",children:"Visible only"})]})]}),key:"dom-included-config"})),"android"===a&&(e.push({label:(0,n.jsxs)("div",{style:{padding:"4px 0"},children:[(0,n.jsx)("div",{style:{marginBottom:"4px",fontSize:"14px"},children:"IME strategy"}),(0,n.jsxs)(t5.A.Group,{size:"small",value:m,onChange:A=>y(A.target.value),children:[(0,n.jsx)(t5.A,{value:"always-yadb",children:"Always YADB"}),(0,n.jsx)(t5.A,{value:"yadb-for-non-ascii",children:"YADB for non-ASCII"})]})]}),key:"ime-strategy-config"}),e.push({label:(0,n.jsx)(rc.A,{onChange:A=>E(A.target.checked),checked:h,children:eD}),key:"auto-dismiss-keyboard-config"}),e.push({label:(0,n.jsxs)("div",{style:{padding:"4px 0"},children:[(0,n.jsx)("div",{style:{marginBottom:"4px",fontSize:"14px"},children:"Keyboard dismiss strategy"}),(0,n.jsxs)(t5.A.Group,{size:"small",value:v,onChange:A=>C(A.target.value),children:[(0,n.jsx)(t5.A,{value:"esc-first",children:"ESC first"}),(0,n.jsx)(t5.A,{value:"back-first",children:"Back first"})]})]}),key:"keyboard-dismiss-strategy-config"}),e.push({label:(0,n.jsx)(rc.A,{onChange:A=>k(A.target.checked),checked:b,children:"Always refresh screen info"}),key:"always-refresh-screen-info-config"})),"ios"===a&&e.push({label:(0,n.jsx)(rc.A,{onChange:A=>E(A.target.checked),checked:h,children:eD}),key:"auto-dismiss-keyboard-config"}),e);return(0,n.jsx)("div",{className:"selector-trigger",children:(0,n.jsx)(tz.A,{menu:{items:S},trigger:["click"],children:(0,n.jsx)(rd,{width:24,height:24})})})};var rp=t(9076),rg=t(5932);let{TextArea:rf}=A4.A,rm=(A,e)=>`${A}${e?" (Optional)":""}`,ry=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A,a=i||`Enter ${e}`;return(0,n.jsx)(eO.A.Item,{name:["params",e],label:rm(t,!r),rules:r?[{required:!0,message:`Please input ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(A4.A,{placeholder:a})},e)},rh=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A,a=i||`Describe the ${e}, use natural language`;return(0,n.jsx)(eO.A.Item,{name:["params",e],label:rm(t,!r),rules:r?[{required:!0,message:`The ${e} is required`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rf,{rows:2,placeholder:a})},e)},rE=A=>{var e;let{name:t,label:r,fieldSchema:o,isRequired:i,marginBottom:a,placeholder:l}=A,s=((null==(e=o._def)?void 0:e.values)||[]).map(A=>({value:A,label:A.charAt(0).toUpperCase()+A.slice(1)}));return(0,n.jsx)(eO.A.Item,{name:["params",t],label:r,rules:i?[{required:!0,message:`Please select ${t}`}]:[],style:{marginBottom:a},colon:!1,children:(0,n.jsx)(rp.A,{placeholder:l||`Select ${t}`,options:s})},t)},rv=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A,a=500*("distance"===e),l=i&&Number(i)||a,s="distance"===e?1e4:void 0;return(0,n.jsx)(eO.A.Item,{name:["params",e],label:`${t}${"distance"===e?" (px)":""}`,rules:r?[{required:!0,message:`Please input ${e}`},{type:"number",min:0,message:`${t} must be at least 0`}]:[{type:"number",min:0,message:`${t} must be at least 0`}],style:{flex:"distance"===e?1:void 0,marginBottom:o},colon:!1,children:(0,n.jsx)(rg.A,{placeholder:l.toString(),min:0,max:s,step:"distance"===e?10:1,style:{width:"100%"}})},e)},rC=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A;return(0,n.jsx)(eO.A.Item,{name:["params",e],label:rm(t,!r),rules:r?[{required:!0,message:`Please select ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rp.A,{placeholder:i||`Select ${e}`,options:[{value:!0,label:"True"},{value:!1,label:"False"}]})},e)},rb=A=>{var e,t;return(0,n.jsx)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:18,height:16,fill:"none",viewBox:"0 0 18 16"},A),t=t={children:(0,n.jsx)("path",{stroke:"#333",strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:1.333,d:"m3.124 2.667 11.162 10.666M3.124 13.333 14.286 2.667"})},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))},rk=A=>{var e,t;return(0,n.jsxs)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:25,height:25,fill:"none",viewBox:"0 0 25 25"},A),t=t={children:[(0,n.jsx)("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeOpacity:.85,strokeWidth:1.33,d:"M6.63 9.021c-2.862 6.126 2.197 10.501 6.063 10.501a7 7 0 1 0-6.063-10.5"}),(0,n.jsx)("path",{stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round",strokeOpacity:.85,strokeWidth:1.33,d:"M12.695 8.322v4.203l2.967 2.968"})]},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))},rS=A=>{var e,t;return(0,n.jsxs)("svg",(e=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({xmlns:"http://www.w3.org/2000/svg",width:19,height:19,fill:"none",viewBox:"0 0 19 19"},A),t=t={children:[(0,n.jsxs)("g",{stroke:"currentColor",strokeLinejoin:"round",strokeOpacity:.65,strokeWidth:1.5,clipPath:"url(#magnifying-glass_svg__a)",children:[(0,n.jsx)("path",{d:"M8.397 14.29a6.375 6.375 0 1 0 0-12.75 6.375 6.375 0 0 0 0 12.75Z"}),(0,n.jsx)("path",{strokeLinecap:"round",d:"M10.519 5.42a3 3 0 0 0-2.122-.88 3 3 0 0 0-2.121.88M12.98 12.499l3.182 3.182"})]}),(0,n.jsx)("defs",{children:(0,n.jsx)("clipPath",{id:"magnifying-glass_svg__a",children:(0,n.jsx)("path",{fill:"#fff",d:"M.522.04h18v18h-18z"})})})]},Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(t)).forEach(function(A){Object.defineProperty(e,A,Object.getOwnPropertyDescriptor(t,A))}),e))},{Text:rI}=A9.A,rR=A=>{let{onSelect:e,history:t,currentType:r}=A,[o,a]=(0,i.useState)(!1),[l,s]=(0,i.useState)(""),c=rA(A=>A.clearHistory),d=(0,i.useRef)(null),u=(0,i.useMemo)(()=>{let A=Date.now(),e=A-6048e5,r=A-31536e6,o=t.filter(A=>A.prompt.toLowerCase().includes(l.toLowerCase()));return{recent7Days:o.filter(A=>A.timestamp>=e),recent1Year:o.filter(A=>A.timestamp<e&&A.timestamp>=r),older:o.filter(A=>A.timestamp<r)}},[t,l]);(0,i.useEffect)(()=>{if(!o)return;let A=A=>{d.current&&!d.current.contains(A.target)&&a(!1)},e=setTimeout(()=>{document.addEventListener("click",A)},100);return()=>{clearTimeout(e),document.removeEventListener("click",A)}},[o]);let p=(A,t)=>0===t.length?null:(0,n.jsxs)("div",{className:"history-group",children:[(0,n.jsx)("div",{className:"history-group-title",children:A}),t.map((A,t)=>(0,n.jsx)("div",{className:"history-item",onClick:()=>{e(A),a(!1)},children:A.prompt},`${A.timestamp}-${t}`))]},A);return(0,n.jsxs)("div",{className:"history-selector-wrapper",children:[(0,n.jsx)("div",{className:"selector-trigger",onClick:()=>a(!0),children:(0,n.jsx)(rk,{width:24,height:24})}),o&&(0,n.jsx)("div",{className:"history-modal-overlay",ref:d,children:(0,n.jsxs)("div",{className:"history-modal-container",children:[(0,n.jsxs)("div",{className:"history-modal-header",children:[(0,n.jsxs)(rI,{strong:!0,style:{fontSize:"16px"},children:["History (",t.length,")"]}),(0,n.jsx)(eK.Ay,{size:"small",type:"text",icon:(0,n.jsx)(rb,{width:16,height:16}),onClick:()=>a(!1),className:"close-button"})]}),(0,n.jsx)("div",{className:"history-search-section",children:(0,n.jsxs)("div",{className:"search-input-wrapper",children:[(0,n.jsx)(A4.A,{placeholder:"Search",value:l,onChange:A=>s(A.target.value),prefix:(0,n.jsx)(rS,{width:18,height:18}),className:"search-input",allowClear:!0}),(0,n.jsx)(eK.Ay,{type:"link",onClick:()=>{c(r),s(""),a(!1)},className:"clear-button",disabled:0===t.length,children:"Clear"})]})}),(0,n.jsx)("div",{className:"history-content",children:0===t.length?(0,n.jsx)("div",{className:"no-results",children:(0,n.jsx)(rI,{type:"secondary",children:"No history record"})}):(0,n.jsxs)(n.Fragment,{children:[p("Last 7 days",u.recent7Days),p("Last 1 year",u.recent1Year),p("Earlier",u.older),l&&0===u.recent7Days.length&&0===u.recent1Year.length&&0===u.older.length&&(0,n.jsx)("div",{className:"no-results",children:(0,n.jsx)(rI,{type:"secondary",children:"No matching history record"})})]})})]})})]})};function rx(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}let{TextArea:rP}=A4.A,rj=A=>{let e,t,r,o,a,l,{runButtonEnabled:s,form:c,serviceMode:d,selectedType:u,dryMode:p,stoppable:g,loading:f,onRun:m,onStop:y,clearPromptAfterRun:h=!0,actionSpace:E,hideDomAndScreenshotOptions:v=!1,deviceType:C}=A,[b,k]=(0,i.useState)(!1),[S,I]=(0,i.useState)(""),R="aiQuery"===u?"What do you want to query?":"aiAssert"===u?"What do you want to assert?":"aiTap"===u?"What element do you want to tap?":"aiDoubleClick"===u?"What element do you want to double-click?":"aiHover"===u?"What element do you want to hover over?":"aiInput"===u?"Format: <value> | <element>\nExample: hello world | search box":"aiRightClick"===u?"What element do you want to right-click?":"aiKeyboardPress"===u?"Format: <key> | <element (optional)>\nExample: Enter | text field":"aiScroll"===u?"Format: <direction> <amount> | <element (optional)>\nExample: down 500 | main content":"aiLocate"===u?"What element do you want to locate?":"aiBoolean"===u?"What do you want to check (returns true/false)?":"aiNumber"===u?"What number do you want to extract?":"aiString"===u?"What text do you want to extract?":"aiAsk"===u?"What do you want to ask?":"aiWaitFor"===u?"What condition do you want to wait for?":"What do you want to do?",x=(0,i.useRef)(null),P=(0,i.useRef)(null),j=eO.A.useWatch("params",c),w=(0,i.useRef)(null),O=rA(A=>A.history),N=rA(A=>A.lastSelectedType),K=rA(A=>A.addHistory),B=rA(A=>A.setLastSelectedType),T=(0,i.useMemo)(()=>O[u]||[],[O,u]),M=(0,i.useMemo)(()=>{if(E){let A=E.find(A=>A.interfaceAlias===u||A.name===u);return!!(null==A?void 0:A.paramSchema)&&(!ri(A.paramSchema)||Object.keys(A.paramSchema.shape||{}).length>0)}return!1},[u,E]),z=(0,i.useMemo)(()=>{if(E&&E.length>0){let A=E.find(A=>A.interfaceAlias===u||A.name===u);if(A){if(A.paramSchema&&ri(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{isOptional:t}=rl(e[A]);return!t})}return!!A.paramSchema}}return!0},[u,E]),D=(0,i.useMemo)(()=>["aiQuery","aiBoolean","aiNumber","aiString","aiAsk","aiAssert"].includes(u),[u]),Q=(0,i.useMemo)(()=>{if("aiLocate"===u)return!0;if(E){let A=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==A?void 0:A.paramSchema)&&ri(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{actualField:t}=rl(e[A]);return ra(t)})}}return!1},[u,E]),Z=(0,i.useMemo)(()=>{let A=D&&!v,e="android"===C||"ios"===C;return"In-Browser-Extension"===d||Q||A||e},[d,Q,D,v,C]),L=(0,i.useMemo)(()=>{let A=Object.keys(eQ);if(!E||0===E.length)return A;let e=E.map(A=>A.interfaceAlias||A.name),t=new Set;return A.forEach(A=>{let r=eQ[A];(null==r?void 0:r.group)==="extraction"||(null==r?void 0:r.group)==="validation"?t.add(A):e.includes(A)&&t.add(A)}),e.forEach(A=>{t.add(A)}),Array.from(t)},[E]),X=(0,i.useCallback)(()=>{if(!M||!E)return{};let A=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==A?void 0:A.paramSchema)&&ri(A.paramSchema)){let e={},t=A.paramSchema.shape||{};return Object.keys(t).forEach(A=>{let r=(A=>{var e;let t=A;for(;null==(e=t._def)?void 0:e.innerType;){if(t._def.typeName===rt&&t._def.defaultValue)return t._def.defaultValue();t=t._def.innerType}})(t[A]);void 0!==r&&(e[A]=r)}),e}return{}},[u,M,E]);(0,i.useEffect)(()=>{!c.getFieldValue("type")&&N&&c.setFieldValue("type",N)},[c,N]),(0,i.useEffect)(()=>{u&&u!==N&&B(u)},[u,N,B]);let J=(0,i.useCallback)(()=>{let A=P.current;if(!A)return;let e=null,t=A.querySelector(".ant-radio-button-wrapper-checked"),r=A.querySelector(".more-apis-button.selected-from-dropdown");if(t?e=t:r&&(e=r),e){let t=A.getBoundingClientRect(),r=e.getBoundingClientRect(),o=r.left-t.left+A.scrollLeft,n=r.width,i=t.width;A.scrollTo({left:Math.max(0,o-(i-n)/2),behavior:"smooth"})}},[]);(0,i.useEffect)(()=>{let A=T[0];if(!A||!w.current||A.timestamp!==w.current.timestamp)if(A)c.setFieldsValue({type:A.type,prompt:A.prompt||"",params:A.params}),I(A.prompt||""),w.current=A;else{let A=X();c.setFieldsValue({prompt:"",params:A}),I(""),w.current=null}},[u,T,c,X]),(0,i.useEffect)(()=>{let A=setTimeout(()=>{J()},100);return()=>clearTimeout(A)},[u,J]);let U=eO.A.useWatch("prompt",c);(0,i.useEffect)(()=>{U!==S&&I(U||"")},[U,S]);let F=(0,i.useCallback)(A=>{c.setFieldsValue({prompt:A.prompt,type:A.type,params:A.params}),I(A.prompt)},[c]),V=(0,i.useCallback)(A=>{I(A.target.value)},[]),q=(0,i.useMemo)(()=>{if(!M||!E)return!1;let A=E.find(A=>A.interfaceAlias===u||A.name===u);return!!((null==A?void 0:A.paramSchema)&&ri(A.paramSchema))&&1===Object.keys(A.paramSchema.shape||{}).length},[u,M,E]),G=(0,i.useMemo)(()=>((A,e,t,r,o,n)=>{if(!A)return!1;if(!(()=>{if(r){let A=r.find(A=>A.interfaceAlias===o||A.name===o);if(A){if(!A.paramSchema)return!1;if("object"==typeof A.paramSchema&&"shape"in A.paramSchema)return Object.keys(A.paramSchema.shape||{}).length>0}}return!0})())return!0;if(e){let A=t||{},e=null==r?void 0:r.find(A=>A.interfaceAlias===o||A.name===o);if((null==e?void 0:e.paramSchema)&&ri(e.paramSchema)){let t=e.paramSchema.shape||{};return Object.keys(t).every(e=>{let{isOptional:r}=rl(t[e]),o=A[e];return r||void 0!==o&&""!==o&&null!==o})}return!0}return n.trim().length>0})(s,!!M,j,E,u,S),[s,M,u,E,S,j]),H=(0,i.useCallback)(()=>{let A=c.getFieldsValue(),e="";if(M&&A.params&&E){let t=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==t?void 0:t.paramSchema)&&ri(t.paramSchema)){let r="",o=[],n=t.paramSchema.shape||{};Object.keys(n).forEach(e=>{var t;let i=null==(t=A.params)?void 0:t[e];if(null!=i&&""!==i){let{actualField:A}=rl(n[e]);ra(A)?r=String(i):"distance"===e?o.push(`${i}`):o.push(String(i))}});let i=o.join(" ");e=r?`${r} - ${i}`:i}else e=A.prompt||""}else e=A.prompt||"";let t={type:A.type,prompt:e,params:A.params,timestamp:Date.now()};if(K(t),m(),h)if(w.current=t,I(""),M){let A=X();c.setFieldValue("params",A)}else c.setFieldValue("prompt","")},[c,K,m,M,u,h,E,X]),W=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&G?(H(),A.preventDefault(),A.stopPropagation()):"Enter"===A.key&&setTimeout(()=>{if(x.current){var A;let e=null==(A=x.current.resizableTextArea)?void 0:A.textArea;if(e){let A=e.selectionStart,t=e.value.lastIndexOf("\n");(-1===t||A>t)&&(e.scrollTop=e.scrollHeight)}}},0)},[H,G]),Y=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&G&&(H(),A.preventDefault(),A.stopPropagation())},[H,G]),_=(0,i.useCallback)(()=>{if(!M)return null;if(E){let A=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==A?void 0:A.paramSchema)&&ri(A.paramSchema)){let e=A.paramSchema.shape||{},t=Object.keys(e);if(1===t.length){let A=t[0],{actualField:r}=rl(e[A]),o=ra(r),i=(()=>{var e,t;if(null==(e=r._def)?void 0:e.description)return r._def.description;if(r.description)return r.description;if(E){let e=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==e?void 0:e.paramSchema)&&"object"==typeof e.paramSchema&&"shape"in e.paramSchema){let r=(e.paramSchema.shape||{})[A];if(null==r||null==(t=r._def)?void 0:t.description)return r._def.description;if(null==r?void 0:r.description)return r.description}}return o?"Describe the element you want to interact with":"keyName"===A?"Enter key name or text to type":"value"===A?"Enter text to input":`Enter ${A}`})();return(0,n.jsx)(eO.A.Item,{name:["params",A],style:{margin:0},children:(0,n.jsx)(A4.A.TextArea,{className:"main-side-console-input-textarea",rows:3,placeholder:i,autoFocus:!0,onKeyDown:Y})})}let r=[],o=t.sort((A,t)=>{let r=e[A],o=e[t],{isOptional:n}=rl(r),{isOptional:i}=rl(o);return!n&&i?-1:n&&!i?1:0});if(o.forEach((A,t)=>{var i,a,l;let{actualField:s,isOptional:c}=rl(e[A]),d=ra(s),p=A.charAt(0).toUpperCase()+A.slice(1),g=12*(t!==o.length-1),f=(()=>{var e,t;if(null==(e=s._def)?void 0:e.description)return s._def.description;if(s.description)return s.description;if(E){let e=E.find(A=>A.interfaceAlias===u||A.name===u);if((null==e?void 0:e.paramSchema)&&"object"==typeof e.paramSchema&&"shape"in e.paramSchema){let r=(e.paramSchema.shape||{})[A];if(null==r||null==(t=r._def)?void 0:t.description)return r._def.description;if(null==r?void 0:r.description)return r.description}}if(d)return"Describe the element you want to interact with"})(),m={name:A,label:p,fieldSchema:s,isRequired:!c,marginBottom:g,placeholder:f};d?r.push((0,n.jsx)(rh,rx({},m),A)):(null==(i=s._def)?void 0:i.typeName)==="ZodEnum"?r.push((0,n.jsx)(rE,rx({},m),A)):(null==(a=s._def)?void 0:a.typeName)==="ZodNumber"?r.push((0,n.jsx)(rv,rx({},m),A)):(null==(l=s._def)?void 0:l.typeName)==="ZodBoolean"?r.push((0,n.jsx)(rC,rx({},m),A)):r.push((0,n.jsx)(ry,rx({},m),A))}),"aiScroll"===u){let A=r.find(A=>i.isValidElement(A)&&"direction"===A.props.name),e=r.find(A=>i.isValidElement(A)&&"distance"===A.props.name),t=r.filter(A=>i.isValidElement(A)&&"direction"!==A.props.name&&"distance"!==A.props.name);if(A&&e)return(0,n.jsxs)("div",{className:"structured-params",children:[(0,n.jsxs)("div",{style:{display:"flex",gap:12,marginBottom:12},children:[A,e]}),t]})}return(0,n.jsx)("div",{className:"structured-params",children:r})}}return null},[u,M,E,Y]),$=(0,i.useCallback)(()=>{k(!0)},[]),AA=(0,i.useCallback)(()=>{k(!1)},[]),Ae=(0,i.useCallback)(()=>{let A=A=>(0,n.jsx)(eK.Ay,{type:"primary",icon:(0,n.jsx)(t0.A,{}),style:{borderRadius:20,zIndex:999},onClick:H,disabled:!G,loading:f,children:A});return p?"aiAct"===u?(0,n.jsx)(A6.A,{title:"Start executing until some interaction actions need to be performed. You can see the process of planning and locating.",children:A("Dry Run")}):A("Run"):g?(0,n.jsx)(eK.Ay,{icon:(0,n.jsx)(t1.A,{}),onClick:y,style:{borderRadius:20,zIndex:999},children:"Stop"}):A("Run")},[p,f,H,y,G,u,g]);return(0,n.jsxs)("div",{className:"prompt-input-wrapper",children:[(0,n.jsxs)("div",{className:"mode-radio-group-wrapper",children:[(0,n.jsxs)("div",{className:"mode-radio-group",ref:P,children:[(0,n.jsx)(eO.A.Item,{name:"type",style:{margin:0},children:(0,n.jsx)(t5.A.Group,{buttonStyle:"solid",disabled:!s,children:eZ.map(A=>{var e;return(0,n.jsx)(A6.A,{title:(null==(e=eQ[A])?void 0:e.title)||"",children:(0,n.jsx)(t5.A.Button,{value:A,children:rs(A)})},A)})})}),(0,n.jsx)(tz.A,{menu:(e=L.filter(A=>!eZ.includes(A)),t=[],(r=e.filter(A=>{var e;return(null==(e=eQ[A])?void 0:e.group)==="interaction"})).length>0&&t.push({key:"interaction-group",type:"group",label:"Interaction APIs",children:r.map(A=>{var e;return{key:A,label:rs(A),title:(null==(e=eQ[A])?void 0:e.title)||"",onClick:()=>{c.setFieldValue("type",A)}}})}),(o=e.filter(A=>{var e;return(null==(e=eQ[A])?void 0:e.group)==="extraction"})).length>0&&t.push({key:"extraction-group",type:"group",label:"Data Extraction APIs",children:o.map(A=>{var e;return{key:A,label:rs(A),title:(null==(e=eQ[A])?void 0:e.title)||"",onClick:()=>{c.setFieldValue("type",A)}}})}),(a=e.filter(A=>{var e;return(null==(e=eQ[A])?void 0:e.group)==="validation"})).length>0&&t.push({key:"validation-group",type:"group",label:"Validation APIs",children:a.map(A=>{var e;return{key:A,label:rs(A),title:(null==(e=eQ[A])?void 0:e.title)||"",onClick:()=>{c.setFieldValue("type",A)}}})}),(l=e.filter(A=>!eQ[A])).length>0&&t.push({key:"device-specific-group",type:"group",label:"Device-Specific APIs",children:l.map(A=>({key:A,label:rs(A),title:"",onClick:()=>{c.setFieldValue("type",A)}}))}),{items:t}),placement:"bottomLeft",trigger:["click"],disabled:!s,overlayClassName:"more-apis-dropdown",children:(0,n.jsxs)(eK.Ay,{className:`more-apis-button ${!eZ.includes(u)?"selected-from-dropdown":""}`,children:[u&&!eZ.includes(u)?rs(u):"more",(0,n.jsx)(t3.A,{style:{fontSize:"10px",marginLeft:"2px"}})]})})]}),(0,n.jsxs)("div",{className:"action-icons",children:[Z&&(0,n.jsx)("div",{className:b?"settings-wrapper settings-wrapper-hover":"settings-wrapper",onMouseEnter:$,onMouseLeave:AA,children:(0,n.jsx)(ru,{enableTracking:"In-Browser-Extension"===d,showDeepThinkOption:Q,showDataExtractionOptions:D,hideDomAndScreenshotOptions:v,deviceType:C})}),(0,n.jsx)(rR,{onSelect:F,history:T,currentType:u})]})]}),(0,n.jsxs)("div",{className:`main-side-console-input ${!s?"disabled":""} ${f?"loading":""}`,children:[z?M?q?_():(0,n.jsx)("div",{className:"structured-params-container",children:_()}):(0,n.jsx)(eO.A.Item,{name:"prompt",style:{margin:0},children:(0,n.jsx)(rP,{className:"main-side-console-input-textarea",disabled:!s,rows:3,placeholder:R,autoFocus:!0,onKeyDown:W,onChange:V,ref:x})}):(0,n.jsxs)("div",{className:"no-input-method",style:{padding:"20px",textAlign:"center",color:"#666",fontSize:"14px"},children:['Click "Run" to execute ',rs(u)]}),(0,n.jsx)("div",{className:"form-controller-wrapper",children:Ae()})]})]})};function rw(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function rO(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){rw(n,r,o,i,a,"next",A)}function a(A){rw(n,r,o,i,a,"throw",A)}i(void 0)})}}let{Text:rN}=A9.A;function rK(A){let{error:e}=A;if(!e)return null;let t=e.replace(/^(Error:\s*)+/,"Error: ");return(0,n.jsx)(ew.A,{message:(0,n.jsx)("span",{style:{color:"#ff4d4f"},children:t}),type:"error",showIcon:!0})}function rB(A){let{playgroundSDK:e,storage:t,contextProvider:r,config:o={},branding:a={},className:l="",dryMode:s=!1,showContextPreview:c=!0}=A,[d]=eO.A.useForm(),{config:u}=ek(),[p,g]=(0,i.useState)(!1);(0,i.useEffect)(()=>{d.setFieldsValue({type:eZ["0"]})},[d]),(0,i.useEffect)(()=>{rO(function*(){if(e&&"function"==typeof e.checkStatus)try{yield e.checkStatus(),g(!0)}catch(A){console.warn("Failed to initialize SDK, using default namespace:",A),g(!0)}else g(!0)})()},[e]);let f=(0,i.useMemo)(()=>{if(t)return t;if(!p)return null;let A=o.storageNamespace||(e&&e.id&&"string"==typeof e.id?`agent-${e.id}`:"playground-default"),r=tl();return console.log(`Using ${r} storage for namespace: ${A}`),ta(r,A)},[t,p,o.storageNamespace,e]),{loading:m,setLoading:y,infoList:h,setInfoList:E,actionSpace:v,actionSpaceLoading:C,uiContextPreview:b,setUiContextPreview:k,showScrollToBottomButton:S,verticalMode:I,replayCounter:R,setReplayCounter:x,infoListRef:P,currentRunningIdRef:j,interruptedFlagRef:w,clearInfoList:O,handleScrollToBottom:N}=function(A,e,t){let[r,o]=(0,i.useState)(!1),[n,a]=(0,i.useState)([]),[l,s]=(0,i.useState)([]),[c,d]=(0,i.useState)(!0),[u,p]=(0,i.useState)(),[g,f]=(0,i.useState)(!1),[m,y]=(0,i.useState)(!1),[h,E]=(0,i.useState)(0),v=(0,i.useRef)(null),C=(0,i.useRef)(null),b=(0,i.useRef)({}),k=(0,i.useRef)(!1);(0,i.useEffect)(()=>{let A=()=>tc(function*(){let A=tu(td({},eL),{id:"welcome",timestamp:new Date});if(null==e?void 0:e.loadMessages)try{let t=yield e.loadMessages();0===t.length&&(t=yield tc(function*(){let A=ta(tl(),"playground-default");try{if(null==A?void 0:A.loadMessages){let t=yield A.loadMessages();if(t.length>1)return console.log("Found data in old namespace, migrating..."),(null==e?void 0:e.saveMessages)&&(yield e.saveMessages(t)),A.clearMessages&&(yield A.clearMessages()),t}}catch(A){console.debug("No data found in old namespace:",A)}return[]})()),t.some(A=>"welcome"===A.id)?a(t):a([A,...t])}catch(e){console.error("Failed to load messages:",e),a([A])}else a([A])})();e&&!k.current?(k.current=!0,A()):e||0!==n.length||A()},[e]),(0,i.useEffect)(()=>{(null==e?void 0:e.saveMessages)&&n.length>1&&e.saveMessages(n).catch(A=>{A instanceof DOMException&&"QuotaExceededError"===A.name?console.warn("Storage quota exceeded - some messages may not be saved persistently"):console.error("Failed to save messages:",A)})},[n,e]),(0,i.useEffect)(()=>{(null==t?void 0:t.getUIContext)&&!u&&t.getUIContext().then(A=>p(A)).catch(A=>{console.error("Failed to get UI context:",A)})},[t,u]),(0,i.useEffect)(()=>{tc(function*(){d(!0);try{var e;if(!A)return void s([]);let r=u||(yield null==t||null==(e=t.getUIContext)?void 0:e.call(t)),o=yield A.getActionSpace(r);s(o||[])}catch(A){console.error("Failed to load action space:",A),s([])}finally{d(!1)}})()},[A,u,t]),(0,i.useEffect)(()=>{y(window.innerWidth<750);let A=()=>{y(window.innerWidth<750)};return window.addEventListener("resize",A),()=>window.removeEventListener("resize",A)},[]);let S=(0,i.useCallback)(()=>{setTimeout(()=>{v.current&&(v.current.scrollTop=v.current.scrollHeight)},100)},[]),I=(0,i.useCallback)(()=>{if(v.current){let{scrollTop:A,scrollHeight:e,clientHeight:t}=v.current;f(!(A+t>=e-10))}},[]),R=(0,i.useCallback)(()=>{v.current&&(v.current.scrollTo({top:v.current.scrollHeight,behavior:"smooth"}),f(!1))},[]);(0,i.useEffect)(()=>{n.length>0&&S()},[n,S]),(0,i.useEffect)(()=>{let A=v.current;if(A)return A.addEventListener("scroll",I),I(),()=>{A.removeEventListener("scroll",I)}},[I]);let x=(0,i.useCallback)(()=>tc(function*(){if(a([tu(td({},eL),{id:"welcome",timestamp:new Date})]),null==e?void 0:e.clearMessages)try{yield e.clearMessages()}catch(A){console.error("Failed to clear stored messages:",A)}})(),[e]),P=(0,i.useCallback)(()=>tc(function*(){if(null==t?void 0:t.refreshContext)try{let A=yield t.refreshContext();p(A)}catch(A){console.error("Failed to refresh context:",A)}})(),[t]);return{loading:r,setLoading:o,infoList:n,setInfoList:a,actionSpace:l,actionSpaceLoading:c,uiContextPreview:u,setUiContextPreview:p,showScrollToBottomButton:g,verticalMode:m,replayCounter:h,setReplayCounter:E,infoListRef:v,currentRunningIdRef:C,interruptedFlagRef:b,clearInfoList:x,refreshContext:P,handleScrollToBottom:R,scrollToBottom:S}}(e,f,r),{handleRun:K,handleStop:B,canStop:T}=function(A,e,t,r,o,n,a,l,s,c,d){let{deepThink:u,screenshotIncluded:p,domIncluded:g}=ek(),f=(0,i.useCallback)(t=>eq(function*(){if(!A)return void console.warn("PlaygroundSDK is not available");let r=Date.now(),i=t.type,f=`${t.type}: ${t.prompt||JSON.stringify(t.params)}`,m={id:`user-${Date.now()}`,type:"user",content:f,timestamp:new Date};n(A=>[...A,m]),o(!0);let y=eG({},eX),h={id:`system-${r}`,type:"system",content:"",timestamp:new Date,loading:!0,loadingProgressText:""};n(A=>[...A,h]);try{if(c.current=r,d.current[r]=!1,A.onDumpUpdate&&A.onDumpUpdate((A,e)=>{var t;if(d.current[r]||!(null==e||null==(t=e.tasks)?void 0:t.length))return;let o=e.tasks.map((A,e)=>{var t;let o,n;return{id:`progress-${r}-task-${e}`,type:"progress",content:(o=eT(A),(n=ez(A))?`${o} - ${n}`:o),timestamp:new Date((null==(t=A.timing)?void 0:t.start)||Date.now()),result:A.error?{error:eW(A.error),result:null}:void 0}});n(A=>{let e=A.findIndex(A=>A.id===`system-${r}`);if(-1===e)return A;let t=A.filter(A=>!("progress"===A.type&&A.id.startsWith(`progress-${r}-`)));return[...t.slice(0,e+1),...o,...t.slice(e+1)]})}),y.result=yield A.executeAction(i,t,{requestId:r.toString(),deepThink:u,screenshotIncluded:p,domIncluded:g}),"object"==typeof y.result&&null!==y.result){let A=y.result;A.dump&&(y.dump=A.dump),A.reportHTML&&(y.reportHTML=A.reportHTML),A.error&&(y.error=eW(A.error)),void 0!==A.result&&(y.result=A.result)}}catch(A){y.error=eW(A),console.error("Playground execution error:",A),"object"==typeof A&&null!==A&&(A.dump&&(y.dump=A.dump),A.reportHTML&&(y.reportHTML=A.reportHTML))}if(d.current[r])return;o(!1),c.current=null;let E=null,v=a;if((null==y?void 0:y.dump)&&y.dump.tasks&&Array.isArray(y.dump.tasks)){var C;let A,e=(A=>{var e,t,r;let o,n;if(!A)return console.warn("[allScriptsFromDump] dump is empty"),{scripts:[],modelBriefs:[]};let i=Array.isArray(A.executions)?A:{sdkVersion:"",groupName:"Execution",modelBriefs:[],executions:[A]},a=new Set,l=i.sdkVersion,s=new Set;if(null==(e=i.executions)||e.filter(Boolean).forEach(A=>{A.tasks.forEach(A=>{var e,t;if(null==(t=A.uiContext)||null==(e=t.size)?void 0:e.width){let e=A.uiContext.size.width,t=A.uiContext.size.height;o||(o=e,n=t),a.add(`${e}x${t}`)}})}),!o||!n)return console.warn("width or height is missing in dump file"),{scripts:[],sdkVersion:l,modelBriefs:[]};let c=[];null==(t=i.executions)||t.filter(Boolean).forEach(A=>{let e=((A,e,t,r)=>{let o;if(!A||!A.tasks.length||0===t||0===r)return null;let n=[];if(-1===e)n=A.tasks;else{let t=A.tasks.findIndex(A=>A===e);if(-1===t)return console.error("task not found, cannot generate animation scripts"),null;if(t===A.tasks.length-1)return null;for(let e=t;e<A.tasks.length&&(!(e>t)||"Planning"!==A.tasks[e].type);e++)n.push(A.tasks[e])}if(0===n.length)return null;let i=eF({left:0,top:0,width:t,height:r},t,r),a=[],l=!1;n.length;let s="",c=!1;return n.forEach((A,e)=>{var n,d,u,p,g,f,m,y,h,E,v,C,b,k,S,I,R,x,P,j,w,O,N,K,B,T;if(!c){if(0===e&&(s=ez(A)),"Planning"===A.type){let e=[];if("Plan"===A.subType){let t=(null==(d=A.output)?void 0:d.actions)||[];if(t.length>0){let A=t[0],r=["locate","start","end"];if(A.param)for(let t in r.forEach(t=>{A.param[t]&&"object"==typeof A.param[t]&&"center"in(A.param[t]||{})&&e.push(A.param[t])}),A.param)!r.includes(t)&&"object"==typeof A.param[t]&&"center"in(A.param[t]||{})&&e.push(A.param[t])}}else"Locate"===A.subType&&(null==(n=A.output)?void 0:n.element)&&(e=[A.output.element]);let i=eT(A),s=ez(A),c=A.uiContext;if(null==c?void 0:c.screenshotBase64){let n=(null==(u=c.size)?void 0:u.width)||t,d=(null==(p=c.size)?void 0:p.height)||r;a.push({type:"img",img:c.screenshotBase64,duration:300,title:i,subTitle:s,imageWidth:n,imageHeight:d}),e.forEach(e=>{var u,p,g,f,m,y;m=function(A){for(var e=1;e<arguments.length;e++){var t=null!=arguments[e]?arguments[e]:{},r=Object.keys(t);"function"==typeof Object.getOwnPropertySymbols&&(r=r.concat(Object.getOwnPropertySymbols(t).filter(function(A){return Object.getOwnPropertyDescriptor(t,A).enumerable}))),r.forEach(function(e){var r;r=t[e],e in A?Object.defineProperty(A,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):A[e]=r})}return A}({},eF(e.rect,n,d)),y=y={pointerLeft:e.center[0],pointerTop:e.center[1]},Object.getOwnPropertyDescriptors?Object.defineProperties(m,Object.getOwnPropertyDescriptors(y)):(function(A,e){var t=Object.keys(A);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(A);t.push.apply(t,r)}return t})(Object(y)).forEach(function(A){Object.defineProperty(m,A,Object.getOwnPropertyDescriptor(y,A))}),o=m,a.push({type:"insight",img:c.screenshotBase64,context:c,camera:o,highlightElement:e,searchArea:null==(p=A.log)||null==(u=p.taskInfo)?void 0:u.searchArea,duration:400,insightCameraDuration:800,title:i,subTitle:e.description||s,imageWidth:(null==(g=c.size)?void 0:g.width)||t,imageHeight:(null==(f=c.size)?void 0:f.height)||r}),l=!0})}A.recorder&&A.recorder.length>0&&a.push({type:"img",img:null==(f=A.recorder)||null==(g=f[0])?void 0:g.screenshot,duration:900,title:eT(A),subTitle:ez(A),imageWidth:(null==(y=A.uiContext)||null==(m=y.size)?void 0:m.width)||t,imageHeight:(null==(E=A.uiContext)||null==(h=E.size)?void 0:h.height)||r})}else if("Action Space"===A.type){let e=eT(A),o=ez(A);a.push({type:"spinning-pointer",duration:300,title:e,subTitle:o}),l&&(a.push({type:"clear-insight",duration:200,title:e,subTitle:o}),l=!1),a.push({type:"pointer",img:eJ,duration:0,title:e,subTitle:o}),a.push({type:"img",img:null==(C=A.recorder)||null==(v=C[0])?void 0:v.screenshot,duration:500,camera:"Sleep"===A.subType?i:void 0,title:e,subTitle:o,imageWidth:(null==(k=A.uiContext)||null==(b=k.size)?void 0:b.width)||t,imageHeight:(null==(I=A.uiContext)||null==(S=I.size)?void 0:S.height)||r})}else{let e=eT(A),o=ez(A),n=null==(x=A.recorder)||null==(R=x[A.recorder.length-1])?void 0:R.screenshot;n&&a.push({type:"img",img:n,duration:900,camera:i,title:e,subTitle:o,imageWidth:(null==(j=A.uiContext)||null==(P=j.size)?void 0:P.width)||t,imageHeight:(null==(O=A.uiContext)||null==(w=O.size)?void 0:w.height)||r})}if("finished"!==A.status){c=!0;let e=eT(A),o=A.errorMessage||"unknown error",n=o.indexOf("NOT_IMPLEMENTED_AS_DESIGNED")>0?"Further actions cannot be performed in the current environment":o;a.push({type:"img",img:A.recorder&&A.recorder.length>0?A.recorder[A.recorder.length-1].screenshot:"",camera:i,duration:900,title:e,subTitle:n,imageWidth:(null==(K=A.uiContext)||null==(N=K.size)?void 0:N.width)||t,imageHeight:(null==(T=A.uiContext)||null==(B=T.size)?void 0:B.height)||r});return}}}),c||a.push({title:"Done",subTitle:s,type:"img",duration:200,camera:i}),a})(A,-1,o,n);e&&c.push(...e),A.tasks.forEach(A=>{if(A.usage){let{model_name:e,model_description:t,intent:r}=A.usage;r&&e&&s.add(t?`${r}/${e}(${t})`:`${r}/${e}`)}})});let d=c.filter((A,e)=>e===c.length-1||"Done"!==A.title),u=(null==(r=i.modelBriefs)?void 0:r.length)?i.modelBriefs:[],p=(()=>{var A;let e=u.length?u:[...s];if(!e.length)return e;let t=null==(A=e[0])?void 0:A.split("/",2)[1];return t&&e.slice(1).every(A=>(null==A?void 0:A.split("/",2)[1])===t)?[t]:e})();return{scripts:d,width:o,height:n,sdkVersion:l,modelBriefs:p}})((C=y.dump,A=new Set,(null==C?void 0:C.tasks)&&Array.isArray(C.tasks)?C.tasks.forEach(e=>{if(e.usage){let{model_name:t,model_description:r,intent:o}=e.usage;o&&t&&A.add(r?`${o}/${t}(${r})`:`${o}/${t}`)}}):console.warn("[wrapExecutionDumpForReplay] Invalid dump structure:",C),{sdkVersion:"",groupName:"Playground Execution",modelBriefs:[...A],executions:[C]}));l(A=>A+1),E=e,v=a+1}n(A=>A.map(A=>A.id===`system-${r}`?eH(eG({},A),{content:"",loading:!1,loadingProgressText:""}):A));let b={id:`result-${r}`,type:"result",content:"Execution result",timestamp:new Date,result:y,loading:!1,replayScriptsInfo:E,replayCounter:v,loadingProgressText:"",verticalMode:s,actionType:i};if(n(A=>[...A,b]),null==e?void 0:e.saveResult)try{yield e.saveResult(b.id,b)}catch(A){console.error("Failed to save result:",A)}let k={id:`separator-${r}`,type:"separator",content:"New Session",timestamp:new Date};n(A=>[...A,k])})(),[A,e,t,o,n,a,l,s,c,d,u,p,g]),m=(0,i.useCallback)(()=>eq(function*(){let e=c.current;if(e&&A&&A.cancelExecution)try{let t=yield A.cancelExecution(e.toString()),r=null;if(t)r=t;else if(A.getCurrentExecutionData)try{r=yield A.getCurrentExecutionData()}catch(A){console.error("Failed to get execution data before stop:",A)}if(d.current[e]=!0,o(!1),A.onProgressUpdate&&A.onProgressUpdate(()=>{}),A.onDumpUpdate&&A.onDumpUpdate(()=>{}),n(A=>A.map(A=>A.id===`system-${e}`?eH(eG({},A),{content:"",loading:!1,loadingProgressText:""}):A)),r&&(r.dump||r.reportHTML)){let A={id:`stop-result-${e}`,type:"result",content:"Execution stopped by user",timestamp:new Date,result:{result:null,dump:r.dump,reportHTML:r.reportHTML,error:null},loading:!1,verticalMode:s,replayCounter:a};n(e=>[...e,A])}else{let A={id:`stop-${e}`,type:"system",content:"Operation stopped",timestamp:new Date,loading:!1};n(e=>[...e,A])}let i={id:`separator-${e}`,type:"separator",content:"New Session",timestamp:new Date};n(A=>[...A,i])}catch(A){console.error("Failed to stop execution:",A)}})(),[A,c,d,o,n,s,a]);return{handleRun:f,handleStop:m,canStop:r&&!!c.current&&!!A&&!!A.cancelExecution}}(e,f,v,m,y,E,R,x,I,j,w);(0,i.useEffect)(()=>{(null==e?void 0:e.overrideConfig)&&u&&e.overrideConfig(u).catch(A=>{console.error("Failed to override SDK config:",A)})},[e,u]);let M=(0,i.useCallback)(()=>rO(function*(){try{let A=d.getFieldsValue();yield K(A)}catch(A){eN.Ay.error((null==A?void 0:A.message)||"Execution failed")}})(),[d,K]),z=Object.keys(u||{}).length>=1,D=o.serverMode||!s&&!C&&z,Q=eO.A.useWatch("type",d),Z=(0,i.useMemo)(()=>e&&"function"==typeof e.getServiceMode?e.getServiceMode():"Server",[e]),L=c&&!1!==o.showContextPreview,X=o.layout||"vertical",J=!1!==o.showVersionInfo,U=o.deviceType;return(0,n.jsx)("div",{className:`playground-container ${X}-mode ${l}`.trim(),children:(0,n.jsxs)(eO.A,{form:d,onFinish:M,className:"command-form",children:[L&&(0,n.jsx)("div",{className:"context-preview-section",children:(0,n.jsx)(tw,{uiContextPreview:b,setUiContextPreview:k,showContextPreview:L})}),(0,n.jsxs)("div",{className:"middle-dialog-area",children:[h.length>1&&(0,n.jsx)("div",{className:"clear-button-container",children:(0,n.jsx)(eK.Ay,{size:"small",icon:(0,n.jsx)(eR.A,{}),onClick:O,type:"text",className:"clear-button"})}),(0,n.jsx)("div",{ref:P,className:"info-list-container",children:(0,n.jsx)(eB.A,{itemLayout:"vertical",dataSource:h,renderItem:A=>{var e,t,r,o;let i,l,s,c,d,u;return(0,n.jsx)(eB.A.Item,{className:"list-item",children:"user"===A.type?(0,n.jsx)("div",{className:"user-message-container",children:(0,n.jsx)("div",{className:"user-message-bubble",children:A.content})}):"progress"===A.type?(0,n.jsx)("div",{children:(l=null==(e=(i=A.content.split(" - "))[0])?void 0:e.trim(),s=i.slice(1).join(" - ").trim(),c=h.findIndex(e=>e.id===A.id),d=h.slice(c+1).some(A=>"progress"===A.type),u=m&&!d,(0,n.jsxs)(n.Fragment,{children:[l&&(0,n.jsxs)("span",{className:"progress-action-item",children:[l,(0,n.jsx)("span",{className:`progress-status-icon ${u?"loading":(null==(t=A.result)?void 0:t.error)?"error":"completed"}`,children:u?(0,n.jsx)(ex.A,{spin:!0}):(null==(r=A.result)?void 0:r.error)?"✗":"✓"})]}),s&&(0,n.jsx)("div",{children:(0,n.jsx)(tI,{text:s,className:"progress-description",disabled:!u})}),(null==(o=A.result)?void 0:o.error)&&(0,n.jsx)(rK,{error:A.result.error})]}))}):"separator"===A.type?(0,n.jsxs)("div",{className:"new-conversation-separator",children:[(0,n.jsx)("div",{className:"separator-line"}),(0,n.jsx)("div",{className:"separator-text-container",children:(0,n.jsx)(rN,{type:"secondary",className:"separator-text",children:A.content})})]}):(0,n.jsxs)("div",{className:"system-message-container",children:[(0,n.jsxs)("div",{className:"system-message-header",children:[(0,n.jsx)(eP.A,{component:a.icon||t$,style:{fontSize:20}}),(0,n.jsx)("span",{className:"system-message-title",children:a.title||"Playground"})]}),(A.content||A.result)&&(0,n.jsx)("div",{className:"system-message-content",children:"result"===A.type?(0,n.jsx)(t_,{result:A.result||null,loading:A.loading||!1,serverValid:!0,serviceMode:Z,replayScriptsInfo:A.replayScriptsInfo||null,replayCounter:A.replayCounter||0,loadingProgressText:A.loadingProgressText||"",verticalMode:A.verticalMode||!1,fitMode:"width",actionType:A.actionType}):(0,n.jsxs)(n.Fragment,{children:[(0,n.jsx)("div",{className:"system-message-text",children:A.content}),A.loading&&A.loadingProgressText&&(0,n.jsx)("div",{className:"loading-progress-text",children:(0,n.jsx)("span",{children:A.loadingProgressText})})]})})]})},A.id)}})}),S&&!1!==o.enableScrollToBottom&&(0,n.jsx)(eK.Ay,{className:"scroll-to-bottom-button",type:"primary",shape:"circle",icon:(0,n.jsx)(ej.A,{}),onClick:N,size:"large"})]}),(0,n.jsxs)("div",{className:"bottom-input-section",children:[o.showEnvConfigReminder?(0,n.jsx)(tN,{}):null,(0,n.jsx)(rj,{runButtonEnabled:D,form:d,serviceMode:Z,selectedType:Q,dryMode:s,stoppable:T,loading:m,onRun:M,onStop:B,actionSpace:v,deviceType:U})]}),J&&a.version&&(0,n.jsx)("div",{className:"version-info-section",children:(0,n.jsxs)("span",{className:"version-text",children:["Midscene.js version: ",a.version]})})]})})}var rT=t(1352),rM=t(955);function rz(A,e,t,r,o,n,i){try{var a=A[n](i),l=a.value}catch(A){t(A);return}a.done?e(l):Promise.resolve(l).then(r,o)}function rD(A){return function(){var e=this,t=arguments;return new Promise(function(r,o){var n=A.apply(e,t);function i(A){rz(n,r,o,i,a,"next",A)}function a(A){rz(n,r,o,i,a,"throw",A)}i(void 0)})}}function rQ(A){let{getScreenshot:e,getInterfaceInfo:t,serverOnline:r,isUserOperating:o=!1}=A,[a,l]=(0,i.useState)(null),[s,c]=(0,i.useState)(!1),[d,u]=(0,i.useState)(null),[p,g]=(0,i.useState)(0),[f,m]=(0,i.useState)(null),y=(0,i.useRef)(null),h=(0,i.useRef)(!1),E=(0,i.useCallback)(function(){let A=arguments.length>0&&void 0!==arguments[0]&&arguments[0];return rD(function*(){if(r){c(!0),A&&u(null);try{let A=yield e();if(console.log("Screenshot API response:",A),null==A?void 0:A.screenshot){let e=A.screenshot.toString().trim();e?(l(e),u(null),g(Date.now())):u("Empty screenshot data received")}else u("No screenshot data in response")}catch(A){console.error("Screenshot fetch error:",A),u(A instanceof Error?A.message:"Failed to fetch screenshot")}finally{c(!1)}}})()},[e,r]),v=(0,i.useCallback)(()=>rD(function*(){if(r&&t)try{let A=yield t();A&&m(A)}catch(A){console.error("Interface info fetch error:",A)}})(),[t,r]),C=(0,i.useCallback)(()=>{y.current&&clearInterval(y.current),console.log("Starting screenshot polling (5s interval)"),y.current=setInterval(()=>{!h.current&&r&&E(!1)},5e3)},[E,r]),b=(0,i.useCallback)(()=>{y.current&&(console.log("Stopping screenshot polling"),clearInterval(y.current),y.current=null)},[]),k=(0,i.useCallback)(()=>{console.log("Pausing screenshot polling"),h.current=!0},[]),S=(0,i.useCallback)(()=>{console.log("Resuming screenshot polling"),h.current=!1},[]),I=(0,i.useCallback)(()=>{E(!0)},[E]);return((0,i.useEffect)(()=>{if(!r){l(null),u(null),m(null),b();return}return E(!1),v(),C(),()=>{b()}},[r,C,b,E,v]),(0,i.useEffect)(()=>{r&&(o?k():(S(),E(!1)))},[o,k,S,E,r]),(0,i.useEffect)(()=>()=>{b()},[b]),r)?s&&!a?(0,n.jsxs)("div",{className:"screenshot-viewer loading",children:[(0,n.jsx)(tK.A,{size:"large"}),(0,n.jsx)("p",{children:"Loading screenshot..."})]}):d&&!a?(0,n.jsx)("div",{className:"screenshot-viewer error",children:(0,n.jsxs)("div",{className:"screenshot-placeholder",children:[(0,n.jsx)("h3",{children:"\uD83D\uDCF1 Screen Preview"}),(0,n.jsx)("p",{className:"error-message",children:d})]})}):(0,n.jsxs)("div",{className:"screenshot-viewer",children:[(0,n.jsx)("div",{className:"screenshot-header",children:(0,n.jsx)("div",{className:"screenshot-title",children:(0,n.jsx)("h3",{children:(null==f?void 0:f.type)?f.type:"Device Name"})})}),(0,n.jsxs)("div",{className:"screenshot-container",children:[(0,n.jsxs)("div",{className:"screenshot-overlay",children:[(0,n.jsxs)("div",{className:"device-name-overlay",children:["Device Name",(0,n.jsx)(A6.A,{title:null==f?void 0:f.description,children:(0,n.jsx)(rT.A,{size:16,className:"info-icon"})})]}),(0,n.jsxs)("div",{className:"screenshot-controls",children:[p>0&&(0,n.jsxs)("span",{className:"last-update-time",children:["Last updated ",(A=>{if(!A)return"";let e=Math.floor((Date.now()-A)/1e3);return e<60?`${e}s ago`:e<3600?`${Math.floor(e/60)}m ago`:new Date(A).toLocaleTimeString()})(p)]}),(0,n.jsx)(A6.A,{title:"Refresh screenshot",children:(0,n.jsx)(eK.Ay,{icon:(0,n.jsx)(rM.A,{}),onClick:I,loading:s,size:"small"})}),o&&(0,n.jsxs)("span",{className:"operation-indicator",children:[(0,n.jsx)(tK.A,{size:"small"})," Operating..."]})]})]}),(0,n.jsx)("div",{className:"screenshot-content",children:a?(0,n.jsx)("img",{src:a.startsWith("data:image/")?a:`data:image/png;base64,${a}`,alt:"Device Screenshot",className:"screenshot-image",onLoad:()=>console.log("Screenshot image loaded successfully"),onError:A=>{console.error("Screenshot image load error:",A),console.error("Screenshot data preview:",a.substring(0,100)),u("Failed to load screenshot image")}}):(0,n.jsx)("div",{className:"screenshot-placeholder",children:(0,n.jsx)("p",{children:"No screenshot available"})})})]})]}):(0,n.jsx)("div",{className:"screenshot-viewer offline",children:(0,n.jsxs)("div",{className:"screenshot-placeholder",children:[(0,n.jsx)("h3",{children:"\uD83D\uDCF1 Screen Preview"}),(0,n.jsx)("p",{children:"Start the playground server to see real-time screenshots"})]})})}var rZ=t(6453),rL=t(2770),rX=t(4458);let rJ=t.p+"static/svg/server-offline-foreground.6e892230.svg",{Content:rU}=rZ.A,rF=document.getElementById("root");if(!rF)throw Error("Root element not found");(0,a.createRoot)(rF).render((0,n.jsx)(i.StrictMode,{children:(0,n.jsx)(function(){let[A,e]=(0,i.useState)(!1),[t,r]=(0,i.useState)(!1),[o,a]=(0,i.useState)(!1),[l,s]=(0,i.useState)("web"),c=(0,i.useMemo)(()=>{let A=new A_({type:"remote-execution",serverUrl:""});return console.log("\uD83C\uDF10 Connecting to playground server:",""),A.onProgressUpdate(A=>{r(!!A)}),A},[]);return((0,i.useEffect)(()=>{let A=async()=>{try{let A=await c.checkStatus();if(e(A),A)try{let A=await c.getInterfaceInfo();if(null==A?void 0:A.type){let e=A.type.toLowerCase();("android"===e||"ios"===e||"web"===e)&&s(e)}}catch(A){console.warn("Failed to get interface info:",A)}}catch(A){console.error("Failed to check server status:",A),e(!1)}};A();let t=setInterval(A,5e3);return()=>clearInterval(t)},[c]),(0,i.useEffect)(()=>{let A=()=>{a(window.innerWidth<=1024)};return A(),window.addEventListener("resize",A),()=>window.removeEventListener("resize",A)},[]),A)?(0,n.jsx)(rL.Ay,{theme:A1(),children:(0,n.jsx)(rZ.A,{className:"app-container playground-container",children:(0,n.jsx)(rU,{className:"app-content",children:(0,n.jsxs)(rX.YZ,{autoSaveId:"playground-layout",direction:o?"vertical":"horizontal",children:[(0,n.jsx)(rX.Zk,{defaultSize:o?67:32,maxSize:o?85:60,minSize:o?67:25,className:"app-panel left-panel",children:(0,n.jsxs)("div",{className:"panel-content left-panel-content",children:[(0,n.jsx)("div",{className:"playground-panel-header",children:(0,n.jsxs)("div",{className:"header-row",children:[(0,n.jsx)(A3,{}),(0,n.jsx)(eI,{showTooltipWhenEmpty:!1,showModelName:!1})]})}),(0,n.jsx)("div",{className:"playground-panel-playground",children:(0,n.jsx)(rB,{playgroundSDK:c,config:{showContextPreview:!1,layout:"vertical",showVersionInfo:!0,enableScrollToBottom:!0,serverMode:!0,showEnvConfigReminder:!0,deviceType:l},branding:{title:"Playground",version:"1.0.4-beta-20251223105123.0"},className:"playground-container"})})]})}),(0,n.jsx)(rX.TW,{className:`panel-resize-handle ${o?"vertical":"horizontal"}`}),(0,n.jsx)(rX.Zk,{className:"app-panel right-panel",children:(0,n.jsx)("div",{className:"panel-content right-panel-content",children:(0,n.jsx)(rQ,{getScreenshot:()=>c.getScreenshot(),getInterfaceInfo:()=>c.getInterfaceInfo(),serverOnline:A,isUserOperating:t})})})]})})})}):(0,n.jsx)(rL.Ay,{theme:A1(),children:(0,n.jsx)("div",{className:"server-offline-container",children:(0,n.jsxs)("div",{className:"server-offline-message",children:[(0,n.jsx)(A3,{}),(0,n.jsxs)("div",{className:"server-offline-content",children:[(0,n.jsxs)("div",{className:"server-offline-icon",children:[(0,n.jsx)("img",{src:"",className:"icon-background",alt:""}),(0,n.jsx)("img",{src:rJ,className:"icon-foreground",alt:""})]}),(0,n.jsx)("h1",{children:"Midscene Playground"}),(0,n.jsx)("p",{className:"connection-status",children:"Server offline..."})]})]})})})},{})}))},4678(A){"use strict";if("undefined"==typeof sharp){var e=Error("Cannot find module 'sharp'");throw e.code="MODULE_NOT_FOUND",e}A.exports=sharp},6122(){},7407(){},9140(){},3009(){},6970(){},3612(){},3244(){},5592(){}},l={};function s(A){var e=l[A];if(void 0!==e)return e.exports;var t=l[A]={exports:{}};return a[A].call(t.exports,t,t.exports,s),t.exports}s.m=a,s.n=A=>{var e=A&&A.__esModule?()=>A.default:()=>A;return s.d(e,{a:e}),e},e=Object.getPrototypeOf?A=>Object.getPrototypeOf(A):A=>A.__proto__,s.t=function(t,r){if(1&r&&(t=this(t)),8&r||"object"==typeof t&&t&&(4&r&&t.__esModule||16&r&&"function"==typeof t.then))return t;var o=Object.create(null);s.r(o);var n={};A=A||[null,e({}),e([]),e(e)];for(var i=2&r&&t;("object"==typeof i||"function"==typeof i)&&!~A.indexOf(i);i=e(i))Object.getOwnPropertyNames(i).forEach(A=>{n[A]=()=>t[A]});return n.default=()=>t,s.d(o,n),o},s.d=(A,e)=>{for(var t in e)s.o(e,t)&&!s.o(A,t)&&Object.defineProperty(A,t,{enumerable:!0,get:e[t]})},s.f={},s.e=A=>Promise.all(Object.keys(s.f).reduce((e,t)=>(s.f[t](A,e),e),[])),s.u=A=>"static/js/async/"+A+"."+({195:"0366f6e8",199:"f31e52e7",221:"591b048e",271:"15d46ff8",35:"2b64fb0f",467:"710fa05a",652:"b5a7c7b4",856:"be9fd814",860:"b56301d9",990:"82a78a53"})[A]+".js",s.miniCssF=A=>""+A+".css",s.g=(()=>{if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(A){if("object"==typeof window)return window}})(),s.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),t={},s.l=function(A,e,r,o){if(t[A])return void t[A].push(e);if(void 0!==r)for(var n,i,a=document.getElementsByTagName("script"),l=0;l<a.length;l++){var c=a[l];if(c.getAttribute("src")==A||c.getAttribute("data-rspack")=="playground:"+r){n=c;break}}n||(i=!0,(n=document.createElement("script")).timeout=120,s.nc&&n.setAttribute("nonce",s.nc),n.setAttribute("data-rspack","playground:"+r),n.src=A),t[A]=[e];var d=function(e,r){n.onerror=n.onload=null,clearTimeout(u);var o=t[A];if(delete t[A],n.parentNode&&n.parentNode.removeChild(n),o&&o.forEach(function(A){return A(r)}),e)return e(r)},u=setTimeout(d.bind(null,void 0,{type:"timeout",target:n}),12e4);n.onerror=d.bind(null,n.onerror),n.onload=d.bind(null,n.onload),i&&document.head.appendChild(n)},s.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})},r=[],s.O=(A,e,t,o)=>{if(e){o=o||0;for(var n=r.length;n>0&&r[n-1][2]>o;n--)r[n]=r[n-1];r[n]=[e,t,o];return}for(var i=1/0,n=0;n<r.length;n++){for(var[e,t,o]=r[n],a=!0,l=0;l<e.length;l++)(!1&o||i>=o)&&Object.keys(s.O).every(A=>s.O[A](e[l]))?e.splice(l--,1):(a=!1,o<i&&(i=o));if(a){r.splice(n--,1);var c=t();void 0!==c&&(A=c)}}return A},s.p="/",s.b=document.baseURI||self.location.href,o={410:0},s.f.j=function(A,e){var t=s.o(o,A)?o[A]:void 0;if(0!==t)if(t)e.push(t[2]);else{var r=new Promise((e,r)=>t=o[A]=[e,r]);e.push(t[2]=r);var n=s.p+s.u(A),i=Error();s.l(n,function(e){if(s.o(o,A)&&(0!==(t=o[A])&&(o[A]=void 0),t)){var r=e&&("load"===e.type?"missing":e.type),n=e&&e.target&&e.target.src;i.message="Loading chunk "+A+" failed.\n("+r+": "+n+")",i.name="ChunkLoadError",i.type=r,i.request=n,t[1](i)}},"chunk-"+A,A)}},s.O.j=A=>0===o[A],n=(A,e)=>{var t,r,[n,i,a]=e,l=0;if(n.some(A=>0!==o[A])){for(t in i)s.o(i,t)&&(s.m[t]=i[t]);if(a)var c=a(s)}for(A&&A(e);l<n.length;l++)r=n[l],s.o(o,r)&&o[r]&&o[r][0](),o[r]=0;return s.O(c)},(i=self.webpackChunkplayground=self.webpackChunkplayground||[]).forEach(n.bind(null,0)),i.push=n.bind(null,i.push.bind(i));var c=s.O(void 0,["783","430"],()=>s(7517));c=s.O(c)})();
|
|
10
|
+
//# sourceMappingURL=index.fb126448.js.map
|