@midscene/ios 0.30.7 → 0.30.8
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 +5 -5
- package/static/index.html +1 -1
- package/static/static/js/{index.540028a2.js → index.81b3ced1.js} +3 -3
- package/static/static/js/index.81b3ced1.js.map +1 -0
- package/static/static/js/index.540028a2.js.map +0 -1
- /package/static/static/js/{index.540028a2.js.LICENSE.txt → index.81b3ced1.js.LICENSE.txt} +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/*! For license information please see index.
|
|
1
|
+
/*! For license information please see index.81b3ced1.js.LICENSE.txt */
|
|
2
2
|
(()=>{"use strict";var A={69921:function(A,e,t){var r,o,n=t(31549),i=t(44194),a=t(8082);t(21437),t(93096),t(11260);let s="MIDSCENE_OPENAI_INIT_CONFIG_JSON",l="MIDSCENE_MODEL_NAME",d="MIDSCENE_DEBUG_AI_PROFILE",c="MIDSCENE_DEBUG_AI_RESPONSE",u="MIDSCENE_OPENAI_SOCKS_PROXY",g="MIDSCENE_OPENAI_HTTP_PROXY",p="OPENAI_API_KEY",m="OPENAI_BASE_URL",E="MIDSCENE_USE_VLM_UI_TARS",f="MIDSCENE_USE_QWEN_VL",h="MIDSCENE_USE_QWEN3_VL",y="MIDSCENE_USE_DOUBAO_VISION",v="MIDSCENE_USE_GEMINI",C="MATCH_BY_POSITION",k="MIDSCENE_USE_AZURE_OPENAI",I="MIDSCENE_AZURE_OPENAI_SCOPE",S="MIDSCENE_AZURE_OPENAI_INIT_CONFIG_JSON",R="AZURE_OPENAI_ENDPOINT",b="AZURE_OPENAI_KEY",N="AZURE_OPENAI_API_VERSION",P="AZURE_OPENAI_DEPLOYMENT",x="MIDSCENE_USE_ANTHROPIC_SDK",w="ANTHROPIC_API_KEY",K="MIDSCENE_RUN_DIR",j="MIDSCENE_OPENAI_BASE_URL",z="MIDSCENE_OPENAI_API_KEY",B="MIDSCENE_OPENAI_USE_AZURE",M="MIDSCENE_AZURE_OPENAI_KEY",Z="MIDSCENE_AZURE_OPENAI_ENDPOINT",T="MIDSCENE_AZURE_OPENAI_API_VERSION",Q="MIDSCENE_AZURE_OPENAI_DEPLOYMENT",O="MIDSCENE_VL_MODE",D="MIDSCENE_VQA_MODEL_NAME",X="MIDSCENE_VQA_OPENAI_SOCKS_PROXY",J="MIDSCENE_VQA_OPENAI_HTTP_PROXY",U="MIDSCENE_VQA_OPENAI_BASE_URL",L="MIDSCENE_VQA_OPENAI_API_KEY",V="MIDSCENE_VQA_OPENAI_INIT_CONFIG_JSON",G="MIDSCENE_VQA_OPENAI_USE_AZURE",q="MIDSCENE_VQA_USE_AZURE_OPENAI",F="MIDSCENE_VQA_AZURE_OPENAI_SCOPE",W="MIDSCENE_VQA_AZURE_OPENAI_KEY",H="MIDSCENE_VQA_AZURE_OPENAI_ENDPOINT",Y="MIDSCENE_VQA_AZURE_OPENAI_API_VERSION",_="MIDSCENE_VQA_AZURE_OPENAI_DEPLOYMENT",$="MIDSCENE_VQA_AZURE_OPENAI_INIT_CONFIG_JSON",AA="MIDSCENE_VQA_USE_ANTHROPIC_SDK",Ae="MIDSCENE_VQA_ANTHROPIC_API_KEY",At="MIDSCENE_VQA_VL_MODE",Ar="MIDSCENE_PLANNING_MODEL_NAME",Ao="MIDSCENE_PLANNING_OPENAI_SOCKS_PROXY",An="MIDSCENE_PLANNING_OPENAI_HTTP_PROXY",Ai="MIDSCENE_PLANNING_OPENAI_BASE_URL",Aa="MIDSCENE_PLANNING_OPENAI_API_KEY",As="MIDSCENE_PLANNING_OPENAI_INIT_CONFIG_JSON",Al="MIDSCENE_PLANNING_OPENAI_USE_AZURE",Ad="MIDSCENE_PLANNING_USE_AZURE_OPENAI",Ac="MIDSCENE_PLANNING_AZURE_OPENAI_SCOPE",Au="MIDSCENE_PLANNING_AZURE_OPENAI_KEY",Ag="MIDSCENE_PLANNING_AZURE_OPENAI_ENDPOINT",Ap="MIDSCENE_PLANNING_AZURE_OPENAI_API_VERSION",Am="MIDSCENE_PLANNING_AZURE_OPENAI_DEPLOYMENT",AE="MIDSCENE_PLANNING_AZURE_OPENAI_INIT_CONFIG_JSON",Af="MIDSCENE_PLANNING_USE_ANTHROPIC_SDK",Ah="MIDSCENE_PLANNING_ANTHROPIC_API_KEY",Ay="MIDSCENE_PLANNING_VL_MODE",Av="MIDSCENE_GROUNDING_MODEL_NAME",AC="MIDSCENE_GROUNDING_OPENAI_SOCKS_PROXY",Ak="MIDSCENE_GROUNDING_OPENAI_HTTP_PROXY",AI="MIDSCENE_GROUNDING_OPENAI_BASE_URL",AS="MIDSCENE_GROUNDING_OPENAI_API_KEY",AR="MIDSCENE_GROUNDING_OPENAI_INIT_CONFIG_JSON",Ab="MIDSCENE_GROUNDING_OPENAI_USE_AZURE",AN="MIDSCENE_GROUNDING_USE_AZURE_OPENAI",AP="MIDSCENE_GROUNDING_AZURE_OPENAI_SCOPE",Ax="MIDSCENE_GROUNDING_AZURE_OPENAI_KEY",Aw="MIDSCENE_GROUNDING_AZURE_OPENAI_ENDPOINT",AK="MIDSCENE_GROUNDING_AZURE_OPENAI_API_VERSION",Aj="MIDSCENE_GROUNDING_AZURE_OPENAI_DEPLOYMENT",Az="MIDSCENE_GROUNDING_AZURE_OPENAI_INIT_CONFIG_JSON",AB="MIDSCENE_GROUNDING_USE_ANTHROPIC_SDK",AM="MIDSCENE_GROUNDING_ANTHROPIC_API_KEY",AZ="MIDSCENE_GROUNDING_VL_MODE",AT="OPENAI_USE_AZURE",AQ=["MIDSCENE_DEBUG_MODE",d,c,K],AO=["MIDSCENE_CACHE","MIDSCENE_LANGSMITH_DEBUG","MIDSCENE_FORCE_DEEP_THINK","MIDSCENE_MCP_USE_PUPPETEER_MODE","MIDSCENE_MCP_ANDROID_MODE"],AD=["MIDSCENE_CACHE_MAX_FILENAME_LENGTH","MIDSCENE_REPLANNING_CYCLE_LIMIT"],AX=["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",C,"MIDSCENE_MCP_CHROME_PATH","DOCKER_CONTAINER"],AJ=[...AO,...AD,...AX],AU=[l,s,z,j,B,u,g,k,I,S,x,E,f,h,y,v,"MIDSCENE_USE_VL_MODEL",w,Z,M,T,Q,O,p,m,AT,w,R,b,N,P,D,X,J,U,L,V,G,q,F,W,H,Y,_,$,AA,Ae,At,Ar,Ao,An,Ai,Aa,As,Al,Ad,Ac,Au,Ag,Ap,Am,AE,Af,Ah,Ay,Av,AC,Ak,AI,AS,AR,Ab,AN,AP,Ax,Aw,AK,Aj,Az,AB,AM,AZ],AL=["MIDSCENE_DANGEROUSLY_PRINT_ALL_CONFIG",...AQ,...AJ,...AU];var AV=((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);let AG=["doubao-vision","gemini","qwen-vl","qwen3-vl","vlm-ui-tars","vlm-ui-tars-doubao","vlm-ui-tars-doubao-1.5"];var Aq=t(18113),AF=t.n(Aq),AW=t(77410),AH=t.n(AW),AY=t(80911),A_=t.n(AY),A$=t(81232),A0=t.n(A$),A1=t(72715),A3=t(73656);let A5=A=>{if(!AQ.includes(A))throw Error(`getBasicEnvValue with key ${A} is not supported.`);return A3.env[A]};t(93114);var A7=t(91278),A2=t(73656);let A9=void 0!==A2&&(null==(o=A2.versions)?void 0:o.node);function A6(A,e){if(!A)throw Error(e||"Assertion failed")}var A8=t(73656);let A4="midscene_run",eA="midscene",ee=new Map,et=new Map;function er(A){let e=`${eA}:${A}`;if(!et.has(e)){let t=A0()(e);et.set(e,function(){for(var e=arguments.length,r=Array(e),o=0;o<e;o++)r[o]=arguments[o];A9&&function(A,e){if(!A9)return;let t=function(A){let e=A.replace(/:/g,"-");if(!ee.has(e)){let A=AH().join((A=>{if(!A9)return"";let e=(()=>{if(!A9)return"";let A=AH().resolve(A8.cwd(),A9?A5(K)||A4:"");if(!(0,Aq.existsSync)(A))try{(0,Aq.mkdirSync)(A,{recursive:!0})}catch(e){A=AH().join((0,A1.tmpdir)(),A4),(0,Aq.mkdirSync)(A,{recursive:!0})}return A})(),t=AH().join(e,A);return(0,Aq.existsSync)(t)||(0,Aq.mkdirSync)(t,{recursive:!0}),t})("log"),`${e}.log`),t=AF().createWriteStream(A,{flags:"a"});ee.set(e,t)}return ee.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(),s=Math.floor(Math.abs(a)/60).toString().padStart(2,"0"),l=(Math.abs(a)%60).toString().padStart(2,"0"),d=`${a<=0?"+":"-"}${s}:${l}`,c=`${o}T${n}.${i}${d}`;t.write(`[${c}] ${e}
|
|
3
3
|
`)}(A,A_().format(...r)),t(...r)})}return et.get(e)}let eo=()=>{var A;let e=A5(d),t="";e&&(console.warn("MIDSCENE_DEBUG_AI_PROFILE is deprecated, use DEBUG=midscene:ai:profile instead"),t="ai:profile"),A5(c)&&(console.warn("MIDSCENE_DEBUG_AI_RESPONSE is deprecated, use DEBUG=midscene:ai:response instead"),t=t?"ai:*":"ai:call"),t&&(A=t,A9||A0().enable(`${eA}:${A}`))};var en=t(73656);function ei(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let ea={modelName:l,socksProxy:u,httpProxy:g,openaiBaseURL:j,openaiApiKey:z,openaiExtraConfig:s,openaiUseAzureDeprecated:B,useAzureOpenai:k,azureOpenaiScope:I,azureOpenaiKey:M,azureOpenaiEndpoint:Z,azureOpenaiApiVersion:T,azureOpenaiDeployment:Q,azureExtraConfig:S,useAnthropicSdk:x,anthropicApiKey:"MIDSCENE_ANTHROPIC_API_KEY",vlMode:O},es={modelName:l,socksProxy:u,httpProxy:g,openaiBaseURL:m,openaiApiKey:p,openaiExtraConfig:s,openaiUseAzureDeprecated:AT,useAzureOpenai:k,azureOpenaiScope:I,azureOpenaiKey:b,azureOpenaiEndpoint:R,azureOpenaiApiVersion:N,azureOpenaiDeployment:P,azureExtraConfig:S,useAnthropicSdk:x,anthropicApiKey:w,vlMode:"DEFAULT_MODEL_CONFIG_KEYS has no vlMode key"},el=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}`},ed=A=>Object.fromEntries(Object.entries(A).map(A=>{let[e,t]=A;return["openaiApiKey","azureOpenaiKey","anthropicApiKey"].includes(e)?[e,el(t)]:["openaiExtraConfig","azureExtraConfig"].includes(e)?[e,el(JSON.stringify(t))]:[e,t]})),ec=(A,e)=>{if(e)try{return JSON.parse(e)}catch(e){throw Error(`Failed to parse ${A} as a JSON. ${e.message}`,{cause:e})}},eu=(A,e,t)=>(r,o,n)=>{t?n?A6(r,`The ${o} must be a non-empty string because of the ${A} is declared as ${t} and ${n} has also been specified in ${e}, but got: ${r}. Please check your config.`):A6(r,`The ${o} must be a non-empty string because of the ${A} is declared as ${t} in ${e}, but got: ${r}. Please check your config.`):A6(r,`The ${o} must be a non-empty string, but got: ${r}. Please check your config.`)},eg=A=>{if(!A)return{vlMode:void 0,uiTarsVersion:void 0};if(!AG.includes(A))throw Error(`the value ${A} is not a valid VL_MODE value, must be one of ${AG}`);return"vlm-ui-tars"===A?{vlMode:"vlm-ui-tars",uiTarsVersion:AV.V1_0}:"vlm-ui-tars-doubao"===A||"vlm-ui-tars-doubao-1.5"===A?{vlMode:"vlm-ui-tars",uiTarsVersion:AV.DOUBAO_1_5_20B}:{vlMode:A,uiTarsVersion:void 0}},ep={VQA:{modelName:D,socksProxy:X,httpProxy:J,openaiBaseURL:U,openaiApiKey:L,openaiExtraConfig:V,openaiUseAzureDeprecated:G,useAzureOpenai:q,azureOpenaiScope:F,azureOpenaiKey:W,azureOpenaiEndpoint:H,azureOpenaiApiVersion:Y,azureOpenaiDeployment:_,azureExtraConfig:$,useAnthropicSdk:AA,anthropicApiKey:Ae,vlMode:At},grounding:{modelName:Av,socksProxy:AC,httpProxy:Ak,openaiBaseURL:AI,openaiApiKey:AS,openaiExtraConfig:AR,openaiUseAzureDeprecated:Ab,useAzureOpenai:AN,azureOpenaiScope:AP,azureOpenaiKey:Ax,azureOpenaiEndpoint:Aw,azureOpenaiApiVersion:AK,azureOpenaiDeployment:Aj,azureExtraConfig:Az,useAnthropicSdk:AB,anthropicApiKey:AM,vlMode:AZ},planning:{modelName:Ar,socksProxy:Ao,httpProxy:An,openaiBaseURL:Ai,openaiApiKey:Aa,openaiExtraConfig:As,openaiUseAzureDeprecated:Al,useAzureOpenai:Ad,azureOpenaiScope:Ac,azureOpenaiKey:Au,azureOpenaiEndpoint:Ag,azureOpenaiApiVersion:Ap,azureOpenaiDeployment:Am,azureExtraConfig:AE,useAnthropicSdk:Af,anthropicApiKey:Ah,vlMode:Ay},default:ea},em=A=>{let{keys:e,provider:t,valueAssert:r}=A;eo();let o=er("ai:config"),n=t[e.socksProxy],i=t[e.httpProxy],a=t[e.vlMode];if(o("enter decideOpenaiSdkConfig with keys:",e),t[e.openaiUseAzureDeprecated]){o(`provider has ${e.openaiUseAzureDeprecated} with value${t[e.openaiUseAzureDeprecated]}`);let A=t[e.openaiBaseURL],s=t[e.openaiApiKey],l=ec(e.openaiExtraConfig,t[e.openaiExtraConfig]);return r(s,e.openaiApiKey,e.openaiUseAzureDeprecated),{socksProxy:n,httpProxy:i,vlModeRaw:a,openaiUseAzureDeprecated:!0,openaiApiKey:s,openaiBaseURL:A,openaiExtraConfig:l}}if(t[e.useAzureOpenai]){o(`provider has ${e.useAzureOpenai} with value ${t[e.useAzureOpenai]}`);let A=t[e.azureOpenaiScope],s=t[e.azureOpenaiKey],l=t[e.azureOpenaiEndpoint],d=t[e.azureOpenaiDeployment],c=t[e.azureOpenaiApiVersion],u=ec(e.azureExtraConfig,t[e.azureExtraConfig]),g=ec(e.openaiExtraConfig,t[e.openaiExtraConfig]);return r(s,e.azureOpenaiKey,e.useAzureOpenai),{socksProxy:n,httpProxy:i,vlModeRaw:a,useAzureOpenai:!0,azureOpenaiScope:A,azureOpenaiKey:s,azureOpenaiEndpoint:l,azureOpenaiDeployment:d,azureOpenaiApiVersion:c,azureExtraConfig:u,openaiExtraConfig:g}}if(t[e.useAnthropicSdk]){o(`provider has ${e.useAnthropicSdk} with value ${t[e.useAnthropicSdk]}`);let A=t[e.anthropicApiKey];return r(A,e.anthropicApiKey,e.useAnthropicSdk),{socksProxy:n,httpProxy:i,useAnthropicSdk:!0,anthropicApiKey:A}}{o("provider has no specific model SDK declared");let A=t[e.openaiBaseURL],s=t[e.openaiApiKey],l=ec(e.openaiExtraConfig,t[e.openaiExtraConfig]);return r(s,e.openaiApiKey),{socksProxy:n,httpProxy:i,vlModeRaw:a,openaiBaseURL:A,openaiApiKey:s,openaiExtraConfig:l}}},eE=(A,e)=>{if(A)if(e)return`UI-TARS=${e}`;else return`${A} mode`;return""},ef=(A,e)=>{let t=er("ai:config");t("decideModelConfig base on agent.modelConfig()");let r=ep[A],o=e[r.modelName];t("Got modelName from modelConfigFn",o);let n=o?(t("query modelConfig from fn by intent got corresponding modelName, will get other corresponding keys"),r):(t("query modelConfig from fn by intent got no corresponding modelName, will get other keys by default"),A6(e[ea.modelName],`The return value of agent.modelConfig do not have a valid value with key ${ea.modelName}.`),ea),i=em({keys:n,provider:e,valueAssert:eu(n.modelName,"modelConfig",o)}),{vlMode:a,uiTarsVersion:s}=eg(i.vlModeRaw),l=eE(a,s),d={...i,modelName:e[n.modelName],vlMode:a,uiTarsModelVersion:s,modelDescription:l,from:"modelConfig",intent:A};return t(`decideModelConfig result by agent.modelConfig() with intent ${A}:`,ed(d)),d},eh=(A,e)=>{eo();let t=er("ai:config"),r="default"===A?es:ep[A];if("default"!==A&&e[r.modelName]){let o=e[r.modelName];t(`Got intent ${A} corresponding modelName ${o} by key ${r.modelName} from globalConfig, will get other config by intent.`);let n=em({keys:r,provider:e,valueAssert:eu(r.modelName,"process.env",o)}),{vlMode:i,uiTarsVersion:a}=eg(n.vlModeRaw),s=eE(i,a),l={...n,modelName:o,vlMode:i,uiTarsModelVersion:a,modelDescription:s,from:"env",intent:A};return t(`decideModelConfig result by process.env with intent ${A}:`,ed(l)),l}t(`decideModelConfig as legacy logic with intent ${A}.`);let o=em({keys:es,provider:e,valueAssert:eu(es.modelName,"process.env")}),{vlMode:n,uiTarsVersion:i}=(A=>{let e=A[y],t=A[f],r=A[h],o=A[E],n=A[v],i=[e&&y,t&&f,r&&h,o&&E,n&&v].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{vlMode:"qwen3-vl",uiTarsVersion:void 0};if(t)return{vlMode:"qwen-vl",uiTarsVersion:void 0};if(e)return{vlMode:"doubao-vision",uiTarsVersion:void 0};if(n)return{vlMode:"gemini",uiTarsVersion:void 0};if(o)if("1"===o)return{vlMode:"vlm-ui-tars",uiTarsVersion:AV.V1_0};else if("DOUBAO"===o||"DOUBAO-1.5"===o)return{vlMode:"vlm-ui-tars",uiTarsVersion:AV.DOUBAO_1_5_20B};else return{vlMode:"vlm-ui-tars",uiTarsVersion:`${o}`};return{vlMode:void 0,uiTarsVersion:void 0}})(e),a=eE(n,i),s={...o,modelName:e[es.modelName]||"gpt-4o",vlMode:n,uiTarsModelVersion:i,modelDescription:a,from:"legacy-env",intent:A};return t(`decideModelConfig result by legacy logic with intent ${A}:`,ed(s)),s};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}let ev=["VQA","default","grounding","planning"],eC=new class{calcIntentConfigMap(A){let e={VQA:void 0,default:void 0,grounding:void 0,planning:void 0};for(let t of ev){let r=A({intent:t});if(!r)throw Error(`The agent has an option named modelConfig is a function, but it return ${r} when call with intent ${t}, which should be a object.`);e[t]=r}return e}calcModelConfigMapBaseOnIntent(A){let e={VQA:void 0,default:void 0,grounding:void 0,planning:void 0};for(let t of ev){let r=ef(t,A[t]);e[t]=r}return e}calcModelConfigMapBaseOnEnv(A){let e={VQA:void 0,default:void 0,grounding:void 0,planning:void 0};for(let t of ev){let r=eh(t,A);e[t]=r}return e}clearModelConfigMap(){if(this.isolatedMode)throw Error("ModelConfigManager work in isolated mode, so clearModelConfigMap should not be called");this.modelConfigMap=void 0}getModelConfig(A){if(this.isolatedMode){if(!this.modelConfigMap)throw Error("modelConfigMap is not initialized in isolated mode, which should not happen");return this.modelConfigMap[A]}if(!this.modelConfigMap){if(!this.globalConfigManager)throw Error("globalConfigManager is not registered, which should not happen");this.modelConfigMap=this.calcModelConfigMapBaseOnEnv(this.globalConfigManager.getAllEnvConfig())}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(){let A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"grounding";if(!this.getModelConfig(A).vlMode)throw Error("No visual language model (VL model) detected for the current scenario. Element localization may be inaccurate. Please verify your model configuration. Learn more: https://midscenejs.com/choose-a-model")}constructor(A){if(ey(this,"modelConfigMap",void 0),ey(this,"isolatedMode",!1),ey(this,"globalConfigManager",void 0),A){this.isolatedMode=!0;let e=this.calcIntentConfigMap(A);this.modelConfigMap=this.calcModelConfigMapBaseOnIntent(e)}}},ek=new class{getAllEnvConfig(){let A=AL.reduce((A,e)=>(A[e]=en.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(!AX.includes(A))throw Error(`getEnvConfigValue with key ${A} is not supported.`);if(A===C)throw Error("MATCH_BY_POSITION is deprecated, use MIDSCENE_USE_VL_MODEL instead");let t=e[A];return(this.keysHaveBeenRead[A]=!0,"string"==typeof t)?t.trim():t}getEnvConfigInNumber(A){let e=this.getAllEnvConfig();if(!AD.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(!AO.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(![...AJ,...AU].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(){ei(this,"override",void 0),ei(this,"keysHaveBeenRead",{}),ei(this,"globalModelConfigManager",void 0),eo()}};ek.registerModelConfigManager(eC),eC.registerGlobalConfigManager(ek);let eI=function(A){let e=arguments.length>1&&void 0!==arguments[1]&&arguments[1];ek.overrideAIConfig(A,e)};function eS(A){let e=[];return!function A(t){for(let r of(t.node&&e.push(t.node),t.children))A(r)}(A),e}t(75044),t(57861),t(5174),t(17444),er("img"),t(25626),t(27736),t(17374),t(27641);var eR=t(43427);er("ai:common");let eb=eR.z.object({left:eR.z.number(),top:eR.z.number()}),eN=eR.z.object({width:eR.z.number(),height:eR.z.number(),dpr:eR.z.number().optional()}),eP=eb.and(eN).and(eR.z.object({zoom:eR.z.number().optional()})),ex=eR.z.object({images:eR.z.array(eR.z.object({name:eR.z.string(),url:eR.z.string()})).optional(),convertHttpImage2Base64:eR.z.boolean().optional()}),ew=eR.z.union([eR.z.string(),eR.z.object({prompt:eR.z.string()}).and(ex.partial())]),eK="midscene_location_field_flag",ej=eR.z.object({prompt:ew,deepThink:eR.z.boolean().optional(),cacheable:eR.z.boolean().optional(),xpath:eR.z.union([eR.z.string(),eR.z.boolean()]).optional()}).passthrough();eR.z.object({[eK]:eR.z.literal(!0),prompt:ew,deepThink:eR.z.boolean().optional(),cacheable:eR.z.boolean().optional(),xpath:eR.z.boolean().optional(),center:eR.z.tuple([eR.z.number(),eR.z.number()]),rect:eP}).passthrough();let ez=(A,e)=>{var t;return A&&(null==(t=A._def)?void 0:t.typeName)==="ZodObject"&&A.shape?Object.keys(A.shape).filter(t=>{let r=A.shape[t];if(!(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(eK in A||"prompt"in A&&A.prompt)return!0}return!1})(r))return!1;if(e){var o;return(null==(o=r._def)?void 0:o.typeName)!=="ZodOptional"}return!0}):[]};var eB=t(55695);new eB.Pf({template:`
|
|
4
4
|
Here is the item user want to find:
|
|
@@ -17,5 +17,5 @@ Here is the item user want to find:
|
|
|
17
17
|
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.
|
|
18
18
|
|
|
19
19
|
Please enter your instructions in the input box below to start experiencing.
|
|
20
|
-
`,loading:!1,result:void 0,replayScriptsInfo:null,replayCounter:0,loadingProgressText:"",verticalMode:!1},tN={result:void 0,dump:null,reportHTML:null,error:null};t(28977);let tP="",tx="";function tw(A){return A.subType&&"Plan"!==A.subType?`${A.type} / ${A.subType||""}`:A.type}function tK(A){if(!A)return"";if("string"==typeof A)return A;if("object"==typeof A){if("string"==typeof A.prompt)return A.prompt;if("object"==typeof A.prompt&&A.prompt.prompt){let e=A.prompt.prompt,t=A.prompt.images||[];if(0===t.length)return e;let r=t.map(A=>{let e=A.url;return(e.startsWith("data:image/")||e.startsWith("data:")&&e.includes("base64"))&&(e=`${e.substring(0,15)}...`),`[${A.name}](${e})`}).join(", ");return`${e}, ${r}`}}return""}function tj(A){var e,t,r,o,n,i,a,s,l,d,c;let u;if("Planning"===A.type&&(u=null==A||null==(e=A.param)?void 0:e.userInstruction),"Insight"===A.type&&(u=tK(null==A?void 0:A.param)||(null==A||null==(t=A.param)?void 0:t.id)||(null==A||null==(r=A.param)?void 0:r.dataDemand)||(null==A||null==(o=A.param)?void 0:o.assertion)),"Action"===A.type){let e=null==A?void 0:A.locate,t=e?tK(e):"";(u=A.thought||"","number"==typeof(null==A||null==(n=A.param)?void 0:n.timeMs))?u=`${null==A||null==(l=A.param)?void 0:l.timeMs}ms`:"string"==typeof(null==A||null==(i=A.param)?void 0:i.scrollType)?u=(c=null==A?void 0:A.param)?`${c.direction||"down"}, ${c.scrollType||"once"}, ${c.distance||"distance-not-set"}`:"":"string"==typeof(null==A||null==(a=A.param)?void 0:a.direction)&&(null==A?void 0:A.subType)==="AndroidPull"?u=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==(s=A.param)?void 0:s.value)&&(u=null==A||null==(d=A.param)?void 0:d.value),t&&(u=u?`${t} - ${u}`:t)}return void 0===u?"":"string"==typeof u?u:"object"==typeof u&&tK(u)?tK(u):JSON.stringify(u,void 0,2)}er("ai:insight"),t(15787),t(5460),t(57861).Buffer,t(73656),t(87333),t(81507),t(73656),er("web:tool:profile"),t(57861).Buffer,er("cache"),er("device-task-executor"),er("agent"),["read-only","read-write","write-only"].map(A=>`"${A}"`).join(", ");let tz=(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 tB(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class tM{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){tB(this,"dbPromise",void 0),tB(this,"dbName",void 0),tB(this,"version",void 0),tB(this,"storeConfigs",void 0),this.dbName=A,this.version=e,this.storeConfigs=t,this.dbPromise=this.initDB()}}let tZ=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}},tT=(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 tQ(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let tO="playground_messages",tD="playground_results";class tX{async saveMessages(A){await tZ(async()=>{await this.dbManager.clear(tO);let e=A.slice(-100);await Promise.all(e.map((A,e)=>{let t={...A,result:void 0},r={id:A.id||`msg-${e}`,data:t,timestamp:A.timestamp?A.timestamp.getTime():Date.now()+e};return this.dbManager.put(tO,r)}))},"Failed to save messages to IndexedDB",void 0,this.messagesCleanup)}async loadMessages(){return await tZ(async()=>{let A=await this.dbManager.getAll(tO,!0);return 0===A.length?[]:Promise.all(A.map(async A=>{let e=A.data,t={...e,timestamp:new Date(e.timestamp)};if("result"===e.type&&e.id){let A=await this.loadResult(e.id);A&&(t.result=A.result,t.replayScriptsInfo=A.replayScriptsInfo,t.replayCounter=A.replayCounter,t.verticalMode=A.verticalMode)}return t}))},"Failed to load messages from IndexedDB",[],this.messagesCleanup)||[]}async clearMessages(){await tZ(async()=>{await Promise.all([this.dbManager.clear(tO),this.dbManager.clear(tD)])},"Failed to clear messages from IndexedDB")}async saveResult(A,e){await tZ(async()=>{let t=this.compressResultForStorage(e),r={id:A,data:t,timestamp:Date.now(),size:JSON.stringify(t).length};await this.dbManager.put(tD,r)},"Failed to save result to IndexedDB",void 0,this.resultsCleanup)}async loadResult(A){return await tZ(async()=>{let e=await this.dbManager.get(tD,A);return(null==e?void 0:e.data)||null},"Failed to load result from IndexedDB",null)||null}compressResultForStorage(A){var e,t;if(!(null==(t=A.result)||null==(e=t.dump)?void 0:e.executions))return A;let r=A.result.dump.executions.map(A=>{var e;return{...A,tasks:(null==(e=A.tasks)?void 0:e.map(A=>{var e,t;return{...A,uiContext:A.uiContext?{...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=>({...A,screenshot:this.compressScreenshotIfNeeded(A.screenshot)}))}}))||[]}});return{...A,result:{...A.result,dump:{...A.result.dump,executions: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}async getStorageStats(){return await tZ(async()=>{let[A,e]=await Promise.all([this.dbManager.count(tO),this.dbManager.count(tD)]);return{messageCount:A,resultCount:e}},"Failed to get storage statistics",{messageCount:0,resultCount:0})||{messageCount:0,resultCount:0}}async cleanup(){await Promise.all([this.messagesCleanup(),this.resultsCleanup()])}constructor(A="playground"){tQ(this,"dbManager",void 0),tQ(this,"namespace",void 0),tQ(this,"messagesCleanup",void 0),tQ(this,"resultsCleanup",void 0),this.namespace=A,this.dbManager=new tM(`midscene_playground_${A}`,1,[{name:tO,keyPath:"id"},{name:tD,keyPath:"id"}]),this.messagesCleanup=tT(this.dbManager,tO,100),this.resultsCleanup=tT(this.dbManager,tD,50)}}function tJ(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class tU{checkStorageSpace(){try{let A="storage-test",e="x".repeat(102400);return localStorage.setItem(A,e),localStorage.removeItem(A),!0}catch(A){return!1}}async saveMessages(A){try{this.checkStorageSpace()||(console.warn("Low storage space detected, clearing old data..."),await this.handleQuotaExceeded());let e=A.slice(-this.maxStorageItems).map(A=>({...A,result:void 0})),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..."),await this.handleQuotaExceeded();try{let e=A.slice(-10).map(A=>({...A,result:void 0})),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),await this.clearMessages()}}else console.error("Failed to save messages to localStorage:",e)}}async loadMessages(){try{let A=localStorage.getItem(this.messagesKey);if(!A)return[];let e=JSON.parse(A);return await Promise.all(e.map(async A=>{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{...A,...e}}catch(A){console.warn("Failed to parse stored result:",A)}}return A}))}catch(A){return console.error("Failed to load messages from localStorage:",A),[]}}async clearMessages(){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)}}async saveResult(A,e){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..."),await 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)}}async handleQuotaExceeded(){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)}}constructor(A="playground"){tJ(this,"messagesKey",void 0),tJ(this,"resultsKey",void 0),tJ(this,"maxStorageItems",50),this.messagesKey=`${A}-messages`,this.resultsKey=`${A}-results`}}class tL{async saveMessages(A){this.messages=[...A]}async loadMessages(){return[...this.messages]}async clearMessages(){this.messages=[],this.results.clear()}async saveResult(A,e){this.results.set(A,e)}constructor(){tJ(this,"messages",[]),tJ(this,"results",new Map)}}class tV{async saveMessages(A){}async loadMessages(){return[]}async clearMessages(){}async saveResult(A,e){}}function tG(){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 tX(e);return console.warn("IndexedDB not available, falling back to localStorage"),tG("localStorage",e);case"localStorage":if("undefined"!=typeof localStorage)return new tU(e);return console.warn("localStorage not available, falling back to memory storage"),tG("memory",e);case"memory":return new tL;case"none":return new tV;default:throw Error(`Unknown storage type: ${A}`)}}function tq(){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"}t(83264);var tF=t(94152),tW=t(15284),tH=t(8811);let tY=(A,e,t)=>{let r,{left:o,top:n,width:i,height:a}=A;r="element"===t?eW[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)%eW.length]:"searchArea"===t?eH("searchArea"):eH("element");let s=new tW.TCu;if(s.beginFill(r,.4),s.lineStyle(1,r,1),s.drawRect(o,n,i,a),s.endFill(),s.filters=[new tH.pt({blur:2,quality:3,alpha:.4,offset:{x:4,y:4},color:3355443})],!e)return[s];let l=new tW.xvT(e,{fontSize:18,fill:0});return l.x=o,l.y=Math.max(n-22,0),[s,l]},t_=A=>{let e=A.highlightElements||[],t=e.map(A=>A.id),r=A.highlightRect,o=A.highlightPoints,a=A.uiContext,{size:s,screenshotBase64:l}=a,d=s.width,c=s.height,u=(0,i.useRef)(null),g=(0,i.useMemo)(()=>new tW.MxU,[]),[p,m]=(0,i.useState)(!1),E=(0,i.useMemo)(()=>new tW.W20,[]),f=(0,i.useMemo)(()=>new tW.W20,[]),[h,y]=(0,i.useState)(null),v=(0,i.useRef)(void 0),{backgroundVisible:C,setBackgroundVisible:k,elementsVisible:I,setElementsVisible:S}=to();(0,i.useEffect)(()=>(Promise.resolve((async()=>{if(!u.current||!d)return;await g.init({width:d,height:c,background:0xffffff});let A=u.current;u.current.appendChild(g.canvas);let{clientWidth:e}=u.current.parentElement,t=.6*window.innerHeight;if(d/c<=e/t){let e=t/c;A.style.width=`${Math.floor(d*e)}px`,A.style.height=`${Math.floor(c*e)}px`}g.stage.addChild(E),g.stage.addChild(f),m(!0)})()),()=>{console.log("will destroy");try{g.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}),[g,d,c]),(0,i.useEffect)(()=>p?(g.stage.eventMode="static",g.stage.hitArea=new tW.AeJ(0,0,d,c),g.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==g||null==(A=g.stage)||A.off("click")}):void 0,[p,A.onCanvasClick,d,c]),(0,i.useEffect)(()=>{if(!p)return;let A=new Image;A.onload=()=>{if(!g.stage)return;let e=tW.xEZ.from(A),t=new tW.jyi(e);t.x=0,t.y=0,t.width=d,t.height=c,t.eventMode="passive",g.stage.addChildAt(t,0),v.current=t,t.visible=C},A.onerror=A=>{console.error("load screenshot failed",A)},A.src=l},[g.stage,p,d,c]);let{highlightElementRects:R}=(0,i.useMemo)(()=>{if(E.removeChildren(),f.removeChildren(),E.eventMode="passive",f.eventMode="passive",r){let[A]=tY(r,"Search Area","searchArea");E.addChild(A)}return e.length&&e.forEach(A=>{let{rect:e,content:t,id:r}=A,[o]=tY(e,t,"highlight");E.addChild(o)}),(null==o?void 0:o.length)&&o.forEach(A=>{let e=((A,e)=>{let[t,r]=A,o=eH("element"),n=new tW.TCu;return n.beginFill(o,.4),n.drawCircle(t,r,10),n.endFill(),n})(A,0);E.addChild(e)}),eS(a.tree).forEach(A=>{let{rect:e,content:r,id:o}=A;if(t.includes(o)||(null==h?void 0:h.id)===o)return;let[n]=tY(e,r,"element");f.addChild(n)}),f.visible=I,{highlightElementRects:[]}},[g,p,e,a.tree,h,r,o]),b=null;return 1===R.length?b=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(R[0])]})}):R.length>1&&(b=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(R)]})})),(0,n.jsxs)("div",{className:"blackboard",children:[(0,n.jsx)("div",{className:"blackboard-main-content",style:{width:"100%"},ref:u}),(0,n.jsx)("div",{className:"blackboard-filter",style:{display:A.hideController?"none":"block"},children:(0,n.jsxs)("div",{className:"overlay-control",children:[(0,n.jsx)(tF.Z,{checked:C,onChange:A=>{k(A.target.checked),v.current&&(v.current.visible=A.target.checked)},children:"Background"}),(0,n.jsx)(tF.Z,{checked:I,onChange:A=>{S(A.target.checked),f.visible=A.target.checked},children:"Elements"})]})}),(0,n.jsx)("div",{className:"bottom-tip",style:{display:A.hideController?"none":"block"},children:b})]})};var t$=t(94249),t0=t(9308),t1=t(32110),t3=t(10195),t5=t(18599),t7=t(34949),t2=t(349),t9=t(7193);let t6=A=>{let{text:e,disabled:t=!1,speed:r=5,className:o=""}=A,i={"--animation-duration":`${r}s`};return(0,n.jsx)("div",{className:`shiny-text ${t?"disabled":""} ${o}`,style:i,children:e})},t8=(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"})]}),t4=function(){let A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:t8;return(0,n.jsx)("div",{className:"server-tip",children:(0,n.jsx)(t9.Z,{message:"Playground Server Not Ready",description:A,type:"warning"})})},rA=(0,n.jsx)("div",{className:"result-empty-tip",style:{textAlign:"center"},children:(0,n.jsx)(t6,{disabled:!0,text:"The result will be shown here"})});var re=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 rt=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)(t_,{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)(t$.Z,{})});case"finishedWithWarning":return(0,n.jsx)("span",{style:{color:"#f7bb05"},children:(0,n.jsx)(t0.Z,{})});case"failed":case"closed":case"timedOut":case"interrupted":return(0,n.jsx)("span",{style:{color:"#FF0A0A"},children:(0,n.jsx)(t1.Z,{})});case"pending":return(0,n.jsx)(t3.Z,{});case"cancelled":case"skipped":return(0,n.jsx)(t5.Z,{});case"running":return(0,n.jsx)(t7.Z,{});default:return(0,n.jsx)(t2.Z,{})}})("failed")," No UI context",(0,n.jsx)(tk.ZP,{type:"link",onClick:A=>{A.preventDefault(),t(re)},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 rr=t(73654);let ro=A=>{let{className:e=""}=A,{config:t}=tg();return Object.keys(t||{}).length>=1?null:(0,n.jsxs)("div",{className:`env-config-reminder ${e}`,children:[(0,n.jsx)(rr.Z,{className:"reminder-icon"}),(0,n.jsx)("span",{className:"reminder-text",children:"Please set up your environment variables before using."}),(0,n.jsx)(tp,{mode:"text",showTooltipWhenEmpty:!1})]})};var rn=t(70223),ri=t(11322),ra=t(50408),rs=t(94878),rl=t(70788),rd=t(64008);let rc=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:(0,n.jsx)("path",{fill:"#333",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"})}),ru=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:[(0,n.jsx)("path",{stroke:"#333",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:"#333",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"})]}),rg=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:(0,n.jsx)("path",{fill:"#333",d:"M13 1.835a2.165 2.165 0 0 1 .665 4.225v3.88a2.166 2.166 0 1 1-2.725 2.725H5.06a2.165 2.165 0 1 1-2.725-2.726V6.06A2.165 2.165 0 1 1 5.06 3.336h5.88c.281-.87 1.097-1.5 2.06-1.5m-10 9.33a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m-7.94-6.5A2.17 2.17 0 0 1 3.665 6.06v3.88c.66.213 1.181.734 1.395 1.395h5.88a2.17 2.17 0 0 1 1.395-1.396V6.06a2.17 2.17 0 0 1-1.395-1.394zM3 3.165a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67"})}),rp=new Map,rm=async A=>{if(!rp.has(A))return tW.deM.load(A).then(e=>{rp.set(A,e)})},rE=A=>rp.get(A);function rf(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let rh=A=>ry(A),ry=A=>A,rv=A=>new Promise(e=>setTimeout(e,A)),rC="frame cancel (this is an error on purpose)";class rk{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)},this.mediaRecorder=A,this.recording=!0,this.mediaRecorder.start()}stop(){var A;if(!this.recording||!this.mediaRecorder)return void console.warn("not recording");this.mediaRecorder.onstop=()=>{let A=new Blob(this.chunks,{type:"video/webm"}),e=URL.createObjectURL(A),t=document.createElement("a");t.href=e,t.download="midscene_replay.webm",t.click(),URL.revokeObjectURL(e)},null==(A=this.mediaRecorder)||A.stop(),this.recording=!1,this.mediaRecorder=null}constructor(A){rf(this,"canvas",void 0),rf(this,"mediaRecorder",null),rf(this,"chunks",void 0),rf(this,"recording",!1),this.canvas=A,this.chunks=[]}}function rI(A){var e;let t,[r,o]=(0,i.useState)(""),[a,s]=(0,i.useState)(""),{autoZoom:l,setAutoZoom:d,elementsVisible:c,setElementsVisible:u}=to();(0,i.useEffect)(()=>{(null==A?void 0:A.autoZoom)!==void 0&&d(A.autoZoom)},[null==A?void 0:A.autoZoom,d]),(0,i.useEffect)(()=>{(null==A?void 0:A.elementsVisible)!==void 0&&u(A.elementsVisible)},[null==A?void 0:A.elementsVisible,u]);let g=null==A?void 0:A.replayScripts,p=(null==A?void 0:A.imageWidth)||1920,m=(null==A?void 0:A.imageHeight)||1080,E=(null==A?void 0:A.fitMode)||"height",f=(0,i.useRef)((null==g||null==(e=g[0])?void 0:e.img)||null),h=(0,i.useRef)(null),y=(0,i.useMemo)(()=>new tW.MxU,[]),v=(0,i.useRef)(null),C=(0,i.useRef)(null),[k,I]=(0,i.useState)(0),S=()=>{I(Date.now())},R=(0,i.useMemo)(()=>new tW.W20,[]),b=(0,i.useMemo)(()=>{let A=new tW.W20;return A.zIndex=1,A},[]);(0,i.useEffect)(()=>{b.visible=c},[c,b]);let N={left:0,top:0,width:p,pointerLeft:Math.round(p/2),pointerTop:Math.round(m/2)},[P,x]=(0,i.useState)(-1),w=(0,i.useRef)(!1);(0,i.useEffect)(()=>(w.current=!1,()=>{w.current=!0}),[]);let K=(0,i.useRef)({...N}),j=async(A,e)=>{if(y.screen.width!==A||y.screen.height!==e){if(y.renderer.resize(A,e),h.current){let t=A/e;h.current.style.setProperty("--canvas-aspect-ratio",t.toString())}K.current={left:0,top:0,width:A,pointerLeft:Math.round(A/2),pointerTop:Math.round(e/2)}}},z=async(A,e)=>{let t=f.current;if(!t)return void console.warn("no image to update");let r=A||p,o=e||m;await j(r,o),rE(t)||(console.warn("image not loaded",t),await rm(t));let n=rE(t);if(!n)throw Error("texture not found");let i=tW.jyi.from(n);if(!i)throw Error("sprite not found");let a="main-img",s=R.getChildByLabel(a);s&&R.removeChild(s),i.label=a,i.zIndex=0,i.width=r,i.height=o,R.addChild(i)},B=A=>{var e,t;let r;C.current||(C.current=tW.jyi.from(tx),C.current.zIndex=3,C.current.anchor.set(.5,.5),C.current.scale.set(.5),C.current.label="spinning-pointer"),C.current.x=(null==(e=v.current)?void 0:e.x)||0,C.current.y=(null==(t=v.current)?void 0:t.y)||0,R.addChild(C.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;C.current&&(C.current.rotation=t),A(n)};return A(n),()=>{C.current&&R.removeChild(C.current),o=!0}},M=async(A,e,t)=>{var r,o;rE(A)||(console.warn("image not loaded",A),await rm(A));let n=rE(A);if(!n)throw Error("texture not found");let i=tW.jyi.from(n),a=null==(r=v.current)?void 0:r.x,s=null==(o=v.current)?void 0:o.y;if("number"==typeof e&&(a=e),"number"==typeof t&&(s=t),void 0===a||void 0===s)return void console.warn("invalid pointer position",e,t);if(v.current){let A=R.getChildByLabel("pointer");A&&R.removeChild(A)}v.current=i,v.current.x=a,v.current.y=s,v.current.label="pointer",v.current.zIndex=2,R.addChild(v.current)},Z=(A,e)=>{K.current=A;let t=e||y.screen.width||p,r=l?Math.max(1,t/A.width):1;R.scale.set(r),R.x=l?Math.round(0-A.left*r):0,R.y=l?Math.round(0-A.top*r):0;let o=R.getChildByLabel("pointer");o&&(o.scale.set(1/r),"number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(o.x=A.pointerLeft,o.y=A.pointerTop))},T=async(A,e,t)=>{let r=y.screen.width||p,o=y.screen.height||m;if(!l){let o={...K.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;await new Promise(s=>{let l=d=>{let c=d-a,u=rh(Math.min(c/e,1));Z({...o,pointerLeft:n+(A.pointerLeft-n)*u,pointerTop:i+(A.pointerTop-i)*u},r),c<e?t(l):s()};t(l)});return}let n={...K.current},i=n.left,a=n.top,s=n.pointerLeft,d=n.pointerTop,c=n.width/r,u=performance.now(),g="number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(A.pointerLeft!==s||A.pointerTop!==d),E=g?.375*e:0,f=e-E;await new Promise(n=>{let l=p=>{let m={...K.current},h=p-u;if(g)if(h<=E){let e=rh(Math.min(h/E,1));m.pointerLeft=s+(A.pointerLeft-s)*e,m.pointerTop=d+(A.pointerTop-d)*e}else m.pointerLeft=A.pointerLeft,m.pointerTop=A.pointerTop;if(h>E){let e=ry(Math.min((h-E)/f,1)),t=c+(A.width/r-c)*e,n=r*t;m.width=n;let s=i+(A.left-i)*e,l=a+(A.top-a)*e,d=s+n-r,u=l+o*t-o;m.left=d>0?s+d:s,m.top=u>0?l+u:l}Z(m,r),h<e?t(l):n()};t(l)})},Q=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 s=a-n,l=Math.min(s/e,1);A.alpha=0===r?1-ry(l):ry(l),s<e?t(i):o()};t(i)})},O=async(A,e,t)=>Q(A,e,t,0),D=async(A,e,t,r,o)=>{b.removeChildren();let n=[...A],i=n.length,a=0;await new Promise(A=>{let s=performance.now(),l=d=>{let c=d-s,u=Math.floor(((A,e,t,r,o)=>{let n=1-A;return e*n*n*n+3*t*A*n*n+3*r*A*A*n+o*A*A*A})(Math.min(c/r,1),0,.5,.5,1)*i);for(;a<u;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0];if(e){let[A]=tY(e.rect,e.content,"element");A.alpha=0,b.addChild(A),a++,Q(A,80,o)}}if(c<r)o(l);else{for(;n.length>0;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0],[t]=tY(e.rect,e.content,"element");t.alpha=1,b.addChild(t)}if(t){let[A]=tY(t,"Search Area","searchArea");A.alpha=1,b.addChild(A)}e.map(A=>{let[e]=tY(A.rect,A.content||"","highlight");e.alpha=1,b.addChild(e)}),A()}};o(l)})},X=async()=>{h.current&&g&&(await y.init({width:p,height:m,background:0xf4f4f4,autoDensity:!0,antialias:!0}),h.current&&(h.current.appendChild(y.canvas),R.x=0,R.y=0,y.stage.addChild(R),b.x=0,b.y=0,R.addChild(b)))},[J,U]=(0,i.useState)(!1),L=(0,i.useRef)(null);(0,i.useEffect)(()=>(Promise.resolve((async()=>{if(await X(),h.current&&p&&m){let A=p/m;h.current.style.setProperty("--canvas-aspect-ratio",A.toString()),h.current.setAttribute("data-fit-mode",E);let e=h.current.closest(".player-container");e&&e.setAttribute("data-fit-mode",E)}S()})()),()=>{try{y.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}),[p,m,E]),(0,i.useEffect)(()=>{if(k){let A;return Promise.resolve((async()=>{let e;if(!y)throw Error("app is not initialized");if(!g)throw Error("scripts is required");let{frame:t,cancel:r,timeout:n}=(e=!1,{frame:A=>{if(e)throw Error(rC);requestAnimationFrame(()=>{if(e)throw Error(rC);A(performance.now())})},timeout:(A,t)=>{if(e)throw Error(rC);setTimeout(()=>{if(e)throw Error(rC);A()},t)},cancel:()=>{e=!0}});A=r;let i=g.filter(A=>!!A.img).map(A=>A.img);await Promise.all([...i,tx,tP].map(rm)),b.removeChildren(),await M(tP,p/2,m/2),await z(),await Z({...N});let a=g.reduce((A,e)=>A+e.duration+(e.camera&&e.insightCameraDuration?e.insightCameraDuration:0),0),l=performance.now();x(0);let d=()=>{let A=Math.min((performance.now()-l)/a,1);if(x(A),A<1)return n(d,200)};for(let A in t(d),L.current&&L.current.start(),g){let e=g[A];if(o(e.title||""),s(e.subTitle||""),"sleep"===e.type)await rv(e.duration);else if("insight"===e.type){var c;if(!e.img)throw Error("img is required");f.current=e.img,await z(e.imageWidth,e.imageHeight);let A=(null==(c=e.context)?void 0:c.tree)?eS(e.context.tree):[],r=e.highlightElement?[e.highlightElement]:[];if(await D(A,r,e.searchArea,e.duration,t),e.camera){if(!e.insightCameraDuration)throw Error("insightCameraDuration is required");await T(e.camera,e.insightCameraDuration,t)}}else if("clear-insight"===e.type)await O(b,e.duration,t),b.removeChildren(),b.alpha=1;else if("img"===e.type)e.img&&e.img!==f.current&&(f.current=e.img,await z(e.imageWidth,e.imageHeight)),e.camera?await T(e.camera,e.duration,t):await rv(e.duration);else if("pointer"===e.type){if(!e.img)throw Error("pointer img is required");await M(e.img)}else if("spinning-pointer"===e.type){let A=B(t);await rv(e.duration),A()}}L.current&&(await rv(1200),L.current.stop(),L.current=null,U(!1))})().catch(A=>{console.error("player error",A)})),()=>{null==A||A()}}},[k]);let[V,G]=(0,i.useState)(!1),[q,F]=(0,i.useState)(!1),W=Math.round(100*P),H=1===P;(0,i.useEffect)(()=>{if(H){let A=A=>{" "===A.key&&S()};return window.addEventListener("keydown",A),()=>{window.removeEventListener("keydown",A)}}},[H]);let Y=()=>{};return P<1?t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(tf.Z,{spin:!0,color:"#333"}),size:"default"}):V?(t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(ri.Z,{color:"#333"}),size:"default"}),Y=()=>S()):t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(ri.Z,{color:"#333"}),size:"default"}),(0,n.jsxs)("div",{className:"player-container",children:[(0,n.jsx)("div",{className:"canvas-container",ref:h}),(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:`${W}%`,transition:0===P?"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)(e5.Z,{title:a,children:(0,n.jsx)("div",{className:"subtitle",children:a})})]}),J?null:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>G(!0),onMouseLeave:()=>G(!1),onClick:Y,children:t}),(null==A?void 0:A.reportFileContent)?(0,n.jsx)(e5.Z,{title:"Download Report",children:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>G(!0),onMouseLeave:()=>G(!1),onClick:()=>(A=>{let e=new Blob([A],{type:"text/html"}),t=URL.createObjectURL(e),r=document.createElement("a");r.href=t,r.download="midscene_report.html",r.click()})(A.reportFileContent),children:(0,n.jsx)(ra.Z,{color:"#333"})})}):null,(0,n.jsx)(e5.Z,{title:J?"Generating...":"Export Video",children:(0,n.jsx)("div",{className:"status-icon",onClick:J?void 0:()=>L.current?void console.warn("recorderSession exists"):y.canvas?void(L.current=new rk(y.canvas),U(!0),S()):void console.warn("canvas is not initialized"),style:{opacity:J?.5:1,cursor:J?"not-allowed":"pointer"},children:J?(0,n.jsx)(rn.Z,{size:"default",percent:W}):(0,n.jsx)(rs.Z,{})})}),(0,n.jsx)(rl.Z,{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)(rc,{style:{width:"16px",height:"16px"}}),(0,n.jsx)("span",{style:{fontSize:"12px",marginRight:"16px"},children:"Focus on cursor"})]}),(0,n.jsx)(rd.Z,{size:"small",checked:l,onChange:A=>{d(A),S()},onClick:(A,e)=>{var t;return null==e||null==(t=e.stopPropagation)?void 0:t.call(e)}})]})},{key:"elementsVisible",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)(rg,{style:{width:"16px",height:"16px"}}),(0,n.jsx)("span",{style:{fontSize:"12px",marginRight:"16px"},children:"Show element markers"})]}),(0,n.jsx)(rd.Z,{size:"small",checked:c,onChange:A=>{u(A),S()},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:q?1:.7,transition:"opacity 0.2s"},children:(0,n.jsx)(ru,{style:{width:"16px",height:"16px"}})})})]})})})]})}let rS=A=>{let{result:e,loading:t,serverValid:r,serviceMode:o,replayScriptsInfo:i,replayCounter:a,loadingProgressText:s,verticalMode:l=!1,notReadyMessage:d,fitMode:c,autoZoom:u}=A,g="result-wrapper";l&&(g+=" vertical-mode-result"),i&&l&&(g+=" result-wrapper-compact");let p=rA;return r||"Server"!==o?t?p=(0,n.jsxs)("div",{className:"loading-container",children:[(0,n.jsx)(rn.Z,{spinning:t,indicator:(0,n.jsx)(tf.Z,{spin:!0})}),(0,n.jsx)("div",{className:"loading-progress-text loading-progress-text-progress",children:(0,n.jsx)(t6,{text:s,speed:3})})]}):i?p=(0,n.jsx)(rI,{replayScripts:i.scripts,imageWidth:i.width,imageHeight:i.height,reportFileContent:("In-Browser-Extension"===o||"Server"===o)&&(null==e?void 0:e.reportHTML)?null==e?void 0:e.reportHTML:null,fitMode:c,autoZoom:u},a):(null==e?void 0:e.error)?p=(0,n.jsx)("pre",{children:null==e?void 0:e.error}):(null==e?void 0:e.result)!==void 0&&(p="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)})):p=t4(d),(0,n.jsx)("div",{className:g,style:{height:"100%",display:"flex",flexDirection:"column",flex:"1 1 auto",justifyContent:"center"},children:p})},rR=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:20,height:20,fill:"none","aria-label":"Playground",viewBox:"0 0 20 20",...A,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"})]});var rb=t(35725),rN=t(9004),rP=t(13098),rx=t(56984),rw={};rw.d=(A,e)=>{for(var t in e)rw.o(e,t)&&!rw.o(A,t)&&Object.defineProperty(A,t,{enumerable:!0,get:e[t]})},rw.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),rw.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})};var rK={};rw.r(rK),rw.d(rK,{create:()=>e9.Ue});let{create:rj}=rK,rz="midscene-prompt-history-v2",rB="midscene-last-selected-type",rM=rj((A,e)=>({history:(()=>{let A=localStorage.getItem(rz);return A?JSON.parse(A):{}})(),lastSelectedType:localStorage.getItem(rB)||"aiAction",clearHistory:t=>{let r={...e().history};delete r[t],A({history:r}),localStorage.setItem(rz,JSON.stringify(r))},addHistory:t=>{let{type:r}=t,o=e().history,n=o[r]||[],i=JSON.stringify({prompt:t.prompt,params:t.params}),a=[t,...n.filter(A=>JSON.stringify({prompt:A.prompt,params:A.params})!==i)];a.length>10&&(a.length=10);let s={...o,[r]:a};A({history:s}),localStorage.setItem(rz,JSON.stringify(s))},getHistoryForType:A=>e().history[A]||[],setLastSelectedType:e=>{A({lastSelectedType:e}),localStorage.setItem(rB,e)}})),rZ="ZodOptional",rT="ZodDefault",rQ="ZodNullable",rO="ZodObject",rD="midscene_location_field_flag",rX=A=>"object"==typeof A&&null!==A&&("shape"in A||"ZodObject"===A.type),rJ=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&&rD 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},rU=A=>{var e,t,r,o,n;let i=A,a=!1,s=!1;for(;(null==(e=i._def)?void 0:e.typeName)===rZ||(null==(t=i._def)?void 0:t.typeName)===rT||(null==(r=i._def)?void 0:r.typeName)===rQ;)(null==(o=i._def)?void 0:o.typeName)===rZ&&(a=!0),(null==(n=i._def)?void 0:n.typeName)===rT&&(s=!0),i=i._def.innerType||i;return{actualField:i,isOptional:a,hasDefault:s}};eR.z.object({locate:ej.describe("The element to be tapped")}),eR.z.object({locate:ej.describe("The element to be right clicked")}),eR.z.object({locate:ej.describe("The element to be double clicked")}),eR.z.object({locate:ej.describe("The element to be hovered")}),eR.z.object({value:eR.z.union([eR.z.string(),eR.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:ej.describe("The element to be input").optional(),mode:eR.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.')}),eR.z.object({locate:ej.describe("The element to be clicked before pressing the key").optional(),keyName:eR.z.string().describe("The key to be pressed. Use '+' for key combinations, e.g., 'Control+A', 'Shift+Enter'")}),eR.z.object({direction:eR.z.enum(["down","up","right","left"]).default("down").describe("The direction to scroll"),scrollType:eR.z.enum(["once","untilBottom","untilTop","untilRight","untilLeft"]).default("once").describe("The scroll type"),distance:eR.z.number().nullable().optional().describe("The distance in pixels to scroll"),locate:ej.optional().describe("The element to be scrolled")}),eR.z.object({from:ej.describe("The position to be dragged"),to:ej.describe("The position to be dropped")}),eR.z.object({locate:ej.describe("The element to be long pressed"),duration:eR.z.number().default(500).optional().describe("Long press duration in milliseconds")}),eR.z.object({start:ej.optional().describe("Starting point of the swipe gesture, if not specified, the center of the page will be used"),direction:eR.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:eR.z.number().optional().describe("The distance in pixels to swipe (mutually exclusive with end)"),end:ej.optional().describe("Ending point of the swipe gesture (mutually exclusive with distance)"),duration:eR.z.number().default(300).describe("Duration of the swipe gesture in milliseconds"),repeat:eR.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)")}),eR.z.object({locate:ej.describe("The input field to be cleared")});let rL=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},rV=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:27,height:27,fill:"none",viewBox:"0 0 27 27",...A,children:(0,n.jsx)("path",{stroke:"#000",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"})}),rG=A=>{let{showDeepThinkOption:e=!1,enableTracking:t=!1,showDataExtractionOptions:r=!1,hideDomAndScreenshotOptions:o=!1}=A,i=tg(A=>A.forceSameTabNavigation),a=tg(A=>A.setForceSameTabNavigation),s=tg(A=>A.deepThink),l=tg(A=>A.setDeepThink),d=tg(A=>A.screenshotIncluded),c=tg(A=>A.setScreenshotIncluded),u=tg(A=>A.domIncluded),g=tg(A=>A.setDomIncluded);if(!t&&!e&&!r)return null;let p=function(){let A=[];return t&&A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>a(A.target.checked),checked:i,children:"limit popup to current tab"}),key:"track-config"}),e&&A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>{l(A.target.checked)},checked:s,children:"deep think"}),key:"deep-think-config"}),r&&!o&&(A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>{c(A.target.checked)},checked:d,children:"include screenshot in request"}),key:"screenshot-included-config"}),A.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)(rx.ZP.Group,{size:"small",value:u,onChange:A=>g(A.target.value),children:[(0,n.jsx)(rx.ZP,{value:!1,children:"Off"}),(0,n.jsx)(rx.ZP,{value:!0,children:"All"}),(0,n.jsx)(rx.ZP,{value:"visible-only",children:"Visible only"})]})]}),key:"dom-included-config"})),A}();return(0,n.jsx)("div",{className:"selector-trigger",children:(0,n.jsx)(rl.Z,{menu:{items:p},trigger:["click"],children:(0,n.jsx)(rV,{width:24,height:24})})})};var rq=t(43564),rF=t(81053);let{TextArea:rW}=e2.Z,rH=(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)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`Please input ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(e2.Z,{placeholder:a})},e)},r_=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)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`The ${e} is required`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rW,{rows:2,placeholder:a})},e)},r$=A=>{var e;let{name:t,label:r,fieldSchema:o,isRequired:i,marginBottom:a,placeholder:s}=A,l=((null==(e=o._def)?void 0:e.values)||[]).map(A=>({value:A,label:A.charAt(0).toUpperCase()+A.slice(1)}));return(0,n.jsx)(tv.Z.Item,{name:["params",t],label:r,rules:i?[{required:!0,message:`Please select ${t}`}]:[],style:{marginBottom:a},colon:!1,children:(0,n.jsx)(rq.Z,{placeholder:s||`Select ${t}`,options:l})},t)},r0=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A,a=500*("distance"===e),s=i&&Number(i)||a,l="distance"===e?1e4:void 0;return(0,n.jsx)(tv.Z.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)(rF.Z,{placeholder:s.toString(),min:0,max:l,step:"distance"===e?10:1,style:{width:"100%"}})},e)},r1=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A;return(0,n.jsx)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`Please select ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rq.Z,{placeholder:i||`Select ${e}`,options:[{value:!0,label:"True"},{value:!1,label:"False"}]})},e)},r3=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:18,height:16,fill:"none",viewBox:"0 0 18 16",...A,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"})}),r5=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:25,height:25,fill:"none",viewBox:"0 0 25 25",...A,children:[(0,n.jsx)("path",{stroke:"#000",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:"#000",strokeLinecap:"round",strokeLinejoin:"round",strokeOpacity:.85,strokeWidth:1.33,d:"M12.695 8.322v4.203l2.967 2.968"})]}),r7=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:19,height:19,fill:"none",viewBox:"0 0 19 19",...A,children:[(0,n.jsxs)("g",{stroke:"#000",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"})})})]}),{Text:r2}=e1.Z,r9=A=>{let{onSelect:e,history:t,currentType:r}=A,[o,a]=(0,i.useState)(!1),[s,l]=(0,i.useState)(""),d=rM(A=>A.clearHistory),c=(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(s.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,s]);(0,i.useEffect)(()=>{if(!o)return;let A=A=>{c.current&&!c.current.contains(A.target)&&a(!1)},e=setTimeout(()=>{document.addEventListener("click",A)},100);return()=>{clearTimeout(e),document.removeEventListener("click",A)}},[o]);let g=(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)(r5,{width:24,height:24})}),o&&(0,n.jsx)("div",{className:"history-modal-overlay",ref:c,children:(0,n.jsxs)("div",{className:"history-modal-container",children:[(0,n.jsxs)("div",{className:"history-modal-header",children:[(0,n.jsxs)(r2,{strong:!0,style:{fontSize:"16px"},children:["History (",t.length,")"]}),(0,n.jsx)(tk.ZP,{size:"small",type:"text",icon:(0,n.jsx)(r3,{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)(e2.Z,{placeholder:"Search",value:s,onChange:A=>l(A.target.value),prefix:(0,n.jsx)(r7,{width:18,height:18}),className:"search-input",allowClear:!0}),(0,n.jsx)(tk.ZP,{type:"link",onClick:()=>{d(r),l(""),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)(r2,{type:"secondary",children:"No history record"})}):(0,n.jsxs)(n.Fragment,{children:[g("Last 7 days",u.recent7Days),g("Last 1 year",u.recent1Year),g("Earlier",u.older),s&&0===u.recent7Days.length&&0===u.recent1Year.length&&0===u.older.length&&(0,n.jsx)("div",{className:"no-results",children:(0,n.jsx)(r2,{type:"secondary",children:"No matching history record"})})]})})]})})]})},{TextArea:r6}=e2.Z,r8=A=>{let{runButtonEnabled:e,form:t,serviceMode:r,selectedType:o,dryMode:a,stoppable:s,loading:l,onRun:d,onStop:c,clearPromptAfterRun:u=!0,actionSpace:g,hideDomAndScreenshotOptions:p=!1}=A,[m,E]=(0,i.useState)(!1),[f,h]=(0,i.useState)(""),y="aiQuery"===o?"What do you want to query?":"aiAssert"===o?"What do you want to assert?":"aiTap"===o?"What element do you want to tap?":"aiDoubleClick"===o?"What element do you want to double-click?":"aiHover"===o?"What element do you want to hover over?":"aiInput"===o?"Format: <value> | <element>\nExample: hello world | search box":"aiRightClick"===o?"What element do you want to right-click?":"aiKeyboardPress"===o?"Format: <key> | <element (optional)>\nExample: Enter | text field":"aiScroll"===o?"Format: <direction> <amount> | <element (optional)>\nExample: down 500 | main content":"aiLocate"===o?"What element do you want to locate?":"aiBoolean"===o?"What do you want to check (returns true/false)?":"aiNumber"===o?"What number do you want to extract?":"aiString"===o?"What text do you want to extract?":"aiAsk"===o?"What do you want to ask?":"aiWaitFor"===o?"What condition do you want to wait for?":"What do you want to do?",v=(0,i.useRef)(null),C=(0,i.useRef)(null),k=tv.Z.useWatch("params",t),I=(0,i.useRef)(null),S=rM(A=>A.history),R=rM(A=>A.lastSelectedType),b=rM(A=>A.addHistory),N=rM(A=>A.setLastSelectedType),P=(0,i.useMemo)(()=>S[o]||[],[S,o]),x=(0,i.useMemo)(()=>{if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);return!!(null==A?void 0:A.paramSchema)&&(!rX(A.paramSchema)||Object.keys(A.paramSchema.shape||{}).length>0)}return!1},[o,g]),w=(0,i.useMemo)(()=>{if(g&&g.length>0){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if(A){if(A.paramSchema&&rX(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{isOptional:t}=rU(e[A]);return!t})}return!!A.paramSchema}}return!0},[o,g]),K=(0,i.useMemo)(()=>["aiQuery","aiBoolean","aiNumber","aiString","aiAsk","aiAssert"].includes(o),[o]),j=(0,i.useMemo)(()=>{if("aiLocate"===o)return!0;if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{actualField:t}=rU(e[A]);return rJ(t)})}}return!1},[o,g]),z=(0,i.useMemo)(()=>{let A=K&&!p;return"In-Browser-Extension"===r||j||A},[r,j,K,p]),B=(0,i.useMemo)(()=>{let A=Object.keys(tS);if(!g||0===g.length)return A;let e=g.map(A=>A.interfaceAlias||A.name),t=new Set;return A.forEach(A=>{let r=tS[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)},[g]),M=(0,i.useCallback)(()=>{if(!x||!g)return{};let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(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{}},[o,x,g]);(0,i.useEffect)(()=>{!t.getFieldValue("type")&&R&&t.setFieldValue("type",R)},[t,R]),(0,i.useEffect)(()=>{o&&o!==R&&N(o)},[o,R,N]);let Z=(0,i.useCallback)(()=>{let A=C.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=P[0];if(!A||!I.current||A.timestamp!==I.current.timestamp)if(A)t.setFieldsValue({type:A.type,prompt:A.prompt||"",params:A.params}),h(A.prompt||""),I.current=A;else{let A=M();t.setFieldsValue({prompt:"",params:A}),h(""),I.current=null}},[o,P,t,M]),(0,i.useEffect)(()=>{let A=setTimeout(()=>{Z()},100);return()=>clearTimeout(A)},[o,Z]);let T=tv.Z.useWatch("prompt",t);(0,i.useEffect)(()=>{T!==f&&h(T||"")},[T,f]);let Q=(0,i.useCallback)(A=>{t.setFieldsValue({prompt:A.prompt,type:A.type,params:A.params}),h(A.prompt)},[t]),O=(0,i.useCallback)(A=>{h(A.target.value)},[]),D=(0,i.useMemo)(()=>{if(!x||!g)return!1;let A=g.find(A=>A.interfaceAlias===o||A.name===o);return!!((null==A?void 0:A.paramSchema)&&rX(A.paramSchema))&&1===Object.keys(A.paramSchema.shape||{}).length},[o,x,g]),X=(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)&&rX(e.paramSchema)){let t=e.paramSchema.shape||{};return Object.keys(t).every(e=>{let{isOptional:r}=rU(t[e]),o=A[e];return r||void 0!==o&&""!==o&&null!==o})}return!0}return n.trim().length>0})(e,!!x,k,g,o,f),[e,x,o,g,f,k]),J=(0,i.useCallback)(()=>{let A=t.getFieldsValue(),e="";if(x&&A.params&&g){let t=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==t?void 0:t.paramSchema)&&rX(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}=rU(n[e]);rJ(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 r={type:A.type,prompt:e,params:A.params,timestamp:Date.now()};if(b(r),d(),u)if(I.current=r,h(""),x){let A=M();t.setFieldValue("params",A)}else t.setFieldValue("prompt","")},[t,b,d,x,o,u,g,M]),U=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&X?(J(),A.preventDefault(),A.stopPropagation()):"Enter"===A.key&&setTimeout(()=>{if(v.current){var A;let e=null==(A=v.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)},[J,X]),L=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&X&&(J(),A.preventDefault(),A.stopPropagation())},[J,X]),V=(0,i.useCallback)(()=>{if(!x)return null;if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(A.paramSchema)){let e=A.paramSchema.shape||{},t=Object.keys(e);if(1===t.length){let A=t[0],{actualField:r}=rU(e[A]),i=rJ(r),a=(()=>{var e,t;if(null==(e=r._def)?void 0:e.description)return r._def.description;if(r.description)return r.description;if(g){let e=g.find(A=>A.interfaceAlias===o||A.name===o);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 i?"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)(tv.Z.Item,{name:["params",A],style:{margin:0},children:(0,n.jsx)(e2.Z.TextArea,{className:"main-side-console-input-textarea",rows:4,placeholder:a,autoFocus:!0,onKeyDown:L})})}let r=[],a=t.sort((A,t)=>{let r=e[A],o=e[t],{isOptional:n}=rU(r),{isOptional:i}=rU(o);return!n&&i?-1:n&&!i?1:0});if(a.forEach((A,t)=>{var i,s,l;let{actualField:d,isOptional:c}=rU(e[A]),u=rJ(d),p=A.charAt(0).toUpperCase()+A.slice(1),m=12*(t!==a.length-1),E=(()=>{var e,t;if(null==(e=d._def)?void 0:e.description)return d._def.description;if(d.description)return d.description;if(g){let e=g.find(A=>A.interfaceAlias===o||A.name===o);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(u)return"Describe the element you want to interact with"})(),f={name:A,label:p,fieldSchema:d,isRequired:!c,marginBottom:m,placeholder:E};u?r.push((0,n.jsx)(r_,{...f},A)):(null==(i=d._def)?void 0:i.typeName)==="ZodEnum"?r.push((0,n.jsx)(r$,{...f},A)):(null==(s=d._def)?void 0:s.typeName)==="ZodNumber"?r.push((0,n.jsx)(r0,{...f},A)):(null==(l=d._def)?void 0:l.typeName)==="ZodBoolean"?r.push((0,n.jsx)(r1,{...f},A)):r.push((0,n.jsx)(rY,{...f},A))}),"aiScroll"===o){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},[o,x,g,L]),G=(0,i.useCallback)(()=>{E(!0)},[]),q=(0,i.useCallback)(()=>{E(!1)},[]),F=(0,i.useCallback)(()=>{let A=A=>(0,n.jsx)(tk.ZP,{type:"primary",icon:(0,n.jsx)(rb.Z,{}),style:{borderRadius:20,zIndex:999},onClick:J,disabled:!X,loading:l,children:A});return a?"aiAction"===o?(0,n.jsx)(e5.Z,{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"):s?(0,n.jsx)(tk.ZP,{icon:(0,n.jsx)(rN.Z,{}),onClick:c,style:{borderRadius:20,zIndex:999},children:"Stop"}):A("Run")},[a,l,J,c,X,o,s]);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:C,children:[(0,n.jsx)(tv.Z.Item,{name:"type",style:{margin:0},children:(0,n.jsx)(rx.ZP.Group,{buttonStyle:"solid",disabled:!e,children:tR.map(A=>{var e;return(0,n.jsx)(e5.Z,{title:(null==(e=tS[A])?void 0:e.title)||"",children:(0,n.jsx)(rx.ZP.Button,{value:A,children:rL(A)})},A)})})}),(0,n.jsx)(rl.Z,{menu:(()=>{let A=B.filter(A=>!tR.includes(A)),e=[],r=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="interaction"});r.length>0&&e.push({key:"interaction-group",type:"group",label:"Interaction APIs",children:r.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let o=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="extraction"});o.length>0&&e.push({key:"extraction-group",type:"group",label:"Data Extraction APIs",children:o.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let n=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="validation"});n.length>0&&e.push({key:"validation-group",type:"group",label:"Validation APIs",children:n.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let i=A.filter(A=>!tS[A]);return i.length>0&&e.push({key:"device-specific-group",type:"group",label:"Device-Specific APIs",children:i.map(A=>({key:A,label:rL(A),title:"",onClick:()=>{t.setFieldValue("type",A)}}))}),{items:e}})(),placement:"bottomLeft",trigger:["click"],disabled:!e,children:(0,n.jsxs)(tk.ZP,{className:`more-apis-button ${!tR.includes(o)?"selected-from-dropdown":""}`,children:[o&&!tR.includes(o)?rL(o):"more",(0,n.jsx)(rP.Z,{style:{fontSize:"10px",marginLeft:"2px"}})]})})]}),(0,n.jsxs)("div",{className:"action-icons",children:[z&&(0,n.jsx)("div",{className:m?"settings-wrapper settings-wrapper-hover":"settings-wrapper",onMouseEnter:G,onMouseLeave:q,children:(0,n.jsx)(rG,{enableTracking:"In-Browser-Extension"===r,showDeepThinkOption:j,showDataExtractionOptions:K,hideDomAndScreenshotOptions:p})}),(0,n.jsx)(r9,{onSelect:Q,history:P,currentType:o})]})]}),(0,n.jsxs)("div",{className:`main-side-console-input ${!e?"disabled":""} ${l?"loading":""}`,children:[w?x?D?V():(0,n.jsx)("div",{className:"structured-params-container",children:V()}):(0,n.jsx)(tv.Z.Item,{name:"prompt",style:{margin:0},children:(0,n.jsx)(r6,{className:"main-side-console-input-textarea",disabled:!e,rows:4,placeholder:y,autoFocus:!0,onKeyDown:U,onChange:O,ref:v})}):(0,n.jsxs)("div",{className:"no-input-method",style:{padding:"20px",textAlign:"center",color:"#666",fontSize:"14px"},children:['Click "Run" to execute ',rL(o)]}),(0,n.jsx)("div",{className:"form-controller-wrapper",children:F()})]})]})},{Text:r4}=e1.Z;function oA(A){let{error:e}=A;return e?(0,n.jsxs)(e5.Z,{title:(0,n.jsx)("span",{style:{whiteSpace:"pre-wrap",wordBreak:"break-all"},children:e}),overlayStyle:{maxWidth:"100vw"},children:["Error: ",e.split("\n")[0]]}):null}function oe(A){let{playgroundSDK:e,storage:t,contextProvider:r,config:o={},branding:a={},className:s="",dryMode:l=!1,showContextPreview:d=!0}=A,[c]=tv.Z.useForm(),{config:u}=tg(),[g,p]=(0,i.useState)(!1);(0,i.useEffect)(()=>{(async()=>{if(e&&"function"==typeof e.checkStatus)try{await e.checkStatus(),p(!0)}catch(A){console.warn("Failed to initialize SDK, using default namespace:",A),p(!0)}else p(!0)})()},[e]);let m=(0,i.useMemo)(()=>{if(t)return t;if(!g)return null;let A=o.storageNamespace||(e.id&&"string"==typeof e.id?`agent-${e.id}`:"playground-default"),r=tq();return console.log(`Using ${r} storage for namespace: ${A}`),tG(r,A)},[t,g,o.storageNamespace,e]),{loading:E,setLoading:f,infoList:h,setInfoList:y,actionSpace:v,actionSpaceLoading:C,uiContextPreview:k,setUiContextPreview:I,showScrollToBottomButton:S,verticalMode:R,replayCounter:b,setReplayCounter:N,infoListRef:P,currentRunningIdRef:x,interruptedFlagRef:w,clearInfoList:K,handleScrollToBottom:j}=function(A,e,t){let[r,o]=(0,i.useState)(!1),[n,a]=(0,i.useState)([]),[s,l]=(0,i.useState)([]),[d,c]=(0,i.useState)(!0),[u,g]=(0,i.useState)(),[p,m]=(0,i.useState)(!1),[E,f]=(0,i.useState)(!1),[h,y]=(0,i.useState)(0),v=(0,i.useRef)(null),C=(0,i.useRef)(null),k=(0,i.useRef)({}),I=(0,i.useRef)(!1);(0,i.useEffect)(()=>{let A=async()=>{let A=tG(tq(),"playground-default");try{if(null==A?void 0:A.loadMessages){let t=await A.loadMessages();if(t.length>1)return console.log("Found data in old namespace, migrating..."),(null==e?void 0:e.saveMessages)&&await e.saveMessages(t),A.clearMessages&&await A.clearMessages(),t}}catch(A){console.debug("No data found in old namespace:",A)}return[]},t=async()=>{let t={...tb,id:"welcome",timestamp:new Date};if(null==e?void 0:e.loadMessages)try{let r=await e.loadMessages();0===r.length&&(r=await A()),r.some(A=>"welcome"===A.id)?a(r):a([t,...r])}catch(A){console.error("Failed to load messages:",A),a([t])}else a([t])};e&&!I.current?(I.current=!0,t()):e||0!==n.length||t()},[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=>g(A)).catch(A=>{console.error("Failed to get UI context:",A)})},[t,u]),(0,i.useEffect)(()=>{(async()=>{c(!0);try{var e;if(!A)return void l([]);let r=u||await (null==t||null==(e=t.getUIContext)?void 0:e.call(t)),o=await A.getActionSpace(r);l(o||[])}catch(A){console.error("Failed to load action space:",A),l([])}finally{c(!1)}})()},[A,u,t]),(0,i.useEffect)(()=>{f(window.innerWidth<750);let A=()=>{f(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)},[]),R=(0,i.useCallback)(()=>{if(v.current){let{scrollTop:A,scrollHeight:e,clientHeight:t}=v.current;m(!(A+t>=e-10))}},[]),b=(0,i.useCallback)(()=>{v.current&&(v.current.scrollTo({top:v.current.scrollHeight,behavior:"smooth"}),m(!1))},[]);(0,i.useEffect)(()=>{n.length>0&&S()},[n,S]),(0,i.useEffect)(()=>{let A=v.current;if(A)return A.addEventListener("scroll",R),R(),()=>{A.removeEventListener("scroll",R)}},[R]);let N=(0,i.useCallback)(async()=>{if(a([{...tb,id:"welcome",timestamp:new Date}]),null==e?void 0:e.clearMessages)try{await e.clearMessages()}catch(A){console.error("Failed to clear stored messages:",A)}},[e]),P=(0,i.useCallback)(async()=>{if(null==t?void 0:t.refreshContext)try{let A=await t.refreshContext();g(A)}catch(A){console.error("Failed to refresh context:",A)}},[t]);return{loading:r,setLoading:o,infoList:n,setInfoList:a,actionSpace:s,actionSpaceLoading:d,uiContextPreview:u,setUiContextPreview:g,showScrollToBottomButton:p,verticalMode:E,replayCounter:h,setReplayCounter:y,infoListRef:v,currentRunningIdRef:C,interruptedFlagRef:k,clearInfoList:N,refreshContext:P,handleScrollToBottom:b,scrollToBottom:S}}(e,m,r),{handleRun:z,handleStop:B,canStop:M}=function(A,e,t,r,o,n,a,s,l,d,c,u){let{deepThink:g,screenshotIncluded:p,domIncluded:m}=tg(),E=(0,i.useCallback)(async t=>{if(!A)return void console.warn("PlaygroundSDK is not available");let r=Date.now(),n=t.type,i=`${t.type}: ${t.prompt||JSON.stringify(t.params)}`,E={id:`user-${Date.now()}`,type:"user",content:i,timestamp:new Date};a(A=>[...A,E]),o(!0);let f={...tN},h={id:`system-${r}`,type:"system",content:"",timestamp:new Date,loading:!0,loadingProgressText:""};a(A=>[...A,h]);try{if(c.current=r,u.current[r]=!1,A.onProgressUpdate&&A.onProgressUpdate(()=>{}),A.onProgressUpdate&&A.onProgressUpdate(A=>{u.current[r]||a(e=>{let t=e[e.length-1];if(t&&"progress"===t.type&&t.content===A)return e;let o={id:`progress-${r}-${Date.now()}`,type:"progress",content:A,timestamp:new Date};return[...e,o]})}),f.result=await A.executeAction(n,t,{requestId:r.toString(),deepThink:g,screenshotIncluded:p,domIncluded:m}),"object"==typeof f.result&&null!==f.result){let A=f.result;A.dump&&(f.dump=A.dump),A.reportHTML&&(f.reportHTML=A.reportHTML),A.error&&(f.error=A.error),void 0!==A.result&&(f.result=A.result)}}catch(A){f.error=(null==A?void 0:A.message)||String(A),console.error("Playground execution error:",A)}if(u.current[r])return;o(!1),c.current=null;let y=null,v=s;if((null==f?void 0:f.dump)&&!eD.includes(n)){let A=(A=>{let e,t,r=new Set,o=A.sdkVersion,n=new Set;if(A.executions.forEach(A=>{A.tasks.forEach(A=>{var o,n;if(null==(n=A.uiContext)||null==(o=n.size)?void 0:o.width){let o=A.uiContext.size.width,n=A.uiContext.size.height;e||(e=o,t=n),r.add(`${o}x${n}`)}})}),!e||!t)return console.warn("width or height is missing in dump file"),{scripts:[],sdkVersion:o,modelBriefs:[]};let i=[];A.executions.forEach(A=>{let r=((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=tz({left:0,top:0,width:t,height:r},t,r),a=(A,e,t)=>({type:"pointer",img:A,duration:0,title:e,subTitle:t}),s=[],l=i,d=!1,c=n.length,u="",g=!1;return n.forEach((A,e)=>{var n,p,m,E,f,h,y,v,C,k,I,S,R,b,N,P,x,w,K,j,z,B,M,Z,T,Q,O,D,X,J,U,L,V,G,q,F,W;if(!g){if(0===e&&(u=tj(A)),"Planning"===A.type)A.recorder&&A.recorder.length>0&&s.push({type:"img",img:null==(p=A.recorder)||null==(n=p[0])?void 0:n.screenshot,camera:0===e?i:void 0,duration:900,title:tw(A),subTitle:tj(A),imageWidth:(null==(E=A.uiContext)||null==(m=E.size)?void 0:m.width)||t,imageHeight:(null==(h=A.uiContext)||null==(f=h.size)?void 0:f.height)||r});else if("Insight"===A.type&&"Locate"===A.subType){let e=null==(y=A.output)?void 0:y.element,n=tw(A),a=tj(A);(null==e?void 0:e.rect)&&(o={...tz(e.rect,t,r),pointerLeft:e.center[0],pointerTop:e.center[1]});let c=A.uiContext;if(null==c?void 0:c.screenshotBase64){let e,u=A.log,g=c.tree?eS(c.tree).length:0;c.screenshotBase64&&s.push({type:"img",img:c.screenshotBase64,duration:300,title:n,subTitle:a,imageWidth:(null==(S=c.size)?void 0:S.width)||t,imageHeight:(null==(R=c.size)?void 0:R.height)||r}),e=l===i?void 0:o?((A,e)=>{let t=Math.min(A.left,e.left),r=Math.min(A.top,e.top);return{left:t,top:r,width:Math.max(A.left+A.width,e.left+e.width)-t}})(l,o):void 0,s.push({type:"insight",img:c.screenshotBase64,context:c,camera:e,highlightElement:(null==(v=A.output)?void 0:v.element)||void 0,searchArea:null==u||null==(C=u.taskInfo)?void 0:C.searchArea,duration:g>20?800:400,insightCameraDuration:800,title:n,subTitle:a,imageWidth:(null==(k=c.size)?void 0:k.width)||t,imageHeight:(null==(I=c.size)?void 0:I.height)||r}),s.push({type:"sleep",duration:300,title:n,subTitle:a}),d=!0}}else if("Action"===A.type&&"FalsyConditionStatement"!==A.subType){let n=tw(A),u=tj(A);s.push(a(tP,n,u)),l=null!=o?o:i,s.push({type:"img",img:null==(N=A.recorder)||null==(b=N[0])?void 0:b.screenshot,duration:1e3,camera:"Sleep"===A.subType?i:o,title:n,subTitle:u,imageWidth:(null==(x=A.uiContext)||null==(P=x.size)?void 0:P.width)||t,imageHeight:(null==(K=A.uiContext)||null==(w=K.size)?void 0:w.height)||r}),d&&(s.push({type:"clear-insight",duration:200,title:n,subTitle:u}),d=!1);let g=900*(e<c-1);(null==(z=A.recorder)||null==(j=z[1])?void 0:j.screenshot)?(s.push({type:"spinning-pointer",duration:300,title:n,subTitle:u}),s.push(a(tP,n,u)),s.push({type:"img",img:null==(M=A.recorder)||null==(B=M[1])?void 0:B.screenshot,duration:g,title:n,subTitle:u,imageWidth:(null==(T=A.uiContext)||null==(Z=T.size)?void 0:Z.width)||t,imageHeight:(null==(O=A.uiContext)||null==(Q=O.size)?void 0:Q.height)||r})):s.push({type:"sleep",duration:g,title:n,subTitle:u})}else{let e=tw(A),o=tj(A),n=null==(X=A.recorder)||null==(D=X[A.recorder.length-1])?void 0:D.screenshot;n&&s.push({type:"img",img:n,duration:900,camera:i,title:e,subTitle:o,imageWidth:(null==(U=A.uiContext)||null==(J=U.size)?void 0:J.width)||t,imageHeight:(null==(V=A.uiContext)||null==(L=V.size)?void 0:L.height)||r})}if("finished"!==A.status){g=!0;let e=tw(A),o=A.errorMessage||"unknown error",n=o.indexOf("NOT_IMPLEMENTED_AS_DESIGNED")>0?"Further actions cannot be performed in the current environment":o;s.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==(q=A.uiContext)||null==(G=q.size)?void 0:G.width)||t,imageHeight:(null==(W=A.uiContext)||null==(F=W.size)?void 0:F.height)||r});return}}}),g||s.push({title:"Done",subTitle:u,type:"img",duration:900,camera:i}),s})(A,-1,e,t);r&&i.push(...r),A.tasks.forEach(A=>{if(A.usage){let{model_name:e,model_description:t,intent:r}=A.usage;r&&e&&n.add(t?`${"string"!=typeof r||0===r.length?r:r.charAt(0).toUpperCase()+r.slice(1)}/${e}(${t})`:e)}})});let a=i.filter((A,e)=>e===i.length-1||"Done"!==A.title),s=(()=>{var A;let e=[...n];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:a,width:e,height:t,sdkVersion:o,modelBriefs:s}})(f.dump);l(A=>A+1),y=A,v=s+1}a(A=>A.map(A=>A.id===`system-${r}`?{...A,content:"",loading:!1,loadingProgressText:""}:A));let C={id:`result-${r}`,type:"result",content:"Execution result",timestamp:new Date,result:f,loading:!1,replayScriptsInfo:y,replayCounter:v,loadingProgressText:"",verticalMode:d};if(a(A=>[...A,C]),null==e?void 0:e.saveResult)try{await e.saveResult(C.id,C)}catch(A){console.error("Failed to save result:",A)}let k={id:`separator-${r}`,type:"separator",content:"New Session",timestamp:new Date};a(A=>[...A,k])},[A,e,t,o,a,s,l,d,c,u,g,p,m]);return{handleRun:E,handleStop:(0,i.useCallback)(async()=>{let e=c.current;if(e&&A&&A.cancelExecution)try{await A.cancelExecution(e.toString()),u.current[e]=!0,o(!1),A.onProgressUpdate&&A.onProgressUpdate(()=>{}),a(A=>A.map(A=>A.id===`system-${e}`&&A.loading?{...A,content:"Operation stopped",loading:!1,loadingProgressText:""}:A));let t={id:`separator-${e}`,type:"separator",content:"New Session",timestamp:new Date};a(A=>[...A,t])}catch(A){console.error("Failed to stop execution:",A)}},[A,c,u,o,a]),canStop:r&&!!c.current&&!!A&&!!A.cancelExecution}}(e,m,v,E,f,0,y,b,N,R,x,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 Z=(0,i.useCallback)(async()=>{try{let A=c.getFieldsValue();await z(A)}catch(A){tC.ZP.error((null==A?void 0:A.message)||"Execution failed")}},[c,z]),T=Object.keys(u||{}).length>=1,Q=o.serverMode||!l&&!C&&T,O=tv.Z.useWatch("type",c),D=d&&!1!==o.showContextPreview,X=o.layout||"vertical",J=!1!==o.showVersionInfo;return(0,n.jsx)("div",{className:`playground-container ${X}-mode ${s}`.trim(),children:(0,n.jsxs)(tv.Z,{form:c,onFinish:Z,className:"command-form",children:[D&&(0,n.jsx)("div",{className:"context-preview-section",children:(0,n.jsx)(rt,{uiContextPreview:k,setUiContextPreview:I,showContextPreview:D})}),(0,n.jsxs)("div",{className:"middle-dialog-area",children:[h.length>1&&(0,n.jsx)("div",{className:"clear-button-container",children:(0,n.jsx)(tk.ZP,{size:"small",icon:(0,n.jsx)(tE.Z,{}),onClick:K,type:"text",className:"clear-button"})}),(0,n.jsx)("div",{ref:P,className:"info-list-container",children:(0,n.jsx)(tI.Z,{itemLayout:"vertical",dataSource:h,renderItem:A=>{var e;return(0,n.jsx)(tI.Z.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:(()=>{var e,t,r,o;let i=A.content.split(" - "),a=null==(e=i[0])?void 0:e.trim(),s=i.slice(1).join(" - ").trim(),l=h.findIndex(e=>e.id===A.id),d=h.slice(l+1).some(A=>"progress"===A.type),c=E&&!d;return(0,n.jsxs)(n.Fragment,{children:[a&&(0,n.jsxs)("span",{className:"progress-action-item",children:[a,(0,n.jsx)("span",{className:`progress-status-icon ${c?"loading":(null==(t=A.result)?void 0:t.error)?"error":"completed"}`,children:c?(0,n.jsx)(tf.Z,{spin:!0}):(null==(r=A.result)?void 0:r.error)?"✗":"✓"})]}),s&&(0,n.jsx)("div",{children:(0,n.jsx)("span",{className:"progress-description",children:s})}),(null==(o=A.result)?void 0:o.error)&&(0,n.jsx)(oA,{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)(r4,{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)(th.Z,{component:a.icon||rR,style:{fontSize:20}}),(0,n.jsx)("span",{className:"system-message-title",children:a.title||"Playground"})]}),(A.content||A.result)&&(0,n.jsxs)("div",{className:"system-message-content",children:["result"===A.type&&(null==(e=A.result)?void 0:e.error)&&(0,n.jsxs)("div",{className:"error-message",children:[(0,n.jsx)("div",{className:"divider"}),(0,n.jsx)(oA,{error:A.result.error})]}),"result"===A.type?(0,n.jsx)(rS,{result:A.result||null,loading:A.loading||!1,serverValid:!0,serviceMode:"Server",replayScriptsInfo:A.replayScriptsInfo||null,replayCounter:A.replayCounter||0,loadingProgressText:A.loadingProgressText||"",verticalMode:A.verticalMode||!1,fitMode:"width"}):(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)(tk.ZP,{className:"scroll-to-bottom-button",type:"primary",shape:"circle",icon:(0,n.jsx)(ty.Z,{}),onClick:j,size:"large"})]}),(0,n.jsxs)("div",{className:"bottom-input-section",children:[o.showEnvConfigReminder?(0,n.jsx)(ro,{}):null,(0,n.jsx)(r8,{runButtonEnabled:Q,form:c,serviceMode:"Server",selectedType:O,dryMode:l,stoppable:M,loading:E,onRun:Z,onStop:B,actionSpace:v})]}),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 ot=t(45761),or=t(75368),oo=t(12764),on=t(7379),oi=t(29129);function oa(A){let{playgroundSDK:e,serverOnline:t,isUserOperating:r=!1}=A,[o,a]=(0,i.useState)(null),[s,l]=(0,i.useState)(!1),[d,c]=(0,i.useState)(null),[u,g]=(0,i.useState)(0),[p,m]=(0,i.useState)(null),E=(0,i.useRef)(null),f=(0,i.useRef)(!1),h=(0,i.useCallback)(async function(){let A=arguments.length>0&&void 0!==arguments[0]&&arguments[0];if(t){l(!0),A&&c(null);try{let A=await e.getScreenshot();if(console.log("Screenshot API response:",A),null==A?void 0:A.screenshot){let e=A.screenshot.toString().trim();e?(a(e),c(null),g(Date.now())):c("Empty screenshot data received")}else c("No screenshot data in response")}catch(A){console.error("Screenshot fetch error:",A),c(A instanceof Error?A.message:"Failed to fetch screenshot")}finally{l(!1)}}},[e,t]),y=(0,i.useCallback)(async()=>{if(t)try{let A=await e.getInterfaceInfo();A&&m(A)}catch(A){console.error("Interface info fetch error:",A)}},[e,t]),v=(0,i.useCallback)(()=>{E.current&&clearInterval(E.current),console.log("Starting screenshot polling (5s interval)"),E.current=setInterval(()=>{!f.current&&t&&h(!1)},5e3)},[h,t]),C=(0,i.useCallback)(()=>{E.current&&(console.log("Stopping screenshot polling"),clearInterval(E.current),E.current=null)},[]),k=(0,i.useCallback)(()=>{console.log("Pausing screenshot polling"),f.current=!0},[]),I=(0,i.useCallback)(()=>{console.log("Resuming screenshot polling"),f.current=!1},[]),S=(0,i.useCallback)(()=>{h(!0)},[h]);return((0,i.useEffect)(()=>{if(!t){a(null),c(null),m(null),C();return}return h(!1),y(),v(),()=>{C()}},[t,v,C,h,y]),(0,i.useEffect)(()=>{t&&(r?k():(I(),h(!1)))},[r,k,I,h,t]),(0,i.useEffect)(()=>()=>{C()},[C]),t)?s&&!o?(0,n.jsxs)("div",{className:"screenshot-viewer loading",children:[(0,n.jsx)(rn.Z,{size:"large"}),(0,n.jsx)("p",{children:"Loading screenshot..."})]}):d&&!o?(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==p?void 0:p.type)?p.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)(e5.Z,{title:null==p?void 0:p.description,children:(0,n.jsx)(on.Z,{size:16,className:"info-icon"})})]}),(0,n.jsxs)("div",{className:"screenshot-controls",children:[u>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()})(u)]}),(0,n.jsx)(e5.Z,{title:"Refresh screenshot",children:(0,n.jsx)(tk.ZP,{icon:(0,n.jsx)(oi.Z,{}),onClick:S,loading:s,size:"small"})}),r&&(0,n.jsxs)("span",{className:"operation-indicator",children:[(0,n.jsx)(rn.Z,{size:"small"})," Operating..."]})]})]}),(0,n.jsx)("div",{className:"screenshot-content",children:o?(0,n.jsx)("img",{src:o.startsWith("data:image/")?o:`data:image/png;base64,${o}`,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:",o.substring(0,100)),c("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"})]})})}let os=t.p+"static/svg/server-offline-foreground.6e892230.svg",{Content:ol}=ot.Z,od=document.getElementById("root");if(!od)throw Error("Root element not found");(0,a.createRoot)(od).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),s=(0,i.useMemo)(()=>{let A=new eF({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 s.checkStatus();e(A)}catch(A){console.error("Failed to check server status:",A),e(!1)}};A();let t=setInterval(A,5e3);return()=>clearInterval(t)},[s]),(0,i.useEffect)(()=>{let A=()=>{a(window.innerWidth<=1024)};return A(),window.addEventListener("resize",A),()=>window.removeEventListener("resize",A)},[]),A)?(0,n.jsx)(or.ZP,{theme:eY(),children:(0,n.jsx)(ot.Z,{className:"app-container playground-container",children:(0,n.jsx)(ol,{className:"app-content",children:(0,n.jsxs)(oo.eh,{autoSaveId:"playground-layout",direction:o?"vertical":"horizontal",children:[(0,n.jsx)(oo.s_,{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)(e_,{}),(0,n.jsx)(tm,{showTooltipWhenEmpty:!1,showModelName:!1})]})}),(0,n.jsx)("div",{className:"playground-panel-playground",children:(0,n.jsx)(oe,{playgroundSDK:s,config:{showContextPreview:!1,layout:"vertical",showVersionInfo:!0,enableScrollToBottom:!0,serverMode:!0,showEnvConfigReminder:!0},branding:{title:"Playground",version:"0.30.7"},className:"playground-container"})})]})}),(0,n.jsx)(oo.OT,{className:`panel-resize-handle ${o?"vertical":"horizontal"}`}),(0,n.jsx)(oo.s_,{className:"app-panel right-panel",children:(0,n.jsx)("div",{className:"panel-content right-panel-content",children:(0,n.jsx)(oa,{playgroundSDK:s,serverOnline:A,isUserOperating:t})})})]})})})}):(0,n.jsx)(or.ZP,{theme:eY(),children:(0,n.jsx)("div",{className:"server-offline-container",children:(0,n.jsxs)("div",{className:"server-offline-message",children:[(0,n.jsx)(e_,{}),(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:os,className:"icon-foreground",alt:""})]}),(0,n.jsx)("h1",{children:"Midscene Playground"}),(0,n.jsx)("p",{className:"connection-status",children:"Server offline..."})]})]})})})},{})}))},66460:function(A){if("undefined"==typeof sharp){var e=Error("Cannot find module 'sharp'");throw e.code="MODULE_NOT_FOUND",e}A.exports=sharp},86110:function(){},58241:function(){},32176:function(){},13527:function(){},64849:function(){},51114:function(){},6156:function(){},41037:function(){},35665:function(){},6281:function(){},39229:function(){},40924:function(){},87333:function(){},15787:function(){},5460:function(){},61546:function(){},18113:function(){},5174:function(){}},e={};function t(r){var o=e[r];if(void 0!==o)return o.exports;var n=e[r]={id:r,loaded:!1,exports:{}};return A[r].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}t.m=A,t.n=A=>{var e=A&&A.__esModule?()=>A.default:()=>A;return t.d(e,{a:e}),e},(()=>{var A,e=Object.getPrototypeOf?A=>Object.getPrototypeOf(A):A=>A.__proto__;t.t=function(r,o){if(1&o&&(r=this(r)),8&o||"object"==typeof r&&r&&(4&o&&r.__esModule||16&o&&"function"==typeof r.then))return r;var n=Object.create(null);t.r(n);var i={};A=A||[null,e({}),e([]),e(e)];for(var a=2&o&&r;"object"==typeof a&&!~A.indexOf(a);a=e(a))Object.getOwnPropertyNames(a).forEach(A=>{i[A]=()=>r[A]});return i.default=()=>r,t.d(n,i),n}})(),t.d=(A,e)=>{for(var r in e)t.o(e,r)&&!t.o(A,r)&&Object.defineProperty(A,r,{enumerable:!0,get:e[r]})},t.f={},t.e=A=>Promise.all(Object.keys(t.f).reduce((e,r)=>(t.f[r](A,e),e),[])),t.u=A=>"static/js/async/"+A+"."+({173:"9cf6b074",212:"e243c338",290:"dd04c2bc",329:"f888b505",364:"1821e74b",544:"b73fa603",582:"5dccae2d",624:"45ee2b2c",644:"6bdc4065",702:"60261735",920:"7d9a9aa8",983:"8b91303f"})[A]+".js",t.miniCssF=A=>""+A+".css",t.g=(()=>{if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(A){if("object"==typeof window)return window}})(),t.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),(()=>{var A={},e="playground:";t.l=function(r,o,n,i){if(A[r])return void A[r].push(o);if(void 0!==n)for(var a,s,l=document.getElementsByTagName("script"),d=0;d<l.length;d++){var c=l[d];if(c.getAttribute("src")==r||c.getAttribute("data-webpack")==e+n){a=c;break}}a||(s=!0,(a=document.createElement("script")).charset="utf-8",a.timeout=120,t.nc&&a.setAttribute("nonce",t.nc),a.setAttribute("data-webpack",e+n),a.src=r),A[r]=[o];var u=function(e,t){a.onerror=a.onload=null,clearTimeout(g);var o=A[r];if(delete A[r],a.parentNode&&a.parentNode.removeChild(a),o&&o.forEach(function(A){return A(t)}),e)return e(t)},g=setTimeout(u.bind(null,void 0,{type:"timeout",target:a}),12e4);a.onerror=u.bind(null,a.onerror),a.onload=u.bind(null,a.onload),s&&document.head.appendChild(a)}})(),t.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})},t.nmd=A=>(A.paths=[],A.children||(A.children=[]),A),(()=>{var A=[];t.O=(e,r,o,n)=>{if(r){n=n||0;for(var i=A.length;i>0&&A[i-1][2]>n;i--)A[i]=A[i-1];A[i]=[r,o,n];return}for(var a=1/0,i=0;i<A.length;i++){for(var[r,o,n]=A[i],s=!0,l=0;l<r.length;l++)(!1&n||a>=n)&&Object.keys(t.O).every(A=>t.O[A](r[l]))?r.splice(l--,1):(s=!1,n<a&&(a=n));if(s){A.splice(i--,1);var d=o();void 0!==d&&(e=d)}}return e}})(),t.p="/",(()=>{t.b=document.baseURI||self.location.href;var A={980:0};t.f.j=function(e,r){var o=t.o(A,e)?A[e]:void 0;if(0!==o)if(o)r.push(o[2]);else{var n=new Promise((t,r)=>o=A[e]=[t,r]);r.push(o[2]=n);var i=t.p+t.u(e),a=Error();t.l(i,function(r){if(t.o(A,e)&&(0!==(o=A[e])&&(A[e]=void 0),o)){var n=r&&("load"===r.type?"missing":r.type),i=r&&r.target&&r.target.src;a.message="Loading chunk "+e+" failed.\n("+n+": "+i+")",a.name="ChunkLoadError",a.type=n,a.request=i,o[1](a)}},"chunk-"+e,e)}},t.O.j=e=>0===A[e];var e=(e,r)=>{var o,n,[i,a,s]=r,l=0;if(i.some(e=>0!==A[e])){for(o in a)t.o(a,o)&&(t.m[o]=a[o]);if(s)var d=s(t)}for(e&&e(r);l<i.length;l++)n=i[l],t.o(A,n)&&A[n]&&A[n][0](),A[n]=0;return t.O(d)},r=self.webpackChunkplayground=self.webpackChunkplayground||[];r.forEach(e.bind(null,0)),r.push=e.bind(null,r.push.bind(r))})();var r=t.O(void 0,["361","657"],function(){return t(69921)});r=t.O(r)})();
|
|
21
|
-
//# sourceMappingURL=index.
|
|
20
|
+
`,loading:!1,result:void 0,replayScriptsInfo:null,replayCounter:0,loadingProgressText:"",verticalMode:!1},tN={result:void 0,dump:null,reportHTML:null,error:null};t(28977);let tP="",tx="";function tw(A){return A.subType&&"Plan"!==A.subType?`${A.type} / ${A.subType||""}`:A.type}function tK(A){if(!A)return"";if("string"==typeof A)return A;if("object"==typeof A){if("string"==typeof A.prompt)return A.prompt;if("object"==typeof A.prompt&&A.prompt.prompt){let e=A.prompt.prompt,t=A.prompt.images||[];if(0===t.length)return e;let r=t.map(A=>{let e=A.url;return(e.startsWith("data:image/")||e.startsWith("data:")&&e.includes("base64"))&&(e=`${e.substring(0,15)}...`),`[${A.name}](${e})`}).join(", ");return`${e}, ${r}`}}return""}function tj(A){var e,t,r,o,n,i,a,s,l,d,c;let u;if("Planning"===A.type&&(u=null==A||null==(e=A.param)?void 0:e.userInstruction),"Insight"===A.type&&(u=tK(null==A?void 0:A.param)||(null==A||null==(t=A.param)?void 0:t.id)||(null==A||null==(r=A.param)?void 0:r.dataDemand)||(null==A||null==(o=A.param)?void 0:o.assertion)),"Action"===A.type){let e=null==A?void 0:A.locate,t=e?tK(e):"";(u=A.thought||"","number"==typeof(null==A||null==(n=A.param)?void 0:n.timeMs))?u=`${null==A||null==(l=A.param)?void 0:l.timeMs}ms`:"string"==typeof(null==A||null==(i=A.param)?void 0:i.scrollType)?u=(c=null==A?void 0:A.param)?`${c.direction||"down"}, ${c.scrollType||"once"}, ${c.distance||"distance-not-set"}`:"":"string"==typeof(null==A||null==(a=A.param)?void 0:a.direction)&&(null==A?void 0:A.subType)==="AndroidPull"?u=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==(s=A.param)?void 0:s.value)&&(u=null==A||null==(d=A.param)?void 0:d.value),t&&(u=u?`${t} - ${u}`:t)}return void 0===u?"":"string"==typeof u?u:"object"==typeof u&&tK(u)?tK(u):JSON.stringify(u,void 0,2)}er("ai:insight"),t(15787),t(5460),t(57861).Buffer,t(73656),t(87333),t(81507),t(73656),er("web:tool:profile"),t(57861).Buffer,er("cache"),er("device-task-executor"),er("agent"),["read-only","read-write","write-only"].map(A=>`"${A}"`).join(", ");let tz=(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 tB(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class tM{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){tB(this,"dbPromise",void 0),tB(this,"dbName",void 0),tB(this,"version",void 0),tB(this,"storeConfigs",void 0),this.dbName=A,this.version=e,this.storeConfigs=t,this.dbPromise=this.initDB()}}let tZ=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}},tT=(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 tQ(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let tO="playground_messages",tD="playground_results";class tX{async saveMessages(A){await tZ(async()=>{await this.dbManager.clear(tO);let e=A.slice(-100);await Promise.all(e.map((A,e)=>{let t={...A,result:void 0},r={id:A.id||`msg-${e}`,data:t,timestamp:A.timestamp?A.timestamp.getTime():Date.now()+e};return this.dbManager.put(tO,r)}))},"Failed to save messages to IndexedDB",void 0,this.messagesCleanup)}async loadMessages(){return await tZ(async()=>{let A=await this.dbManager.getAll(tO,!0);return 0===A.length?[]:Promise.all(A.map(async A=>{let e=A.data,t={...e,timestamp:new Date(e.timestamp)};if("result"===e.type&&e.id){let A=await this.loadResult(e.id);A&&(t.result=A.result,t.replayScriptsInfo=A.replayScriptsInfo,t.replayCounter=A.replayCounter,t.verticalMode=A.verticalMode)}return t}))},"Failed to load messages from IndexedDB",[],this.messagesCleanup)||[]}async clearMessages(){await tZ(async()=>{await Promise.all([this.dbManager.clear(tO),this.dbManager.clear(tD)])},"Failed to clear messages from IndexedDB")}async saveResult(A,e){await tZ(async()=>{let t=this.compressResultForStorage(e),r={id:A,data:t,timestamp:Date.now(),size:JSON.stringify(t).length};await this.dbManager.put(tD,r)},"Failed to save result to IndexedDB",void 0,this.resultsCleanup)}async loadResult(A){return await tZ(async()=>{let e=await this.dbManager.get(tD,A);return(null==e?void 0:e.data)||null},"Failed to load result from IndexedDB",null)||null}compressResultForStorage(A){var e,t;if(!(null==(t=A.result)||null==(e=t.dump)?void 0:e.executions))return A;let r=A.result.dump.executions.map(A=>{var e;return{...A,tasks:(null==(e=A.tasks)?void 0:e.map(A=>{var e,t;return{...A,uiContext:A.uiContext?{...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=>({...A,screenshot:this.compressScreenshotIfNeeded(A.screenshot)}))}}))||[]}});return{...A,result:{...A.result,dump:{...A.result.dump,executions: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}async getStorageStats(){return await tZ(async()=>{let[A,e]=await Promise.all([this.dbManager.count(tO),this.dbManager.count(tD)]);return{messageCount:A,resultCount:e}},"Failed to get storage statistics",{messageCount:0,resultCount:0})||{messageCount:0,resultCount:0}}async cleanup(){await Promise.all([this.messagesCleanup(),this.resultsCleanup()])}constructor(A="playground"){tQ(this,"dbManager",void 0),tQ(this,"namespace",void 0),tQ(this,"messagesCleanup",void 0),tQ(this,"resultsCleanup",void 0),this.namespace=A,this.dbManager=new tM(`midscene_playground_${A}`,1,[{name:tO,keyPath:"id"},{name:tD,keyPath:"id"}]),this.messagesCleanup=tT(this.dbManager,tO,100),this.resultsCleanup=tT(this.dbManager,tD,50)}}function tJ(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}class tU{checkStorageSpace(){try{let A="storage-test",e="x".repeat(102400);return localStorage.setItem(A,e),localStorage.removeItem(A),!0}catch(A){return!1}}async saveMessages(A){try{this.checkStorageSpace()||(console.warn("Low storage space detected, clearing old data..."),await this.handleQuotaExceeded());let e=A.slice(-this.maxStorageItems).map(A=>({...A,result:void 0})),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..."),await this.handleQuotaExceeded();try{let e=A.slice(-10).map(A=>({...A,result:void 0})),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),await this.clearMessages()}}else console.error("Failed to save messages to localStorage:",e)}}async loadMessages(){try{let A=localStorage.getItem(this.messagesKey);if(!A)return[];let e=JSON.parse(A);return await Promise.all(e.map(async A=>{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{...A,...e}}catch(A){console.warn("Failed to parse stored result:",A)}}return A}))}catch(A){return console.error("Failed to load messages from localStorage:",A),[]}}async clearMessages(){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)}}async saveResult(A,e){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..."),await 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)}}async handleQuotaExceeded(){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)}}constructor(A="playground"){tJ(this,"messagesKey",void 0),tJ(this,"resultsKey",void 0),tJ(this,"maxStorageItems",50),this.messagesKey=`${A}-messages`,this.resultsKey=`${A}-results`}}class tL{async saveMessages(A){this.messages=[...A]}async loadMessages(){return[...this.messages]}async clearMessages(){this.messages=[],this.results.clear()}async saveResult(A,e){this.results.set(A,e)}constructor(){tJ(this,"messages",[]),tJ(this,"results",new Map)}}class tV{async saveMessages(A){}async loadMessages(){return[]}async clearMessages(){}async saveResult(A,e){}}function tG(){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 tX(e);return console.warn("IndexedDB not available, falling back to localStorage"),tG("localStorage",e);case"localStorage":if("undefined"!=typeof localStorage)return new tU(e);return console.warn("localStorage not available, falling back to memory storage"),tG("memory",e);case"memory":return new tL;case"none":return new tV;default:throw Error(`Unknown storage type: ${A}`)}}function tq(){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"}t(83264);var tF=t(94152),tW=t(15284),tH=t(8811);let tY=(A,e,t)=>{let r,{left:o,top:n,width:i,height:a}=A;r="element"===t?eW[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)%eW.length]:"searchArea"===t?eH("searchArea"):eH("element");let s=new tW.TCu;if(s.beginFill(r,.4),s.lineStyle(1,r,1),s.drawRect(o,n,i,a),s.endFill(),s.filters=[new tH.pt({blur:2,quality:3,alpha:.4,offset:{x:4,y:4},color:3355443})],!e)return[s];let l=new tW.xvT(e,{fontSize:18,fill:0});return l.x=o,l.y=Math.max(n-22,0),[s,l]},t_=A=>{let e=A.highlightElements||[],t=e.map(A=>A.id),r=A.highlightRect,o=A.highlightPoints,a=A.uiContext,{size:s,screenshotBase64:l}=a,d=s.width,c=s.height,u=(0,i.useRef)(null),g=(0,i.useMemo)(()=>new tW.MxU,[]),[p,m]=(0,i.useState)(!1),E=(0,i.useMemo)(()=>new tW.W20,[]),f=(0,i.useMemo)(()=>new tW.W20,[]),[h,y]=(0,i.useState)(null),v=(0,i.useRef)(void 0),{backgroundVisible:C,setBackgroundVisible:k,elementsVisible:I,setElementsVisible:S}=to();(0,i.useEffect)(()=>(Promise.resolve((async()=>{if(!u.current||!d)return;await g.init({width:d,height:c,background:0xffffff});let A=u.current;u.current.appendChild(g.canvas);let{clientWidth:e}=u.current.parentElement,t=.6*window.innerHeight;if(d/c<=e/t){let e=t/c;A.style.width=`${Math.floor(d*e)}px`,A.style.height=`${Math.floor(c*e)}px`}g.stage.addChild(E),g.stage.addChild(f),m(!0)})()),()=>{console.log("will destroy");try{g.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}),[g,d,c]),(0,i.useEffect)(()=>p?(g.stage.eventMode="static",g.stage.hitArea=new tW.AeJ(0,0,d,c),g.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==g||null==(A=g.stage)||A.off("click")}):void 0,[p,A.onCanvasClick,d,c]),(0,i.useEffect)(()=>{if(!p)return;let A=new Image;A.onload=()=>{if(!g.stage)return;let e=tW.xEZ.from(A),t=new tW.jyi(e);t.x=0,t.y=0,t.width=d,t.height=c,t.eventMode="passive",g.stage.addChildAt(t,0),v.current=t,t.visible=C},A.onerror=A=>{console.error("load screenshot failed",A)},A.src=l},[g.stage,p,d,c]);let{highlightElementRects:R}=(0,i.useMemo)(()=>{if(E.removeChildren(),f.removeChildren(),E.eventMode="passive",f.eventMode="passive",r){let[A]=tY(r,"Search Area","searchArea");E.addChild(A)}return e.length&&e.forEach(A=>{let{rect:e,content:t,id:r}=A,[o]=tY(e,t,"highlight");E.addChild(o)}),(null==o?void 0:o.length)&&o.forEach(A=>{let e=((A,e)=>{let[t,r]=A,o=eH("element"),n=new tW.TCu;return n.beginFill(o,.4),n.drawCircle(t,r,10),n.endFill(),n})(A,0);E.addChild(e)}),eS(a.tree).forEach(A=>{let{rect:e,content:r,id:o}=A;if(t.includes(o)||(null==h?void 0:h.id)===o)return;let[n]=tY(e,r,"element");f.addChild(n)}),f.visible=I,{highlightElementRects:[]}},[g,p,e,a.tree,h,r,o]),b=null;return 1===R.length?b=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(R[0])]})}):R.length>1&&(b=(0,n.jsx)("div",{className:"bottom-tip",children:(0,n.jsxs)("div",{className:"bottom-tip-item",children:["Element: ",JSON.stringify(R)]})})),(0,n.jsxs)("div",{className:"blackboard",children:[(0,n.jsx)("div",{className:"blackboard-main-content",style:{width:"100%"},ref:u}),(0,n.jsx)("div",{className:"blackboard-filter",style:{display:A.hideController?"none":"block"},children:(0,n.jsxs)("div",{className:"overlay-control",children:[(0,n.jsx)(tF.Z,{checked:C,onChange:A=>{k(A.target.checked),v.current&&(v.current.visible=A.target.checked)},children:"Background"}),(0,n.jsx)(tF.Z,{checked:I,onChange:A=>{S(A.target.checked),f.visible=A.target.checked},children:"Elements"})]})}),(0,n.jsx)("div",{className:"bottom-tip",style:{display:A.hideController?"none":"block"},children:b})]})};var t$=t(94249),t0=t(9308),t1=t(32110),t3=t(10195),t5=t(18599),t7=t(34949),t2=t(349),t9=t(7193);let t6=A=>{let{text:e,disabled:t=!1,speed:r=5,className:o=""}=A,i={"--animation-duration":`${r}s`};return(0,n.jsx)("div",{className:`shiny-text ${t?"disabled":""} ${o}`,style:i,children:e})},t8=(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"})]}),t4=function(){let A=arguments.length>0&&void 0!==arguments[0]?arguments[0]:t8;return(0,n.jsx)("div",{className:"server-tip",children:(0,n.jsx)(t9.Z,{message:"Playground Server Not Ready",description:A,type:"warning"})})},rA=(0,n.jsx)("div",{className:"result-empty-tip",style:{textAlign:"center"},children:(0,n.jsx)(t6,{disabled:!0,text:"The result will be shown here"})});var re=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 rt=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)(t_,{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)(t$.Z,{})});case"finishedWithWarning":return(0,n.jsx)("span",{style:{color:"#f7bb05"},children:(0,n.jsx)(t0.Z,{})});case"failed":case"closed":case"timedOut":case"interrupted":return(0,n.jsx)("span",{style:{color:"#FF0A0A"},children:(0,n.jsx)(t1.Z,{})});case"pending":return(0,n.jsx)(t3.Z,{});case"cancelled":case"skipped":return(0,n.jsx)(t5.Z,{});case"running":return(0,n.jsx)(t7.Z,{});default:return(0,n.jsx)(t2.Z,{})}})("failed")," No UI context",(0,n.jsx)(tk.ZP,{type:"link",onClick:A=>{A.preventDefault(),t(re)},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 rr=t(73654);let ro=A=>{let{className:e=""}=A,{config:t}=tg();return Object.keys(t||{}).length>=1?null:(0,n.jsxs)("div",{className:`env-config-reminder ${e}`,children:[(0,n.jsx)(rr.Z,{className:"reminder-icon"}),(0,n.jsx)("span",{className:"reminder-text",children:"Please set up your environment variables before using."}),(0,n.jsx)(tp,{mode:"text",showTooltipWhenEmpty:!1})]})};var rn=t(70223),ri=t(11322),ra=t(50408),rs=t(94878),rl=t(70788),rd=t(64008);let rc=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:(0,n.jsx)("path",{fill:"#333",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"})}),ru=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:[(0,n.jsx)("path",{stroke:"#333",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:"#333",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"})]}),rg=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:16,height:16,fill:"none",viewBox:"0 0 16 16",...A,children:(0,n.jsx)("path",{fill:"#333",d:"M13 1.835a2.165 2.165 0 0 1 .665 4.225v3.88a2.166 2.166 0 1 1-2.725 2.725H5.06a2.165 2.165 0 1 1-2.725-2.726V6.06A2.165 2.165 0 1 1 5.06 3.336h5.88c.281-.87 1.097-1.5 2.06-1.5m-10 9.33a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m-7.94-6.5A2.17 2.17 0 0 1 3.665 6.06v3.88c.66.213 1.181.734 1.395 1.395h5.88a2.17 2.17 0 0 1 1.395-1.396V6.06a2.17 2.17 0 0 1-1.395-1.394zM3 3.165a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67m10 0a.835.835 0 1 0 0 1.67.835.835 0 0 0 0-1.67"})}),rp=new Map,rm=async A=>{if(!rp.has(A))return tW.deM.load(A).then(e=>{rp.set(A,e)})},rE=A=>rp.get(A);function rf(A,e,t){return e in A?Object.defineProperty(A,e,{value:t,enumerable:!0,configurable:!0,writable:!0}):A[e]=t,A}let rh=A=>ry(A),ry=A=>A,rv=A=>new Promise(e=>setTimeout(e,A)),rC="frame cancel (this is an error on purpose)";class rk{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)},this.mediaRecorder=A,this.recording=!0,this.mediaRecorder.start()}stop(){var A;if(!this.recording||!this.mediaRecorder)return void console.warn("not recording");this.mediaRecorder.onstop=()=>{let A=new Blob(this.chunks,{type:"video/webm"}),e=URL.createObjectURL(A),t=document.createElement("a");t.href=e,t.download="midscene_replay.webm",t.click(),URL.revokeObjectURL(e)},null==(A=this.mediaRecorder)||A.stop(),this.recording=!1,this.mediaRecorder=null}constructor(A){rf(this,"canvas",void 0),rf(this,"mediaRecorder",null),rf(this,"chunks",void 0),rf(this,"recording",!1),this.canvas=A,this.chunks=[]}}function rI(A){var e;let t,[r,o]=(0,i.useState)(""),[a,s]=(0,i.useState)(""),{autoZoom:l,setAutoZoom:d,elementsVisible:c,setElementsVisible:u}=to();(0,i.useEffect)(()=>{(null==A?void 0:A.autoZoom)!==void 0&&d(A.autoZoom)},[null==A?void 0:A.autoZoom,d]),(0,i.useEffect)(()=>{(null==A?void 0:A.elementsVisible)!==void 0&&u(A.elementsVisible)},[null==A?void 0:A.elementsVisible,u]);let g=null==A?void 0:A.replayScripts,p=(null==A?void 0:A.imageWidth)||1920,m=(null==A?void 0:A.imageHeight)||1080,E=(null==A?void 0:A.fitMode)||"height",f=(0,i.useRef)((null==g||null==(e=g[0])?void 0:e.img)||null),h=(0,i.useRef)(null),y=(0,i.useMemo)(()=>new tW.MxU,[]),v=(0,i.useRef)(null),C=(0,i.useRef)(null),[k,I]=(0,i.useState)(0),S=()=>{I(Date.now())},R=(0,i.useMemo)(()=>new tW.W20,[]),b=(0,i.useMemo)(()=>{let A=new tW.W20;return A.zIndex=1,A},[]);(0,i.useEffect)(()=>{b.visible=c},[c,b]);let N={left:0,top:0,width:p,pointerLeft:Math.round(p/2),pointerTop:Math.round(m/2)},[P,x]=(0,i.useState)(-1),w=(0,i.useRef)(!1);(0,i.useEffect)(()=>(w.current=!1,()=>{w.current=!0}),[]);let K=(0,i.useRef)({...N}),j=async(A,e)=>{if(y.screen.width!==A||y.screen.height!==e){if(y.renderer.resize(A,e),h.current){let t=A/e;h.current.style.setProperty("--canvas-aspect-ratio",t.toString())}K.current={left:0,top:0,width:A,pointerLeft:Math.round(A/2),pointerTop:Math.round(e/2)}}},z=async(A,e)=>{let t=f.current;if(!t)return void console.warn("no image to update");let r=A||p,o=e||m;await j(r,o),rE(t)||(console.warn("image not loaded",t),await rm(t));let n=rE(t);if(!n)throw Error("texture not found");let i=tW.jyi.from(n);if(!i)throw Error("sprite not found");let a="main-img",s=R.getChildByLabel(a);s&&R.removeChild(s),i.label=a,i.zIndex=0,i.width=r,i.height=o,R.addChild(i)},B=A=>{var e,t;let r;C.current||(C.current=tW.jyi.from(tx),C.current.zIndex=3,C.current.anchor.set(.5,.5),C.current.scale.set(.5),C.current.label="spinning-pointer"),C.current.x=(null==(e=v.current)?void 0:e.x)||0,C.current.y=(null==(t=v.current)?void 0:t.y)||0,R.addChild(C.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;C.current&&(C.current.rotation=t),A(n)};return A(n),()=>{C.current&&R.removeChild(C.current),o=!0}},M=async(A,e,t)=>{var r,o;rE(A)||(console.warn("image not loaded",A),await rm(A));let n=rE(A);if(!n)throw Error("texture not found");let i=tW.jyi.from(n),a=null==(r=v.current)?void 0:r.x,s=null==(o=v.current)?void 0:o.y;if("number"==typeof e&&(a=e),"number"==typeof t&&(s=t),void 0===a||void 0===s)return void console.warn("invalid pointer position",e,t);if(v.current){let A=R.getChildByLabel("pointer");A&&R.removeChild(A)}v.current=i,v.current.x=a,v.current.y=s,v.current.label="pointer",v.current.zIndex=2,R.addChild(v.current)},Z=(A,e)=>{K.current=A;let t=e||y.screen.width||p,r=l?Math.max(1,t/A.width):1;R.scale.set(r),R.x=l?Math.round(0-A.left*r):0,R.y=l?Math.round(0-A.top*r):0;let o=R.getChildByLabel("pointer");o&&(o.scale.set(1/r),"number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(o.x=A.pointerLeft,o.y=A.pointerTop))},T=async(A,e,t)=>{let r=y.screen.width||p,o=y.screen.height||m;if(!l){let o={...K.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;await new Promise(s=>{let l=d=>{let c=d-a,u=rh(Math.min(c/e,1));Z({...o,pointerLeft:n+(A.pointerLeft-n)*u,pointerTop:i+(A.pointerTop-i)*u},r),c<e?t(l):s()};t(l)});return}let n={...K.current},i=n.left,a=n.top,s=n.pointerLeft,d=n.pointerTop,c=n.width/r,u=performance.now(),g="number"==typeof A.pointerLeft&&"number"==typeof A.pointerTop&&(A.pointerLeft!==s||A.pointerTop!==d),E=g?.375*e:0,f=e-E;await new Promise(n=>{let l=p=>{let m={...K.current},h=p-u;if(g)if(h<=E){let e=rh(Math.min(h/E,1));m.pointerLeft=s+(A.pointerLeft-s)*e,m.pointerTop=d+(A.pointerTop-d)*e}else m.pointerLeft=A.pointerLeft,m.pointerTop=A.pointerTop;if(h>E){let e=ry(Math.min((h-E)/f,1)),t=c+(A.width/r-c)*e,n=r*t;m.width=n;let s=i+(A.left-i)*e,l=a+(A.top-a)*e,d=s+n-r,u=l+o*t-o;m.left=d>0?s+d:s,m.top=u>0?l+u:l}Z(m,r),h<e?t(l):n()};t(l)})},Q=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 s=a-n,l=Math.min(s/e,1);A.alpha=0===r?1-ry(l):ry(l),s<e?t(i):o()};t(i)})},O=async(A,e,t)=>Q(A,e,t,0),D=async(A,e,t,r,o)=>{b.removeChildren();let n=[...A],i=n.length,a=0;await new Promise(A=>{let s=performance.now(),l=d=>{let c=d-s,u=Math.floor(((A,e,t,r,o)=>{let n=1-A;return e*n*n*n+3*t*A*n*n+3*r*A*A*n+o*A*A*A})(Math.min(c/r,1),0,.5,.5,1)*i);for(;a<u;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0];if(e){let[A]=tY(e.rect,e.content,"element");A.alpha=0,b.addChild(A),a++,Q(A,80,o)}}if(c<r)o(l);else{for(;n.length>0;){let A=Math.floor(Math.random()*n.length),e=n.splice(A,1)[0],[t]=tY(e.rect,e.content,"element");t.alpha=1,b.addChild(t)}if(t){let[A]=tY(t,"Search Area","searchArea");A.alpha=1,b.addChild(A)}e.map(A=>{let[e]=tY(A.rect,A.content||"","highlight");e.alpha=1,b.addChild(e)}),A()}};o(l)})},X=async()=>{h.current&&g&&(await y.init({width:p,height:m,background:0xf4f4f4,autoDensity:!0,antialias:!0}),h.current&&(h.current.appendChild(y.canvas),R.x=0,R.y=0,y.stage.addChild(R),b.x=0,b.y=0,R.addChild(b)))},[J,U]=(0,i.useState)(!1),L=(0,i.useRef)(null);(0,i.useEffect)(()=>(Promise.resolve((async()=>{if(await X(),h.current&&p&&m){let A=p/m;h.current.style.setProperty("--canvas-aspect-ratio",A.toString()),h.current.setAttribute("data-fit-mode",E);let e=h.current.closest(".player-container");e&&e.setAttribute("data-fit-mode",E)}S()})()),()=>{try{y.destroy(!0,{children:!0,texture:!0})}catch(A){console.warn("destroy failed",A)}}),[p,m,E]),(0,i.useEffect)(()=>{if(k){let A;return Promise.resolve((async()=>{let e;if(!y)throw Error("app is not initialized");if(!g)throw Error("scripts is required");let{frame:t,cancel:r,timeout:n}=(e=!1,{frame:A=>{if(e)throw Error(rC);requestAnimationFrame(()=>{if(e)throw Error(rC);A(performance.now())})},timeout:(A,t)=>{if(e)throw Error(rC);setTimeout(()=>{if(e)throw Error(rC);A()},t)},cancel:()=>{e=!0}});A=r;let i=g.filter(A=>!!A.img).map(A=>A.img);await Promise.all([...i,tx,tP].map(rm)),b.removeChildren(),await M(tP,p/2,m/2),await z(),await Z({...N});let a=g.reduce((A,e)=>A+e.duration+(e.camera&&e.insightCameraDuration?e.insightCameraDuration:0),0),l=performance.now();x(0);let d=()=>{let A=Math.min((performance.now()-l)/a,1);if(x(A),A<1)return n(d,200)};for(let A in t(d),L.current&&L.current.start(),g){let e=g[A];if(o(e.title||""),s(e.subTitle||""),"sleep"===e.type)await rv(e.duration);else if("insight"===e.type){var c;if(!e.img)throw Error("img is required");f.current=e.img,await z(e.imageWidth,e.imageHeight);let A=(null==(c=e.context)?void 0:c.tree)?eS(e.context.tree):[],r=e.highlightElement?[e.highlightElement]:[];if(await D(A,r,e.searchArea,e.duration,t),e.camera){if(!e.insightCameraDuration)throw Error("insightCameraDuration is required");await T(e.camera,e.insightCameraDuration,t)}}else if("clear-insight"===e.type)await O(b,e.duration,t),b.removeChildren(),b.alpha=1;else if("img"===e.type)e.img&&e.img!==f.current&&(f.current=e.img,await z(e.imageWidth,e.imageHeight)),e.camera?await T(e.camera,e.duration,t):await rv(e.duration);else if("pointer"===e.type){if(!e.img)throw Error("pointer img is required");await M(e.img)}else if("spinning-pointer"===e.type){let A=B(t);await rv(e.duration),A()}}L.current&&(await rv(1200),L.current.stop(),L.current=null,U(!1))})().catch(A=>{console.error("player error",A)})),()=>{null==A||A()}}},[k]);let[V,G]=(0,i.useState)(!1),[q,F]=(0,i.useState)(!1),W=Math.round(100*P),H=1===P;(0,i.useEffect)(()=>{if(H){let A=A=>{" "===A.key&&S()};return window.addEventListener("keydown",A),()=>{window.removeEventListener("keydown",A)}}},[H]);let Y=()=>{};return P<1?t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(tf.Z,{spin:!0,color:"#333"}),size:"default"}):V?(t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(ri.Z,{color:"#333"}),size:"default"}),Y=()=>S()):t=(0,n.jsx)(rn.Z,{indicator:(0,n.jsx)(ri.Z,{color:"#333"}),size:"default"}),(0,n.jsxs)("div",{className:"player-container",children:[(0,n.jsx)("div",{className:"canvas-container",ref:h}),(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:`${W}%`,transition:0===P?"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)(e5.Z,{title:a,children:(0,n.jsx)("div",{className:"subtitle",children:a})})]}),J?null:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>G(!0),onMouseLeave:()=>G(!1),onClick:Y,children:t}),(null==A?void 0:A.reportFileContent)?(0,n.jsx)(e5.Z,{title:"Download Report",children:(0,n.jsx)("div",{className:"status-icon",onMouseEnter:()=>G(!0),onMouseLeave:()=>G(!1),onClick:()=>(A=>{let e=new Blob([A],{type:"text/html"}),t=URL.createObjectURL(e),r=document.createElement("a");r.href=t,r.download="midscene_report.html",r.click()})(A.reportFileContent),children:(0,n.jsx)(ra.Z,{color:"#333"})})}):null,(0,n.jsx)(e5.Z,{title:J?"Generating...":"Export Video",children:(0,n.jsx)("div",{className:"status-icon",onClick:J?void 0:()=>L.current?void console.warn("recorderSession exists"):y.canvas?void(L.current=new rk(y.canvas),U(!0),S()):void console.warn("canvas is not initialized"),style:{opacity:J?.5:1,cursor:J?"not-allowed":"pointer"},children:J?(0,n.jsx)(rn.Z,{size:"default",percent:W}):(0,n.jsx)(rs.Z,{})})}),(0,n.jsx)(rl.Z,{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)(rc,{style:{width:"16px",height:"16px"}}),(0,n.jsx)("span",{style:{fontSize:"12px",marginRight:"16px"},children:"Focus on cursor"})]}),(0,n.jsx)(rd.Z,{size:"small",checked:l,onChange:A=>{d(A),S()},onClick:(A,e)=>{var t;return null==e||null==(t=e.stopPropagation)?void 0:t.call(e)}})]})},{key:"elementsVisible",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)(rg,{style:{width:"16px",height:"16px"}}),(0,n.jsx)("span",{style:{fontSize:"12px",marginRight:"16px"},children:"Show element markers"})]}),(0,n.jsx)(rd.Z,{size:"small",checked:c,onChange:A=>{u(A),S()},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:q?1:.7,transition:"opacity 0.2s"},children:(0,n.jsx)(ru,{style:{width:"16px",height:"16px"}})})})]})})})]})}let rS=A=>{let{result:e,loading:t,serverValid:r,serviceMode:o,replayScriptsInfo:i,replayCounter:a,loadingProgressText:s,verticalMode:l=!1,notReadyMessage:d,fitMode:c,autoZoom:u}=A,g="result-wrapper";l&&(g+=" vertical-mode-result"),i&&l&&(g+=" result-wrapper-compact");let p=rA;return r||"Server"!==o?t?p=(0,n.jsxs)("div",{className:"loading-container",children:[(0,n.jsx)(rn.Z,{spinning:t,indicator:(0,n.jsx)(tf.Z,{spin:!0})}),(0,n.jsx)("div",{className:"loading-progress-text loading-progress-text-progress",children:(0,n.jsx)(t6,{text:s,speed:3})})]}):i?p=(0,n.jsx)(rI,{replayScripts:i.scripts,imageWidth:i.width,imageHeight:i.height,reportFileContent:("In-Browser-Extension"===o||"Server"===o)&&(null==e?void 0:e.reportHTML)?null==e?void 0:e.reportHTML:null,fitMode:c,autoZoom:u},a):(null==e?void 0:e.error)?p=(0,n.jsx)("pre",{children:null==e?void 0:e.error}):(null==e?void 0:e.result)!==void 0&&(p="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)})):p=t4(d),(0,n.jsx)("div",{className:g,style:{height:"100%",display:"flex",flexDirection:"column",flex:"1 1 auto",justifyContent:"center"},children:p})},rR=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:20,height:20,fill:"none","aria-label":"Playground",viewBox:"0 0 20 20",...A,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"})]});var rb=t(35725),rN=t(9004),rP=t(13098),rx=t(56984),rw={};rw.d=(A,e)=>{for(var t in e)rw.o(e,t)&&!rw.o(A,t)&&Object.defineProperty(A,t,{enumerable:!0,get:e[t]})},rw.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),rw.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})};var rK={};rw.r(rK),rw.d(rK,{create:()=>e9.Ue});let{create:rj}=rK,rz="midscene-prompt-history-v2",rB="midscene-last-selected-type",rM=rj((A,e)=>({history:(()=>{let A=localStorage.getItem(rz);return A?JSON.parse(A):{}})(),lastSelectedType:localStorage.getItem(rB)||"aiAction",clearHistory:t=>{let r={...e().history};delete r[t],A({history:r}),localStorage.setItem(rz,JSON.stringify(r))},addHistory:t=>{let{type:r}=t,o=e().history,n=o[r]||[],i=JSON.stringify({prompt:t.prompt,params:t.params}),a=[t,...n.filter(A=>JSON.stringify({prompt:A.prompt,params:A.params})!==i)];a.length>10&&(a.length=10);let s={...o,[r]:a};A({history:s}),localStorage.setItem(rz,JSON.stringify(s))},getHistoryForType:A=>e().history[A]||[],setLastSelectedType:e=>{A({lastSelectedType:e}),localStorage.setItem(rB,e)}})),rZ="ZodOptional",rT="ZodDefault",rQ="ZodNullable",rO="ZodObject",rD="midscene_location_field_flag",rX=A=>"object"==typeof A&&null!==A&&("shape"in A||"ZodObject"===A.type),rJ=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&&rD 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},rU=A=>{var e,t,r,o,n;let i=A,a=!1,s=!1;for(;(null==(e=i._def)?void 0:e.typeName)===rZ||(null==(t=i._def)?void 0:t.typeName)===rT||(null==(r=i._def)?void 0:r.typeName)===rQ;)(null==(o=i._def)?void 0:o.typeName)===rZ&&(a=!0),(null==(n=i._def)?void 0:n.typeName)===rT&&(s=!0),i=i._def.innerType||i;return{actualField:i,isOptional:a,hasDefault:s}};eR.z.object({locate:ej.describe("The element to be tapped")}),eR.z.object({locate:ej.describe("The element to be right clicked")}),eR.z.object({locate:ej.describe("The element to be double clicked")}),eR.z.object({locate:ej.describe("The element to be hovered")}),eR.z.object({value:eR.z.union([eR.z.string(),eR.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:ej.describe("The element to be input").optional(),mode:eR.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.')}),eR.z.object({locate:ej.describe("The element to be clicked before pressing the key").optional(),keyName:eR.z.string().describe("The key to be pressed. Use '+' for key combinations, e.g., 'Control+A', 'Shift+Enter'")}),eR.z.object({direction:eR.z.enum(["down","up","right","left"]).default("down").describe("The direction to scroll"),scrollType:eR.z.enum(["once","untilBottom","untilTop","untilRight","untilLeft"]).default("once").describe("The scroll type"),distance:eR.z.number().nullable().optional().describe("The distance in pixels to scroll"),locate:ej.optional().describe("The element to be scrolled")}),eR.z.object({from:ej.describe("The position to be dragged"),to:ej.describe("The position to be dropped")}),eR.z.object({locate:ej.describe("The element to be long pressed"),duration:eR.z.number().default(500).optional().describe("Long press duration in milliseconds")}),eR.z.object({start:ej.optional().describe("Starting point of the swipe gesture, if not specified, the center of the page will be used"),direction:eR.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:eR.z.number().optional().describe("The distance in pixels to swipe (mutually exclusive with end)"),end:ej.optional().describe("Ending point of the swipe gesture (mutually exclusive with distance)"),duration:eR.z.number().default(300).describe("Duration of the swipe gesture in milliseconds"),repeat:eR.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)")}),eR.z.object({locate:ej.describe("The input field to be cleared")});let rL=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},rV=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:27,height:27,fill:"none",viewBox:"0 0 27 27",...A,children:(0,n.jsx)("path",{stroke:"#000",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"})}),rG=A=>{let{showDeepThinkOption:e=!1,enableTracking:t=!1,showDataExtractionOptions:r=!1,hideDomAndScreenshotOptions:o=!1}=A,i=tg(A=>A.forceSameTabNavigation),a=tg(A=>A.setForceSameTabNavigation),s=tg(A=>A.deepThink),l=tg(A=>A.setDeepThink),d=tg(A=>A.screenshotIncluded),c=tg(A=>A.setScreenshotIncluded),u=tg(A=>A.domIncluded),g=tg(A=>A.setDomIncluded);if(!t&&!e&&!r)return null;let p=function(){let A=[];return t&&A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>a(A.target.checked),checked:i,children:"limit popup to current tab"}),key:"track-config"}),e&&A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>{l(A.target.checked)},checked:s,children:"deep think"}),key:"deep-think-config"}),r&&!o&&(A.push({label:(0,n.jsx)(tF.Z,{onChange:A=>{c(A.target.checked)},checked:d,children:"include screenshot in request"}),key:"screenshot-included-config"}),A.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)(rx.ZP.Group,{size:"small",value:u,onChange:A=>g(A.target.value),children:[(0,n.jsx)(rx.ZP,{value:!1,children:"Off"}),(0,n.jsx)(rx.ZP,{value:!0,children:"All"}),(0,n.jsx)(rx.ZP,{value:"visible-only",children:"Visible only"})]})]}),key:"dom-included-config"})),A}();return(0,n.jsx)("div",{className:"selector-trigger",children:(0,n.jsx)(rl.Z,{menu:{items:p},trigger:["click"],children:(0,n.jsx)(rV,{width:24,height:24})})})};var rq=t(43564),rF=t(81053);let{TextArea:rW}=e2.Z,rH=(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)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`Please input ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(e2.Z,{placeholder:a})},e)},r_=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)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`The ${e} is required`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rW,{rows:2,placeholder:a})},e)},r$=A=>{var e;let{name:t,label:r,fieldSchema:o,isRequired:i,marginBottom:a,placeholder:s}=A,l=((null==(e=o._def)?void 0:e.values)||[]).map(A=>({value:A,label:A.charAt(0).toUpperCase()+A.slice(1)}));return(0,n.jsx)(tv.Z.Item,{name:["params",t],label:r,rules:i?[{required:!0,message:`Please select ${t}`}]:[],style:{marginBottom:a},colon:!1,children:(0,n.jsx)(rq.Z,{placeholder:s||`Select ${t}`,options:l})},t)},r0=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A,a=500*("distance"===e),s=i&&Number(i)||a,l="distance"===e?1e4:void 0;return(0,n.jsx)(tv.Z.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)(rF.Z,{placeholder:s.toString(),min:0,max:l,step:"distance"===e?10:1,style:{width:"100%"}})},e)},r1=A=>{let{name:e,label:t,isRequired:r,marginBottom:o,placeholder:i}=A;return(0,n.jsx)(tv.Z.Item,{name:["params",e],label:rH(t,!r),rules:r?[{required:!0,message:`Please select ${e}`}]:[],style:{marginBottom:o},colon:!1,children:(0,n.jsx)(rq.Z,{placeholder:i||`Select ${e}`,options:[{value:!0,label:"True"},{value:!1,label:"False"}]})},e)},r3=A=>(0,n.jsx)("svg",{xmlns:"http://www.w3.org/2000/svg",width:18,height:16,fill:"none",viewBox:"0 0 18 16",...A,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"})}),r5=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:25,height:25,fill:"none",viewBox:"0 0 25 25",...A,children:[(0,n.jsx)("path",{stroke:"#000",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:"#000",strokeLinecap:"round",strokeLinejoin:"round",strokeOpacity:.85,strokeWidth:1.33,d:"M12.695 8.322v4.203l2.967 2.968"})]}),r7=A=>(0,n.jsxs)("svg",{xmlns:"http://www.w3.org/2000/svg",width:19,height:19,fill:"none",viewBox:"0 0 19 19",...A,children:[(0,n.jsxs)("g",{stroke:"#000",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"})})})]}),{Text:r2}=e1.Z,r9=A=>{let{onSelect:e,history:t,currentType:r}=A,[o,a]=(0,i.useState)(!1),[s,l]=(0,i.useState)(""),d=rM(A=>A.clearHistory),c=(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(s.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,s]);(0,i.useEffect)(()=>{if(!o)return;let A=A=>{c.current&&!c.current.contains(A.target)&&a(!1)},e=setTimeout(()=>{document.addEventListener("click",A)},100);return()=>{clearTimeout(e),document.removeEventListener("click",A)}},[o]);let g=(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)(r5,{width:24,height:24})}),o&&(0,n.jsx)("div",{className:"history-modal-overlay",ref:c,children:(0,n.jsxs)("div",{className:"history-modal-container",children:[(0,n.jsxs)("div",{className:"history-modal-header",children:[(0,n.jsxs)(r2,{strong:!0,style:{fontSize:"16px"},children:["History (",t.length,")"]}),(0,n.jsx)(tk.ZP,{size:"small",type:"text",icon:(0,n.jsx)(r3,{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)(e2.Z,{placeholder:"Search",value:s,onChange:A=>l(A.target.value),prefix:(0,n.jsx)(r7,{width:18,height:18}),className:"search-input",allowClear:!0}),(0,n.jsx)(tk.ZP,{type:"link",onClick:()=>{d(r),l(""),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)(r2,{type:"secondary",children:"No history record"})}):(0,n.jsxs)(n.Fragment,{children:[g("Last 7 days",u.recent7Days),g("Last 1 year",u.recent1Year),g("Earlier",u.older),s&&0===u.recent7Days.length&&0===u.recent1Year.length&&0===u.older.length&&(0,n.jsx)("div",{className:"no-results",children:(0,n.jsx)(r2,{type:"secondary",children:"No matching history record"})})]})})]})})]})},{TextArea:r6}=e2.Z,r8=A=>{let{runButtonEnabled:e,form:t,serviceMode:r,selectedType:o,dryMode:a,stoppable:s,loading:l,onRun:d,onStop:c,clearPromptAfterRun:u=!0,actionSpace:g,hideDomAndScreenshotOptions:p=!1}=A,[m,E]=(0,i.useState)(!1),[f,h]=(0,i.useState)(""),y="aiQuery"===o?"What do you want to query?":"aiAssert"===o?"What do you want to assert?":"aiTap"===o?"What element do you want to tap?":"aiDoubleClick"===o?"What element do you want to double-click?":"aiHover"===o?"What element do you want to hover over?":"aiInput"===o?"Format: <value> | <element>\nExample: hello world | search box":"aiRightClick"===o?"What element do you want to right-click?":"aiKeyboardPress"===o?"Format: <key> | <element (optional)>\nExample: Enter | text field":"aiScroll"===o?"Format: <direction> <amount> | <element (optional)>\nExample: down 500 | main content":"aiLocate"===o?"What element do you want to locate?":"aiBoolean"===o?"What do you want to check (returns true/false)?":"aiNumber"===o?"What number do you want to extract?":"aiString"===o?"What text do you want to extract?":"aiAsk"===o?"What do you want to ask?":"aiWaitFor"===o?"What condition do you want to wait for?":"What do you want to do?",v=(0,i.useRef)(null),C=(0,i.useRef)(null),k=tv.Z.useWatch("params",t),I=(0,i.useRef)(null),S=rM(A=>A.history),R=rM(A=>A.lastSelectedType),b=rM(A=>A.addHistory),N=rM(A=>A.setLastSelectedType),P=(0,i.useMemo)(()=>S[o]||[],[S,o]),x=(0,i.useMemo)(()=>{if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);return!!(null==A?void 0:A.paramSchema)&&(!rX(A.paramSchema)||Object.keys(A.paramSchema.shape||{}).length>0)}return!1},[o,g]),w=(0,i.useMemo)(()=>{if(g&&g.length>0){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if(A){if(A.paramSchema&&rX(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{isOptional:t}=rU(e[A]);return!t})}return!!A.paramSchema}}return!0},[o,g]),K=(0,i.useMemo)(()=>["aiQuery","aiBoolean","aiNumber","aiString","aiAsk","aiAssert"].includes(o),[o]),j=(0,i.useMemo)(()=>{if("aiLocate"===o)return!0;if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(A.paramSchema)){let e=A.paramSchema.shape||{};return Object.keys(e).some(A=>{let{actualField:t}=rU(e[A]);return rJ(t)})}}return!1},[o,g]),z=(0,i.useMemo)(()=>{let A=K&&!p;return"In-Browser-Extension"===r||j||A},[r,j,K,p]),B=(0,i.useMemo)(()=>{let A=Object.keys(tS);if(!g||0===g.length)return A;let e=g.map(A=>A.interfaceAlias||A.name),t=new Set;return A.forEach(A=>{let r=tS[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)},[g]),M=(0,i.useCallback)(()=>{if(!x||!g)return{};let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(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{}},[o,x,g]);(0,i.useEffect)(()=>{!t.getFieldValue("type")&&R&&t.setFieldValue("type",R)},[t,R]),(0,i.useEffect)(()=>{o&&o!==R&&N(o)},[o,R,N]);let Z=(0,i.useCallback)(()=>{let A=C.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=P[0];if(!A||!I.current||A.timestamp!==I.current.timestamp)if(A)t.setFieldsValue({type:A.type,prompt:A.prompt||"",params:A.params}),h(A.prompt||""),I.current=A;else{let A=M();t.setFieldsValue({prompt:"",params:A}),h(""),I.current=null}},[o,P,t,M]),(0,i.useEffect)(()=>{let A=setTimeout(()=>{Z()},100);return()=>clearTimeout(A)},[o,Z]);let T=tv.Z.useWatch("prompt",t);(0,i.useEffect)(()=>{T!==f&&h(T||"")},[T,f]);let Q=(0,i.useCallback)(A=>{t.setFieldsValue({prompt:A.prompt,type:A.type,params:A.params}),h(A.prompt)},[t]),O=(0,i.useCallback)(A=>{h(A.target.value)},[]),D=(0,i.useMemo)(()=>{if(!x||!g)return!1;let A=g.find(A=>A.interfaceAlias===o||A.name===o);return!!((null==A?void 0:A.paramSchema)&&rX(A.paramSchema))&&1===Object.keys(A.paramSchema.shape||{}).length},[o,x,g]),X=(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)&&rX(e.paramSchema)){let t=e.paramSchema.shape||{};return Object.keys(t).every(e=>{let{isOptional:r}=rU(t[e]),o=A[e];return r||void 0!==o&&""!==o&&null!==o})}return!0}return n.trim().length>0})(e,!!x,k,g,o,f),[e,x,o,g,f,k]),J=(0,i.useCallback)(()=>{let A=t.getFieldsValue(),e="";if(x&&A.params&&g){let t=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==t?void 0:t.paramSchema)&&rX(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}=rU(n[e]);rJ(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 r={type:A.type,prompt:e,params:A.params,timestamp:Date.now()};if(b(r),d(),u)if(I.current=r,h(""),x){let A=M();t.setFieldValue("params",A)}else t.setFieldValue("prompt","")},[t,b,d,x,o,u,g,M]),U=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&X?(J(),A.preventDefault(),A.stopPropagation()):"Enter"===A.key&&setTimeout(()=>{if(v.current){var A;let e=null==(A=v.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)},[J,X]),L=(0,i.useCallback)(A=>{"Enter"===A.key&&A.metaKey&&X&&(J(),A.preventDefault(),A.stopPropagation())},[J,X]),V=(0,i.useCallback)(()=>{if(!x)return null;if(g){let A=g.find(A=>A.interfaceAlias===o||A.name===o);if((null==A?void 0:A.paramSchema)&&rX(A.paramSchema)){let e=A.paramSchema.shape||{},t=Object.keys(e);if(1===t.length){let A=t[0],{actualField:r}=rU(e[A]),i=rJ(r),a=(()=>{var e,t;if(null==(e=r._def)?void 0:e.description)return r._def.description;if(r.description)return r.description;if(g){let e=g.find(A=>A.interfaceAlias===o||A.name===o);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 i?"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)(tv.Z.Item,{name:["params",A],style:{margin:0},children:(0,n.jsx)(e2.Z.TextArea,{className:"main-side-console-input-textarea",rows:4,placeholder:a,autoFocus:!0,onKeyDown:L})})}let r=[],a=t.sort((A,t)=>{let r=e[A],o=e[t],{isOptional:n}=rU(r),{isOptional:i}=rU(o);return!n&&i?-1:n&&!i?1:0});if(a.forEach((A,t)=>{var i,s,l;let{actualField:d,isOptional:c}=rU(e[A]),u=rJ(d),p=A.charAt(0).toUpperCase()+A.slice(1),m=12*(t!==a.length-1),E=(()=>{var e,t;if(null==(e=d._def)?void 0:e.description)return d._def.description;if(d.description)return d.description;if(g){let e=g.find(A=>A.interfaceAlias===o||A.name===o);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(u)return"Describe the element you want to interact with"})(),f={name:A,label:p,fieldSchema:d,isRequired:!c,marginBottom:m,placeholder:E};u?r.push((0,n.jsx)(r_,{...f},A)):(null==(i=d._def)?void 0:i.typeName)==="ZodEnum"?r.push((0,n.jsx)(r$,{...f},A)):(null==(s=d._def)?void 0:s.typeName)==="ZodNumber"?r.push((0,n.jsx)(r0,{...f},A)):(null==(l=d._def)?void 0:l.typeName)==="ZodBoolean"?r.push((0,n.jsx)(r1,{...f},A)):r.push((0,n.jsx)(rY,{...f},A))}),"aiScroll"===o){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},[o,x,g,L]),G=(0,i.useCallback)(()=>{E(!0)},[]),q=(0,i.useCallback)(()=>{E(!1)},[]),F=(0,i.useCallback)(()=>{let A=A=>(0,n.jsx)(tk.ZP,{type:"primary",icon:(0,n.jsx)(rb.Z,{}),style:{borderRadius:20,zIndex:999},onClick:J,disabled:!X,loading:l,children:A});return a?"aiAction"===o?(0,n.jsx)(e5.Z,{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"):s?(0,n.jsx)(tk.ZP,{icon:(0,n.jsx)(rN.Z,{}),onClick:c,style:{borderRadius:20,zIndex:999},children:"Stop"}):A("Run")},[a,l,J,c,X,o,s]);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:C,children:[(0,n.jsx)(tv.Z.Item,{name:"type",style:{margin:0},children:(0,n.jsx)(rx.ZP.Group,{buttonStyle:"solid",disabled:!e,children:tR.map(A=>{var e;return(0,n.jsx)(e5.Z,{title:(null==(e=tS[A])?void 0:e.title)||"",children:(0,n.jsx)(rx.ZP.Button,{value:A,children:rL(A)})},A)})})}),(0,n.jsx)(rl.Z,{menu:(()=>{let A=B.filter(A=>!tR.includes(A)),e=[],r=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="interaction"});r.length>0&&e.push({key:"interaction-group",type:"group",label:"Interaction APIs",children:r.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let o=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="extraction"});o.length>0&&e.push({key:"extraction-group",type:"group",label:"Data Extraction APIs",children:o.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let n=A.filter(A=>{var e;return(null==(e=tS[A])?void 0:e.group)==="validation"});n.length>0&&e.push({key:"validation-group",type:"group",label:"Validation APIs",children:n.map(A=>{var e;return{key:A,label:rL(A),title:(null==(e=tS[A])?void 0:e.title)||"",onClick:()=>{t.setFieldValue("type",A)}}})});let i=A.filter(A=>!tS[A]);return i.length>0&&e.push({key:"device-specific-group",type:"group",label:"Device-Specific APIs",children:i.map(A=>({key:A,label:rL(A),title:"",onClick:()=>{t.setFieldValue("type",A)}}))}),{items:e}})(),placement:"bottomLeft",trigger:["click"],disabled:!e,children:(0,n.jsxs)(tk.ZP,{className:`more-apis-button ${!tR.includes(o)?"selected-from-dropdown":""}`,children:[o&&!tR.includes(o)?rL(o):"more",(0,n.jsx)(rP.Z,{style:{fontSize:"10px",marginLeft:"2px"}})]})})]}),(0,n.jsxs)("div",{className:"action-icons",children:[z&&(0,n.jsx)("div",{className:m?"settings-wrapper settings-wrapper-hover":"settings-wrapper",onMouseEnter:G,onMouseLeave:q,children:(0,n.jsx)(rG,{enableTracking:"In-Browser-Extension"===r,showDeepThinkOption:j,showDataExtractionOptions:K,hideDomAndScreenshotOptions:p})}),(0,n.jsx)(r9,{onSelect:Q,history:P,currentType:o})]})]}),(0,n.jsxs)("div",{className:`main-side-console-input ${!e?"disabled":""} ${l?"loading":""}`,children:[w?x?D?V():(0,n.jsx)("div",{className:"structured-params-container",children:V()}):(0,n.jsx)(tv.Z.Item,{name:"prompt",style:{margin:0},children:(0,n.jsx)(r6,{className:"main-side-console-input-textarea",disabled:!e,rows:4,placeholder:y,autoFocus:!0,onKeyDown:U,onChange:O,ref:v})}):(0,n.jsxs)("div",{className:"no-input-method",style:{padding:"20px",textAlign:"center",color:"#666",fontSize:"14px"},children:['Click "Run" to execute ',rL(o)]}),(0,n.jsx)("div",{className:"form-controller-wrapper",children:F()})]})]})},{Text:r4}=e1.Z;function oA(A){let{error:e}=A;return e?(0,n.jsxs)(e5.Z,{title:(0,n.jsx)("span",{style:{whiteSpace:"pre-wrap",wordBreak:"break-all"},children:e}),overlayStyle:{maxWidth:"100vw"},children:["Error: ",e.split("\n")[0]]}):null}function oe(A){let{playgroundSDK:e,storage:t,contextProvider:r,config:o={},branding:a={},className:s="",dryMode:l=!1,showContextPreview:d=!0}=A,[c]=tv.Z.useForm(),{config:u}=tg(),[g,p]=(0,i.useState)(!1);(0,i.useEffect)(()=>{(async()=>{if(e&&"function"==typeof e.checkStatus)try{await e.checkStatus(),p(!0)}catch(A){console.warn("Failed to initialize SDK, using default namespace:",A),p(!0)}else p(!0)})()},[e]);let m=(0,i.useMemo)(()=>{if(t)return t;if(!g)return null;let A=o.storageNamespace||(e.id&&"string"==typeof e.id?`agent-${e.id}`:"playground-default"),r=tq();return console.log(`Using ${r} storage for namespace: ${A}`),tG(r,A)},[t,g,o.storageNamespace,e]),{loading:E,setLoading:f,infoList:h,setInfoList:y,actionSpace:v,actionSpaceLoading:C,uiContextPreview:k,setUiContextPreview:I,showScrollToBottomButton:S,verticalMode:R,replayCounter:b,setReplayCounter:N,infoListRef:P,currentRunningIdRef:x,interruptedFlagRef:w,clearInfoList:K,handleScrollToBottom:j}=function(A,e,t){let[r,o]=(0,i.useState)(!1),[n,a]=(0,i.useState)([]),[s,l]=(0,i.useState)([]),[d,c]=(0,i.useState)(!0),[u,g]=(0,i.useState)(),[p,m]=(0,i.useState)(!1),[E,f]=(0,i.useState)(!1),[h,y]=(0,i.useState)(0),v=(0,i.useRef)(null),C=(0,i.useRef)(null),k=(0,i.useRef)({}),I=(0,i.useRef)(!1);(0,i.useEffect)(()=>{let A=async()=>{let A=tG(tq(),"playground-default");try{if(null==A?void 0:A.loadMessages){let t=await A.loadMessages();if(t.length>1)return console.log("Found data in old namespace, migrating..."),(null==e?void 0:e.saveMessages)&&await e.saveMessages(t),A.clearMessages&&await A.clearMessages(),t}}catch(A){console.debug("No data found in old namespace:",A)}return[]},t=async()=>{let t={...tb,id:"welcome",timestamp:new Date};if(null==e?void 0:e.loadMessages)try{let r=await e.loadMessages();0===r.length&&(r=await A()),r.some(A=>"welcome"===A.id)?a(r):a([t,...r])}catch(A){console.error("Failed to load messages:",A),a([t])}else a([t])};e&&!I.current?(I.current=!0,t()):e||0!==n.length||t()},[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=>g(A)).catch(A=>{console.error("Failed to get UI context:",A)})},[t,u]),(0,i.useEffect)(()=>{(async()=>{c(!0);try{var e;if(!A)return void l([]);let r=u||await (null==t||null==(e=t.getUIContext)?void 0:e.call(t)),o=await A.getActionSpace(r);l(o||[])}catch(A){console.error("Failed to load action space:",A),l([])}finally{c(!1)}})()},[A,u,t]),(0,i.useEffect)(()=>{f(window.innerWidth<750);let A=()=>{f(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)},[]),R=(0,i.useCallback)(()=>{if(v.current){let{scrollTop:A,scrollHeight:e,clientHeight:t}=v.current;m(!(A+t>=e-10))}},[]),b=(0,i.useCallback)(()=>{v.current&&(v.current.scrollTo({top:v.current.scrollHeight,behavior:"smooth"}),m(!1))},[]);(0,i.useEffect)(()=>{n.length>0&&S()},[n,S]),(0,i.useEffect)(()=>{let A=v.current;if(A)return A.addEventListener("scroll",R),R(),()=>{A.removeEventListener("scroll",R)}},[R]);let N=(0,i.useCallback)(async()=>{if(a([{...tb,id:"welcome",timestamp:new Date}]),null==e?void 0:e.clearMessages)try{await e.clearMessages()}catch(A){console.error("Failed to clear stored messages:",A)}},[e]),P=(0,i.useCallback)(async()=>{if(null==t?void 0:t.refreshContext)try{let A=await t.refreshContext();g(A)}catch(A){console.error("Failed to refresh context:",A)}},[t]);return{loading:r,setLoading:o,infoList:n,setInfoList:a,actionSpace:s,actionSpaceLoading:d,uiContextPreview:u,setUiContextPreview:g,showScrollToBottomButton:p,verticalMode:E,replayCounter:h,setReplayCounter:y,infoListRef:v,currentRunningIdRef:C,interruptedFlagRef:k,clearInfoList:N,refreshContext:P,handleScrollToBottom:b,scrollToBottom:S}}(e,m,r),{handleRun:z,handleStop:B,canStop:M}=function(A,e,t,r,o,n,a,s,l,d,c,u){let{deepThink:g,screenshotIncluded:p,domIncluded:m}=tg(),E=(0,i.useCallback)(async t=>{if(!A)return void console.warn("PlaygroundSDK is not available");let r=Date.now(),n=t.type,i=`${t.type}: ${t.prompt||JSON.stringify(t.params)}`,E={id:`user-${Date.now()}`,type:"user",content:i,timestamp:new Date};a(A=>[...A,E]),o(!0);let f={...tN},h={id:`system-${r}`,type:"system",content:"",timestamp:new Date,loading:!0,loadingProgressText:""};a(A=>[...A,h]);try{if(c.current=r,u.current[r]=!1,A.onProgressUpdate&&A.onProgressUpdate(()=>{}),A.onProgressUpdate&&A.onProgressUpdate(A=>{u.current[r]||a(e=>{let t=e[e.length-1];if(t&&"progress"===t.type&&t.content===A)return e;let o={id:`progress-${r}-${Date.now()}`,type:"progress",content:A,timestamp:new Date};return[...e,o]})}),f.result=await A.executeAction(n,t,{requestId:r.toString(),deepThink:g,screenshotIncluded:p,domIncluded:m}),"object"==typeof f.result&&null!==f.result){let A=f.result;A.dump&&(f.dump=A.dump),A.reportHTML&&(f.reportHTML=A.reportHTML),A.error&&(f.error=A.error),void 0!==A.result&&(f.result=A.result)}}catch(A){f.error=(null==A?void 0:A.message)||String(A),console.error("Playground execution error:",A)}if(u.current[r])return;o(!1),c.current=null;let y=null,v=s;if((null==f?void 0:f.dump)&&!eD.includes(n)){let A=(A=>{let e,t,r=new Set,o=A.sdkVersion,n=new Set;if(A.executions.forEach(A=>{A.tasks.forEach(A=>{var o,n;if(null==(n=A.uiContext)||null==(o=n.size)?void 0:o.width){let o=A.uiContext.size.width,n=A.uiContext.size.height;e||(e=o,t=n),r.add(`${o}x${n}`)}})}),!e||!t)return console.warn("width or height is missing in dump file"),{scripts:[],sdkVersion:o,modelBriefs:[]};let i=[];A.executions.forEach(A=>{let r=((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=tz({left:0,top:0,width:t,height:r},t,r),a=(A,e,t)=>({type:"pointer",img:A,duration:0,title:e,subTitle:t}),s=[],l=i,d=!1,c=n.length,u="",g=!1;return n.forEach((A,e)=>{var n,p,m,E,f,h,y,v,C,k,I,S,R,b,N,P,x,w,K,j,z,B,M,Z,T,Q,O,D,X,J,U,L,V,G,q,F,W;if(!g){if(0===e&&(u=tj(A)),"Planning"===A.type)A.recorder&&A.recorder.length>0&&s.push({type:"img",img:null==(p=A.recorder)||null==(n=p[0])?void 0:n.screenshot,camera:0===e?i:void 0,duration:900,title:tw(A),subTitle:tj(A),imageWidth:(null==(E=A.uiContext)||null==(m=E.size)?void 0:m.width)||t,imageHeight:(null==(h=A.uiContext)||null==(f=h.size)?void 0:f.height)||r});else if("Insight"===A.type&&"Locate"===A.subType){let e=null==(y=A.output)?void 0:y.element,n=tw(A),a=tj(A);(null==e?void 0:e.rect)&&(o={...tz(e.rect,t,r),pointerLeft:e.center[0],pointerTop:e.center[1]});let c=A.uiContext;if(null==c?void 0:c.screenshotBase64){let e,u=A.log,g=c.tree?eS(c.tree).length:0;c.screenshotBase64&&s.push({type:"img",img:c.screenshotBase64,duration:300,title:n,subTitle:a,imageWidth:(null==(S=c.size)?void 0:S.width)||t,imageHeight:(null==(R=c.size)?void 0:R.height)||r}),e=l===i?void 0:o?((A,e)=>{let t=Math.min(A.left,e.left),r=Math.min(A.top,e.top);return{left:t,top:r,width:Math.max(A.left+A.width,e.left+e.width)-t}})(l,o):void 0,s.push({type:"insight",img:c.screenshotBase64,context:c,camera:e,highlightElement:(null==(v=A.output)?void 0:v.element)||void 0,searchArea:null==u||null==(C=u.taskInfo)?void 0:C.searchArea,duration:g>20?800:400,insightCameraDuration:800,title:n,subTitle:a,imageWidth:(null==(k=c.size)?void 0:k.width)||t,imageHeight:(null==(I=c.size)?void 0:I.height)||r}),s.push({type:"sleep",duration:300,title:n,subTitle:a}),d=!0}}else if("Action"===A.type&&"FalsyConditionStatement"!==A.subType){let n=tw(A),u=tj(A);s.push(a(tP,n,u)),l=null!=o?o:i,s.push({type:"img",img:null==(N=A.recorder)||null==(b=N[0])?void 0:b.screenshot,duration:1e3,camera:"Sleep"===A.subType?i:o,title:n,subTitle:u,imageWidth:(null==(x=A.uiContext)||null==(P=x.size)?void 0:P.width)||t,imageHeight:(null==(K=A.uiContext)||null==(w=K.size)?void 0:w.height)||r}),d&&(s.push({type:"clear-insight",duration:200,title:n,subTitle:u}),d=!1);let g=900*(e<c-1);(null==(z=A.recorder)||null==(j=z[1])?void 0:j.screenshot)?(s.push({type:"spinning-pointer",duration:300,title:n,subTitle:u}),s.push(a(tP,n,u)),s.push({type:"img",img:null==(M=A.recorder)||null==(B=M[1])?void 0:B.screenshot,duration:g,title:n,subTitle:u,imageWidth:(null==(T=A.uiContext)||null==(Z=T.size)?void 0:Z.width)||t,imageHeight:(null==(O=A.uiContext)||null==(Q=O.size)?void 0:Q.height)||r})):s.push({type:"sleep",duration:g,title:n,subTitle:u})}else{let e=tw(A),o=tj(A),n=null==(X=A.recorder)||null==(D=X[A.recorder.length-1])?void 0:D.screenshot;n&&s.push({type:"img",img:n,duration:900,camera:i,title:e,subTitle:o,imageWidth:(null==(U=A.uiContext)||null==(J=U.size)?void 0:J.width)||t,imageHeight:(null==(V=A.uiContext)||null==(L=V.size)?void 0:L.height)||r})}if("finished"!==A.status){g=!0;let e=tw(A),o=A.errorMessage||"unknown error",n=o.indexOf("NOT_IMPLEMENTED_AS_DESIGNED")>0?"Further actions cannot be performed in the current environment":o;s.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==(q=A.uiContext)||null==(G=q.size)?void 0:G.width)||t,imageHeight:(null==(W=A.uiContext)||null==(F=W.size)?void 0:F.height)||r});return}}}),g||s.push({title:"Done",subTitle:u,type:"img",duration:900,camera:i}),s})(A,-1,e,t);r&&i.push(...r),A.tasks.forEach(A=>{if(A.usage){let{model_name:e,model_description:t,intent:r}=A.usage;r&&e&&n.add(t?`${"string"!=typeof r||0===r.length?r:r.charAt(0).toUpperCase()+r.slice(1)}/${e}(${t})`:e)}})});let a=i.filter((A,e)=>e===i.length-1||"Done"!==A.title),s=(()=>{var A;let e=[...n];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:a,width:e,height:t,sdkVersion:o,modelBriefs:s}})(f.dump);l(A=>A+1),y=A,v=s+1}a(A=>A.map(A=>A.id===`system-${r}`?{...A,content:"",loading:!1,loadingProgressText:""}:A));let C={id:`result-${r}`,type:"result",content:"Execution result",timestamp:new Date,result:f,loading:!1,replayScriptsInfo:y,replayCounter:v,loadingProgressText:"",verticalMode:d};if(a(A=>[...A,C]),null==e?void 0:e.saveResult)try{await e.saveResult(C.id,C)}catch(A){console.error("Failed to save result:",A)}let k={id:`separator-${r}`,type:"separator",content:"New Session",timestamp:new Date};a(A=>[...A,k])},[A,e,t,o,a,s,l,d,c,u,g,p,m]);return{handleRun:E,handleStop:(0,i.useCallback)(async()=>{let e=c.current;if(e&&A&&A.cancelExecution)try{await A.cancelExecution(e.toString()),u.current[e]=!0,o(!1),A.onProgressUpdate&&A.onProgressUpdate(()=>{}),a(A=>A.map(A=>A.id===`system-${e}`&&A.loading?{...A,content:"Operation stopped",loading:!1,loadingProgressText:""}:A));let t={id:`separator-${e}`,type:"separator",content:"New Session",timestamp:new Date};a(A=>[...A,t])}catch(A){console.error("Failed to stop execution:",A)}},[A,c,u,o,a]),canStop:r&&!!c.current&&!!A&&!!A.cancelExecution}}(e,m,v,E,f,0,y,b,N,R,x,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 Z=(0,i.useCallback)(async()=>{try{let A=c.getFieldsValue();await z(A)}catch(A){tC.ZP.error((null==A?void 0:A.message)||"Execution failed")}},[c,z]),T=Object.keys(u||{}).length>=1,Q=o.serverMode||!l&&!C&&T,O=tv.Z.useWatch("type",c),D=d&&!1!==o.showContextPreview,X=o.layout||"vertical",J=!1!==o.showVersionInfo;return(0,n.jsx)("div",{className:`playground-container ${X}-mode ${s}`.trim(),children:(0,n.jsxs)(tv.Z,{form:c,onFinish:Z,className:"command-form",children:[D&&(0,n.jsx)("div",{className:"context-preview-section",children:(0,n.jsx)(rt,{uiContextPreview:k,setUiContextPreview:I,showContextPreview:D})}),(0,n.jsxs)("div",{className:"middle-dialog-area",children:[h.length>1&&(0,n.jsx)("div",{className:"clear-button-container",children:(0,n.jsx)(tk.ZP,{size:"small",icon:(0,n.jsx)(tE.Z,{}),onClick:K,type:"text",className:"clear-button"})}),(0,n.jsx)("div",{ref:P,className:"info-list-container",children:(0,n.jsx)(tI.Z,{itemLayout:"vertical",dataSource:h,renderItem:A=>{var e;return(0,n.jsx)(tI.Z.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:(()=>{var e,t,r,o;let i=A.content.split(" - "),a=null==(e=i[0])?void 0:e.trim(),s=i.slice(1).join(" - ").trim(),l=h.findIndex(e=>e.id===A.id),d=h.slice(l+1).some(A=>"progress"===A.type),c=E&&!d;return(0,n.jsxs)(n.Fragment,{children:[a&&(0,n.jsxs)("span",{className:"progress-action-item",children:[a,(0,n.jsx)("span",{className:`progress-status-icon ${c?"loading":(null==(t=A.result)?void 0:t.error)?"error":"completed"}`,children:c?(0,n.jsx)(tf.Z,{spin:!0}):(null==(r=A.result)?void 0:r.error)?"✗":"✓"})]}),s&&(0,n.jsx)("div",{children:(0,n.jsx)("span",{className:"progress-description",children:s})}),(null==(o=A.result)?void 0:o.error)&&(0,n.jsx)(oA,{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)(r4,{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)(th.Z,{component:a.icon||rR,style:{fontSize:20}}),(0,n.jsx)("span",{className:"system-message-title",children:a.title||"Playground"})]}),(A.content||A.result)&&(0,n.jsxs)("div",{className:"system-message-content",children:["result"===A.type&&(null==(e=A.result)?void 0:e.error)&&(0,n.jsxs)("div",{className:"error-message",children:[(0,n.jsx)("div",{className:"divider"}),(0,n.jsx)(oA,{error:A.result.error})]}),"result"===A.type?(0,n.jsx)(rS,{result:A.result||null,loading:A.loading||!1,serverValid:!0,serviceMode:"Server",replayScriptsInfo:A.replayScriptsInfo||null,replayCounter:A.replayCounter||0,loadingProgressText:A.loadingProgressText||"",verticalMode:A.verticalMode||!1,fitMode:"width"}):(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)(tk.ZP,{className:"scroll-to-bottom-button",type:"primary",shape:"circle",icon:(0,n.jsx)(ty.Z,{}),onClick:j,size:"large"})]}),(0,n.jsxs)("div",{className:"bottom-input-section",children:[o.showEnvConfigReminder?(0,n.jsx)(ro,{}):null,(0,n.jsx)(r8,{runButtonEnabled:Q,form:c,serviceMode:"Server",selectedType:O,dryMode:l,stoppable:M,loading:E,onRun:Z,onStop:B,actionSpace:v})]}),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 ot=t(45761),or=t(75368),oo=t(12764),on=t(7379),oi=t(29129);function oa(A){let{playgroundSDK:e,serverOnline:t,isUserOperating:r=!1}=A,[o,a]=(0,i.useState)(null),[s,l]=(0,i.useState)(!1),[d,c]=(0,i.useState)(null),[u,g]=(0,i.useState)(0),[p,m]=(0,i.useState)(null),E=(0,i.useRef)(null),f=(0,i.useRef)(!1),h=(0,i.useCallback)(async function(){let A=arguments.length>0&&void 0!==arguments[0]&&arguments[0];if(t){l(!0),A&&c(null);try{let A=await e.getScreenshot();if(console.log("Screenshot API response:",A),null==A?void 0:A.screenshot){let e=A.screenshot.toString().trim();e?(a(e),c(null),g(Date.now())):c("Empty screenshot data received")}else c("No screenshot data in response")}catch(A){console.error("Screenshot fetch error:",A),c(A instanceof Error?A.message:"Failed to fetch screenshot")}finally{l(!1)}}},[e,t]),y=(0,i.useCallback)(async()=>{if(t)try{let A=await e.getInterfaceInfo();A&&m(A)}catch(A){console.error("Interface info fetch error:",A)}},[e,t]),v=(0,i.useCallback)(()=>{E.current&&clearInterval(E.current),console.log("Starting screenshot polling (5s interval)"),E.current=setInterval(()=>{!f.current&&t&&h(!1)},5e3)},[h,t]),C=(0,i.useCallback)(()=>{E.current&&(console.log("Stopping screenshot polling"),clearInterval(E.current),E.current=null)},[]),k=(0,i.useCallback)(()=>{console.log("Pausing screenshot polling"),f.current=!0},[]),I=(0,i.useCallback)(()=>{console.log("Resuming screenshot polling"),f.current=!1},[]),S=(0,i.useCallback)(()=>{h(!0)},[h]);return((0,i.useEffect)(()=>{if(!t){a(null),c(null),m(null),C();return}return h(!1),y(),v(),()=>{C()}},[t,v,C,h,y]),(0,i.useEffect)(()=>{t&&(r?k():(I(),h(!1)))},[r,k,I,h,t]),(0,i.useEffect)(()=>()=>{C()},[C]),t)?s&&!o?(0,n.jsxs)("div",{className:"screenshot-viewer loading",children:[(0,n.jsx)(rn.Z,{size:"large"}),(0,n.jsx)("p",{children:"Loading screenshot..."})]}):d&&!o?(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==p?void 0:p.type)?p.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)(e5.Z,{title:null==p?void 0:p.description,children:(0,n.jsx)(on.Z,{size:16,className:"info-icon"})})]}),(0,n.jsxs)("div",{className:"screenshot-controls",children:[u>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()})(u)]}),(0,n.jsx)(e5.Z,{title:"Refresh screenshot",children:(0,n.jsx)(tk.ZP,{icon:(0,n.jsx)(oi.Z,{}),onClick:S,loading:s,size:"small"})}),r&&(0,n.jsxs)("span",{className:"operation-indicator",children:[(0,n.jsx)(rn.Z,{size:"small"})," Operating..."]})]})]}),(0,n.jsx)("div",{className:"screenshot-content",children:o?(0,n.jsx)("img",{src:o.startsWith("data:image/")?o:`data:image/png;base64,${o}`,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:",o.substring(0,100)),c("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"})]})})}let os=t.p+"static/svg/server-offline-foreground.6e892230.svg",{Content:ol}=ot.Z,od=document.getElementById("root");if(!od)throw Error("Root element not found");(0,a.createRoot)(od).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),s=(0,i.useMemo)(()=>{let A=new eF({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 s.checkStatus();e(A)}catch(A){console.error("Failed to check server status:",A),e(!1)}};A();let t=setInterval(A,5e3);return()=>clearInterval(t)},[s]),(0,i.useEffect)(()=>{let A=()=>{a(window.innerWidth<=1024)};return A(),window.addEventListener("resize",A),()=>window.removeEventListener("resize",A)},[]),A)?(0,n.jsx)(or.ZP,{theme:eY(),children:(0,n.jsx)(ot.Z,{className:"app-container playground-container",children:(0,n.jsx)(ol,{className:"app-content",children:(0,n.jsxs)(oo.eh,{autoSaveId:"playground-layout",direction:o?"vertical":"horizontal",children:[(0,n.jsx)(oo.s_,{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)(e_,{}),(0,n.jsx)(tm,{showTooltipWhenEmpty:!1,showModelName:!1})]})}),(0,n.jsx)("div",{className:"playground-panel-playground",children:(0,n.jsx)(oe,{playgroundSDK:s,config:{showContextPreview:!1,layout:"vertical",showVersionInfo:!0,enableScrollToBottom:!0,serverMode:!0,showEnvConfigReminder:!0},branding:{title:"Playground",version:"0.30.8"},className:"playground-container"})})]})}),(0,n.jsx)(oo.OT,{className:`panel-resize-handle ${o?"vertical":"horizontal"}`}),(0,n.jsx)(oo.s_,{className:"app-panel right-panel",children:(0,n.jsx)("div",{className:"panel-content right-panel-content",children:(0,n.jsx)(oa,{playgroundSDK:s,serverOnline:A,isUserOperating:t})})})]})})})}):(0,n.jsx)(or.ZP,{theme:eY(),children:(0,n.jsx)("div",{className:"server-offline-container",children:(0,n.jsxs)("div",{className:"server-offline-message",children:[(0,n.jsx)(e_,{}),(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:os,className:"icon-foreground",alt:""})]}),(0,n.jsx)("h1",{children:"Midscene Playground"}),(0,n.jsx)("p",{className:"connection-status",children:"Server offline..."})]})]})})})},{})}))},66460:function(A){if("undefined"==typeof sharp){var e=Error("Cannot find module 'sharp'");throw e.code="MODULE_NOT_FOUND",e}A.exports=sharp},86110:function(){},58241:function(){},32176:function(){},13527:function(){},64849:function(){},51114:function(){},6156:function(){},41037:function(){},35665:function(){},6281:function(){},39229:function(){},40924:function(){},87333:function(){},15787:function(){},5460:function(){},61546:function(){},18113:function(){},5174:function(){}},e={};function t(r){var o=e[r];if(void 0!==o)return o.exports;var n=e[r]={id:r,loaded:!1,exports:{}};return A[r].call(n.exports,n,n.exports,t),n.loaded=!0,n.exports}t.m=A,t.n=A=>{var e=A&&A.__esModule?()=>A.default:()=>A;return t.d(e,{a:e}),e},(()=>{var A,e=Object.getPrototypeOf?A=>Object.getPrototypeOf(A):A=>A.__proto__;t.t=function(r,o){if(1&o&&(r=this(r)),8&o||"object"==typeof r&&r&&(4&o&&r.__esModule||16&o&&"function"==typeof r.then))return r;var n=Object.create(null);t.r(n);var i={};A=A||[null,e({}),e([]),e(e)];for(var a=2&o&&r;"object"==typeof a&&!~A.indexOf(a);a=e(a))Object.getOwnPropertyNames(a).forEach(A=>{i[A]=()=>r[A]});return i.default=()=>r,t.d(n,i),n}})(),t.d=(A,e)=>{for(var r in e)t.o(e,r)&&!t.o(A,r)&&Object.defineProperty(A,r,{enumerable:!0,get:e[r]})},t.f={},t.e=A=>Promise.all(Object.keys(t.f).reduce((e,r)=>(t.f[r](A,e),e),[])),t.u=A=>"static/js/async/"+A+"."+({173:"9cf6b074",212:"e243c338",290:"dd04c2bc",329:"f888b505",364:"1821e74b",544:"b73fa603",582:"5dccae2d",624:"45ee2b2c",644:"6bdc4065",702:"60261735",920:"7d9a9aa8",983:"8b91303f"})[A]+".js",t.miniCssF=A=>""+A+".css",t.g=(()=>{if("object"==typeof globalThis)return globalThis;try{return this||Function("return this")()}catch(A){if("object"==typeof window)return window}})(),t.o=(A,e)=>Object.prototype.hasOwnProperty.call(A,e),(()=>{var A={},e="playground:";t.l=function(r,o,n,i){if(A[r])return void A[r].push(o);if(void 0!==n)for(var a,s,l=document.getElementsByTagName("script"),d=0;d<l.length;d++){var c=l[d];if(c.getAttribute("src")==r||c.getAttribute("data-webpack")==e+n){a=c;break}}a||(s=!0,(a=document.createElement("script")).charset="utf-8",a.timeout=120,t.nc&&a.setAttribute("nonce",t.nc),a.setAttribute("data-webpack",e+n),a.src=r),A[r]=[o];var u=function(e,t){a.onerror=a.onload=null,clearTimeout(g);var o=A[r];if(delete A[r],a.parentNode&&a.parentNode.removeChild(a),o&&o.forEach(function(A){return A(t)}),e)return e(t)},g=setTimeout(u.bind(null,void 0,{type:"timeout",target:a}),12e4);a.onerror=u.bind(null,a.onerror),a.onload=u.bind(null,a.onload),s&&document.head.appendChild(a)}})(),t.r=A=>{"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(A,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(A,"__esModule",{value:!0})},t.nmd=A=>(A.paths=[],A.children||(A.children=[]),A),(()=>{var A=[];t.O=(e,r,o,n)=>{if(r){n=n||0;for(var i=A.length;i>0&&A[i-1][2]>n;i--)A[i]=A[i-1];A[i]=[r,o,n];return}for(var a=1/0,i=0;i<A.length;i++){for(var[r,o,n]=A[i],s=!0,l=0;l<r.length;l++)(!1&n||a>=n)&&Object.keys(t.O).every(A=>t.O[A](r[l]))?r.splice(l--,1):(s=!1,n<a&&(a=n));if(s){A.splice(i--,1);var d=o();void 0!==d&&(e=d)}}return e}})(),t.p="/",(()=>{t.b=document.baseURI||self.location.href;var A={980:0};t.f.j=function(e,r){var o=t.o(A,e)?A[e]:void 0;if(0!==o)if(o)r.push(o[2]);else{var n=new Promise((t,r)=>o=A[e]=[t,r]);r.push(o[2]=n);var i=t.p+t.u(e),a=Error();t.l(i,function(r){if(t.o(A,e)&&(0!==(o=A[e])&&(A[e]=void 0),o)){var n=r&&("load"===r.type?"missing":r.type),i=r&&r.target&&r.target.src;a.message="Loading chunk "+e+" failed.\n("+n+": "+i+")",a.name="ChunkLoadError",a.type=n,a.request=i,o[1](a)}},"chunk-"+e,e)}},t.O.j=e=>0===A[e];var e=(e,r)=>{var o,n,[i,a,s]=r,l=0;if(i.some(e=>0!==A[e])){for(o in a)t.o(a,o)&&(t.m[o]=a[o]);if(s)var d=s(t)}for(e&&e(r);l<i.length;l++)n=i[l],t.o(A,n)&&A[n]&&A[n][0](),A[n]=0;return t.O(d)},r=self.webpackChunkplayground=self.webpackChunkplayground||[];r.forEach(e.bind(null,0)),r.push=e.bind(null,r.push.bind(r))})();var r=t.O(void 0,["361","657"],function(){return t(69921)});r=t.O(r)})();
|
|
21
|
+
//# sourceMappingURL=index.81b3ced1.js.map
|