serve-sim 0.0.0 → 0.0.2
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/bin/serve-sim-bin +0 -0
- package/dist/middleware.js +9 -4
- package/dist/serve-sim.js +16 -11
- package/package.json +7 -1
- package/src/middleware.ts +133 -2
package/bin/serve-sim-bin
CHANGED
|
Binary file
|
package/dist/middleware.js
CHANGED
|
@@ -1,7 +1,12 @@
|
|
|
1
1
|
// @bun
|
|
2
|
-
import{readdirSync as J,readFileSync as P}from"fs";import{spawn as j}from"child_process";import{tmpdir as k}from"os";import{join as H}from"path";var F=H(k(),"serve-sim");function Z(){let U;try{U=J(F).filter((G)=>G.startsWith("server-")&&G.endsWith(".json"))}catch{return[]}let B=[];for(let G of U)try{let z=JSON.parse(P(H(F,G),"utf-8"));try{process.kill(z.pid,0),B.push(z)}catch{}}catch{}return B}var $=null;function D(){if(!$)$=Buffer.from("<!doctype html>
<html><head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Simulator Preview</title>
<style>*,*::before,*::after{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}</style>
</head><body>
<div id="root"></div>
<!--__SIM_PREVIEW_CONFIG__-->
<script type="module">var b0,P,b4,j5,K0,w4,p4,v4,X4,C0,U0,j4,K4,Y4,Z4,R4,w0={},S0=[],R5=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,A0=Array.isArray;function X0(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function Q4(X){X&&X.parentNode&&X.parentNode.removeChild(X)}function Y0(X,Y,Z){var J,q,K,Q={};for(K in Y)K=="key"?J=Y[K]:K=="ref"?q=Y[K]:Q[K]=Y[K];if(arguments.length>2&&(Q.children=arguments.length>3?b0.call(arguments,2):Z),typeof X=="function"&&X.defaultProps!=null)for(K in X.defaultProps)Q[K]===void 0&&(Q[K]=X.defaultProps[K]);return E0(X,Q,J,q,null)}function E0(X,Y,Z,J,q){var K={type:X,props:Y,key:Z,ref:J,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:q==null?++b4:q,__i:-1,__u:0};return q==null&&P.vnode!=null&&P.vnode(K),K}function x(X){return X.children}function g(X,Y){this.props=X,this.context=Y}function L0(X,Y){if(Y==null)return X.__?L0(X.__,X.__i+1):null;for(var Z;Y<X.__k.length;Y++)if((Z=X.__k[Y])!=null&&Z.__e!=null)return Z.__e;return typeof X.type=="function"?L0(X):null}function y5(X){if(X.__P&&X.__d){var Y=X.__v,Z=Y.__e,J=[],q=[],K=X0({},Y);K.__v=Y.__v+1,P.vnode&&P.vnode(K),$4(X.__P,K,Y,X.__n,X.__P.namespaceURI,32&Y.__u?[Z]:null,J,Z==null?L0(Y):Z,!!(32&Y.__u),q),K.__v=Y.__v,K.__.__k[K.__i]=K,d4(J,K,q),Y.__e=Y.__=null,K.__e!=Z&&y4(K)}}function y4(X){if((X=X.__)!=null&&X.__c!=null)return X.__e=X.__c.base=null,X.__k.some(function(Y){if(Y!=null&&Y.__e!=null)return X.__e=X.__c.base=Y.__e}),y4(X)}function J4(X){(!X.__d&&(X.__d=!0)&&K0.push(X)&&!T0.__r++||w4!=P.debounceRendering)&&((w4=P.debounceRendering)||p4)(T0)}function T0(){try{for(var X,Y=1;K0.length;)K0.length>Y&&K0.sort(v4),X=K0.shift(),Y=K0.length,y5(X)}finally{K0.length=T0.__r=0}}function g4(X,Y,Z,J,q,K,Q,z,G,L,D){var W,O,U,k,_,C,M,F=J&&J.__k||S0,E=Y.length;for(G=g5(Z,Y,F,G,E),W=0;W<E;W++)(U=Z.__k[W])!=null&&(O=U.__i!=-1&&F[U.__i]||w0,U.__i=W,C=$4(X,U,O,q,K,Q,z,G,L,D),k=U.__e,U.ref&&O.ref!=U.ref&&(O.ref&&W4(O.ref,null,U),D.push(U.ref,U.__c||k,U)),_==null&&k!=null&&(_=k),(M=!!(4&U.__u))||O.__k===U.__k?(G=x4(U,G,X,M),M&&O.__e&&(O.__e=null)):typeof U.type=="function"&&C!==void 0?G=C:k&&(G=k.nextSibling),U.__u&=-7);return Z.__e=_,G}function g5(X,Y,Z,J,q){var K,Q,z,G,L,D=Z.length,W=D,O=0;for(X.__k=Array(q),K=0;K<q;K++)(Q=Y[K])!=null&&typeof Q!="boolean"&&typeof Q!="function"?(typeof Q=="string"||typeof Q=="number"||typeof Q=="bigint"||Q.constructor==String?Q=X.__k[K]=E0(null,Q,null,null,null):A0(Q)?Q=X.__k[K]=E0(x,{children:Q},null,null,null):Q.constructor===void 0&&Q.__b>0?Q=X.__k[K]=E0(Q.type,Q.props,Q.key,Q.ref?Q.ref:null,Q.__v):X.__k[K]=Q,G=K+O,Q.__=X,Q.__b=X.__b+1,z=null,(L=Q.__i=x5(Q,Z,G,W))!=-1&&(W--,(z=Z[L])&&(z.__u|=2)),z==null||z.__v==null?(L==-1&&(q>D?O--:q<D&&O++),typeof Q.type!="function"&&(Q.__u|=4)):L!=G&&(L==G-1?O--:L==G+1?O++:(L>G?O--:O++,Q.__u|=4))):X.__k[K]=null;if(W)for(K=0;K<D;K++)(z=Z[K])!=null&&(2&z.__u)==0&&(z.__e==J&&(J=L0(z)),h4(z,z));return J}function x4(X,Y,Z,J){var q,K;if(typeof X.type=="function"){for(q=X.__k,K=0;q&&K<q.length;K++)q[K]&&(q[K].__=X,Y=x4(q[K],Y,Z,J));return Y}X.__e!=Y&&(J&&(Y&&X.type&&!Y.parentNode&&(Y=L0(X)),Z.insertBefore(X.__e,Y||null)),Y=X.__e);do Y=Y&&Y.nextSibling;while(Y!=null&&Y.nodeType==8);return Y}function Z0(X,Y){return Y=Y||[],X==null||typeof X=="boolean"||(A0(X)?X.some(function(Z){Z0(Z,Y)}):Y.push(X)),Y}function x5(X,Y,Z,J){var q,K,Q,z=X.key,G=X.type,L=Y[Z],D=L!=null&&(2&L.__u)==0;if(L===null&&z==null||D&&z==L.key&&G==L.type)return Z;if(J>(D?1:0)){for(q=Z-1,K=Z+1;q>=0||K<Y.length;)if((L=Y[Q=q>=0?q--:K++])!=null&&(2&L.__u)==0&&z==L.key&&G==L.type)return Q}return-1}function S4(X,Y,Z){Y[0]=="-"?X.setProperty(Y,Z==null?"":Z):X[Y]=Z==null?"":typeof Z!="number"||R5.test(Y)?Z:Z+"px"}function M0(X,Y,Z,J,q){var K,Q;X:if(Y=="style")if(typeof Z=="string")X.style.cssText=Z;else{if(typeof J=="string"&&(X.style.cssText=J=""),J)for(Y in J)Z&&Y in Z||S4(X.style,Y,"");if(Z)for(Y in Z)J&&Z[Y]==J[Y]||S4(X.style,Y,Z[Y])}else if(Y[0]=="o"&&Y[1]=="n")K=Y!=(Y=Y.replace(j4,"$1")),Q=Y.toLowerCase(),Y=Q in X||Y=="onFocusOut"||Y=="onFocusIn"?Q.slice(2):Y.slice(2),X.l||(X.l={}),X.l[Y+K]=Z,Z?J?Z[U0]=J[U0]:(Z[U0]=K4,X.addEventListener(Y,K?Z4:Y4,K)):X.removeEventListener(Y,K?Z4:Y4,K);else{if(q=="http://www.w3.org/2000/svg")Y=Y.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if(Y!="width"&&Y!="height"&&Y!="href"&&Y!="list"&&Y!="form"&&Y!="tabIndex"&&Y!="download"&&Y!="rowSpan"&&Y!="colSpan"&&Y!="role"&&Y!="popover"&&Y in X)try{X[Y]=Z==null?"":Z;break X}catch(z){}typeof Z=="function"||(Z==null||Z===!1&&Y[4]!="-"?X.removeAttribute(Y):X.setAttribute(Y,Y=="popover"&&Z==1?"":Z))}}function T4(X){return function(Y){if(this.l){var Z=this.l[Y.type+X];if(Y[C0]==null)Y[C0]=K4++;else if(Y[C0]<Z[U0])return;return Z(P.event?P.event(Y):Y)}}}function $4(X,Y,Z,J,q,K,Q,z,G,L){var D,W,O,U,k,_,C,M,F,E,I,v,r,f,i,y=Y.type;if(Y.constructor!==void 0)return null;128&Z.__u&&(G=!!(32&Z.__u),K=[z=Y.__e=Z.__e]),(D=P.__b)&&D(Y);X:if(typeof y=="function")try{if(M=Y.props,F=y.prototype&&y.prototype.render,E=(D=y.contextType)&&J[D.__c],I=D?E?E.props.value:D.__:J,Z.__c?C=(W=Y.__c=Z.__c).__=W.__E:(F?Y.__c=W=new y(M,I):(Y.__c=W=new g(M,I),W.constructor=y,W.render=m5),E&&E.sub(W),W.state||(W.state={}),W.__n=J,O=W.__d=!0,W.__h=[],W._sb=[]),F&&W.__s==null&&(W.__s=W.state),F&&y.getDerivedStateFromProps!=null&&(W.__s==W.state&&(W.__s=X0({},W.__s)),X0(W.__s,y.getDerivedStateFromProps(M,W.__s))),U=W.props,k=W.state,W.__v=Y,O)F&&y.getDerivedStateFromProps==null&&W.componentWillMount!=null&&W.componentWillMount(),F&&W.componentDidMount!=null&&W.__h.push(W.componentDidMount);else{if(F&&y.getDerivedStateFromProps==null&&M!==U&&W.componentWillReceiveProps!=null&&W.componentWillReceiveProps(M,I),Y.__v==Z.__v||!W.__e&&W.shouldComponentUpdate!=null&&W.shouldComponentUpdate(M,W.__s,I)===!1){Y.__v!=Z.__v&&(W.props=M,W.state=W.__s,W.__d=!1),Y.__e=Z.__e,Y.__k=Z.__k,Y.__k.some(function(m){m&&(m.__=Y)}),S0.push.apply(W.__h,W._sb),W._sb=[],W.__h.length&&Q.push(W);break X}W.componentWillUpdate!=null&&W.componentWillUpdate(M,W.__s,I),F&&W.componentDidUpdate!=null&&W.__h.push(function(){W.componentDidUpdate(U,k,_)})}if(W.context=I,W.props=M,W.__P=X,W.__e=!1,v=P.__r,r=0,F)W.state=W.__s,W.__d=!1,v&&v(Y),D=W.render(W.props,W.state,W.context),S0.push.apply(W.__h,W._sb),W._sb=[];else do W.__d=!1,v&&v(Y),D=W.render(W.props,W.state,W.context),W.state=W.__s;while(W.__d&&++r<25);W.state=W.__s,W.getChildContext!=null&&(J=X0(X0({},J),W.getChildContext())),F&&!O&&W.getSnapshotBeforeUpdate!=null&&(_=W.getSnapshotBeforeUpdate(U,k)),f=D!=null&&D.type===x&&D.key==null?m4(D.props.children):D,z=g4(X,A0(f)?f:[f],Y,Z,J,q,K,Q,z,G,L),W.base=Y.__e,Y.__u&=-161,W.__h.length&&Q.push(W),C&&(W.__E=W.__=null)}catch(m){if(Y.__v=null,G||K!=null)if(m.then){for(Y.__u|=G?160:128;z&&z.nodeType==8&&z.nextSibling;)z=z.nextSibling;K[K.indexOf(z)]=null,Y.__e=z}else{for(i=K.length;i--;)Q4(K[i]);q4(Y)}else Y.__e=Z.__e,Y.__k=Z.__k,m.then||q4(Y);P.__e(m,Y,Z)}else K==null&&Y.__v==Z.__v?(Y.__k=Z.__k,Y.__e=Z.__e):z=Y.__e=d5(Z.__e,Y,Z,J,q,K,Q,G,L);return(D=P.diffed)&&D(Y),128&Y.__u?void 0:z}function q4(X){X&&(X.__c&&(X.__c.__e=!0),X.__k&&X.__k.some(q4))}function d4(X,Y,Z){for(var J=0;J<Z.length;J++)W4(Z[J],Z[++J],Z[++J]);P.__c&&P.__c(Y,X),X.some(function(q){try{X=q.__h,q.__h=[],X.some(function(K){K.call(q)})}catch(K){P.__e(K,q.__v)}})}function m4(X){return typeof X!="object"||X==null||X.__b>0?X:A0(X)?X.map(m4):X0({},X)}function d5(X,Y,Z,J,q,K,Q,z,G){var L,D,W,O,U,k,_,C=Z.props||w0,M=Y.props,F=Y.type;if(F=="svg"?q="http://www.w3.org/2000/svg":F=="math"?q="http://www.w3.org/1998/Math/MathML":q||(q="http://www.w3.org/1999/xhtml"),K!=null){for(L=0;L<K.length;L++)if((U=K[L])&&"setAttribute"in U==!!F&&(F?U.localName==F:U.nodeType==3)){X=U,K[L]=null;break}}if(X==null){if(F==null)return document.createTextNode(M);X=document.createElementNS(q,F,M.is&&M),z&&(P.__m&&P.__m(Y,K),z=!1),K=null}if(F==null)C===M||z&&X.data==M||(X.data=M);else{if(K=K&&b0.call(X.childNodes),!z&&K!=null)for(C={},L=0;L<X.attributes.length;L++)C[(U=X.attributes[L]).name]=U.value;for(L in C)U=C[L],L=="dangerouslySetInnerHTML"?W=U:L=="children"||(L in M)||L=="value"&&("defaultValue"in M)||L=="checked"&&("defaultChecked"in M)||M0(X,L,null,U,q);for(L in M)U=M[L],L=="children"?O=U:L=="dangerouslySetInnerHTML"?D=U:L=="value"?k=U:L=="checked"?_=U:z&&typeof U!="function"||C[L]===U||M0(X,L,U,C[L],q);if(D)z||W&&(D.__html==W.__html||D.__html==X.innerHTML)||(X.innerHTML=D.__html),Y.__k=[];else if(W&&(X.innerHTML=""),g4(Y.type=="template"?X.content:X,A0(O)?O:[O],Y,Z,J,F=="foreignObject"?"http://www.w3.org/1999/xhtml":q,K,Q,K?K[0]:Z.__k&&L0(Z,0),z,G),K!=null)for(L=K.length;L--;)Q4(K[L]);z||(L="value",F=="progress"&&k==null?X.removeAttribute("value"):k!=null&&(k!==X[L]||F=="progress"&&!k||F=="option"&&k!=C[L])&&M0(X,L,k,C[L],q),L="checked",_!=null&&_!=X[L]&&M0(X,L,_,C[L],q))}return X}function W4(X,Y,Z){try{if(typeof X=="function"){var J=typeof X.__u=="function";J&&X.__u(),J&&Y==null||(X.__u=X(Y))}else X.current=Y}catch(q){P.__e(q,Z)}}function h4(X,Y,Z){var J,q;if(P.unmount&&P.unmount(X),(J=X.ref)&&(J.current&&J.current!=X.__e||W4(J,null,Y)),(J=X.__c)!=null){if(J.componentWillUnmount)try{J.componentWillUnmount()}catch(K){P.__e(K,Y)}J.base=J.__P=null}if(J=X.__k)for(q=0;q<J.length;q++)J[q]&&h4(J[q],Y,Z||typeof X.type!="function");Z||Q4(X.__e),X.__c=X.__=X.__e=void 0}function m5(X,Y,Z){return this.constructor(X,Z)}function p0(X,Y,Z){var J,q,K,Q;Y==document&&(Y=document.documentElement),P.__&&P.__(X,Y),q=(J=typeof Z=="function")?null:Z&&Z.__k||Y.__k,K=[],Q=[],$4(Y,X=(!J&&Z||Y).__k=Y0(x,null,[X]),q||w0,w0,Y.namespaceURI,!J&&Z?[Z]:q?null:Y.firstChild?b0.call(Y.childNodes):null,K,!J&&Z?Z:q?q.__e:Y.firstChild,J,Q),d4(K,X,Q)}function z0(X){function Y(Z){var J,q;return this.getChildContext||(J=new Set,(q={})[Y.__c]=this,this.getChildContext=function(){return q},this.componentWillUnmount=function(){J=null},this.shouldComponentUpdate=function(K){this.props.value!=K.value&&J.forEach(function(Q){Q.__e=!0,J4(Q)})},this.sub=function(K){J.add(K);var Q=K.componentWillUnmount;K.componentWillUnmount=function(){J&&J.delete(K),Q&&Q.call(K)}}),Z.children}return Y.__c="__cC"+R4++,Y.__=X,Y.Provider=Y.__l=(Y.Consumer=function(Z,J){return Z.children(J)}).contextType=Y,Y}b0=S0.slice,P={__e:function(X,Y,Z,J){for(var q,K,Q;Y=Y.__;)if((q=Y.__c)&&!q.__)try{if((K=q.constructor)&&K.getDerivedStateFromError!=null&&(q.setState(K.getDerivedStateFromError(X)),Q=q.__d),q.componentDidCatch!=null&&(q.componentDidCatch(X,J||{}),Q=q.__d),Q)return q.__E=q}catch(z){X=z}throw X}},b4=0,j5=function(X){return X!=null&&X.constructor===void 0},g.prototype.setState=function(X,Y){var Z;Z=this.__s!=null&&this.__s!=this.state?this.__s:this.__s=X0({},this.state),typeof X=="function"&&(X=X(X0({},Z),this.props)),X&&X0(Z,X),X!=null&&this.__v&&(Y&&this._sb.push(Y),J4(this))},g.prototype.forceUpdate=function(X){this.__v&&(this.__e=!0,X&&this.__h.push(X),J4(this))},g.prototype.render=x,K0=[],p4=typeof Promise=="function"?Promise.prototype.then.bind(Promise.resolve()):setTimeout,v4=function(X,Y){return X.__v.__b-Y.__v.__b},T0.__r=0,X4=Math.random().toString(8),C0="__d"+X4,U0="__a"+X4,j4=/(PointerCapture)$|Capture$/i,K4=0,Y4=T4(!1),Z4=T4(!0),R4=0;var N0,T,L4,f4,D0=0,r4=[],b=P,a4=b.__b,c4=b.__r,l4=b.diffed,i4=b.__c,s4=b.unmount,o4=b.__;function j0(X,Y){b.__h&&b.__h(T,X,D0||Y),D0=0;var Z=T.__H||(T.__H={__:[],__h:[]});return X>=Z.__.length&&Z.__.push({}),Z.__[X]}function p(X){return D0=1,N4(n4,X)}function N4(X,Y,Z){var J=j0(N0++,2);if(J.t=X,!J.__c&&(J.__=[Z?Z(Y):n4(void 0,Y),function(z){var G=J.__N?J.__N[0]:J.__[0],L=J.t(G,z);G!==L&&(J.__N=[L,J.__[1]],J.__c.setState({}))}],J.__c=T,!T.__f)){var q=function(z,G,L){if(!J.__c.__H)return!0;var D=J.__c.__H.__.filter(function(O){return O.__c});if(D.every(function(O){return!O.__N}))return!K||K.call(this,z,G,L);var W=J.__c.props!==z;return D.some(function(O){if(O.__N){var U=O.__[0];O.__=O.__N,O.__N=void 0,U!==O.__[0]&&(W=!0)}}),K&&K.call(this,z,G,L)||W};T.__f=!0;var{shouldComponentUpdate:K,componentWillUpdate:Q}=T;T.componentWillUpdate=function(z,G,L){if(this.__e){var D=K;K=void 0,q(z,G,L),K=D}Q&&Q.call(this,z,G,L)},T.shouldComponentUpdate=q}return J.__N||J.__}function d(X,Y){var Z=j0(N0++,3);!b.__s&&t4(Z.__H,Y)&&(Z.__=X,Z.u=Y,T.__H.__h.push(Z))}function w(X){return D0=5,R0(function(){return{current:X}},[])}function R0(X,Y){var Z=j0(N0++,7);return t4(Z.__H,Y)&&(Z.__=X(),Z.__H=Y,Z.__h=X),Z.__}function j(X,Y){return D0=8,R0(function(){return X},Y)}function P0(X){var Y=T.context[X.__c],Z=j0(N0++,9);return Z.c=X,Y?(Z.__==null&&(Z.__=!0,Y.sub(T)),Y.props.value):X.__}function h5(){for(var X;X=r4.shift();){var Y=X.__H;if(X.__P&&Y)try{Y.__h.some(v0),Y.__h.some(z4),Y.__h=[]}catch(Z){Y.__h=[],b.__e(Z,X.__v)}}}b.__b=function(X){T=null,a4&&a4(X)},b.__=function(X,Y){X&&Y.__k&&Y.__k.__m&&(X.__m=Y.__k.__m),o4&&o4(X,Y)},b.__r=function(X){c4&&c4(X),N0=0;var Y=(T=X.__c).__H;Y&&(L4===T?(Y.__h=[],T.__h=[],Y.__.some(function(Z){Z.__N&&(Z.__=Z.__N),Z.u=Z.__N=void 0})):(Y.__h.some(v0),Y.__h.some(z4),Y.__h=[],N0=0)),L4=T},b.diffed=function(X){l4&&l4(X);var Y=X.__c;Y&&Y.__H&&(Y.__H.__h.length&&(r4.push(Y)!==1&&f4===b.requestAnimationFrame||((f4=b.requestAnimationFrame)||f5)(h5)),Y.__H.__.some(function(Z){Z.u&&(Z.__H=Z.u),Z.u=void 0})),L4=T=null},b.__c=function(X,Y){Y.some(function(Z){try{Z.__h.some(v0),Z.__h=Z.__h.filter(function(J){return!J.__||z4(J)})}catch(J){Y.some(function(q){q.__h&&(q.__h=[])}),Y=[],b.__e(J,Z.__v)}}),i4&&i4(X,Y)},b.unmount=function(X){s4&&s4(X);var Y,Z=X.__c;Z&&Z.__H&&(Z.__H.__.some(function(J){try{v0(J)}catch(q){Y=q}}),Z.__H=void 0,Y&&b.__e(Y,Z.__v))};var u4=typeof requestAnimationFrame=="function";function f5(X){var Y,Z=function(){clearTimeout(J),u4&&cancelAnimationFrame(Y),setTimeout(X)},J=setTimeout(Z,35);u4&&(Y=requestAnimationFrame(Z))}function v0(X){var Y=T,Z=X.__c;typeof Z=="function"&&(X.__c=void 0,Z()),T=Y}function z4(X){var Y=T;X.__c=X.__(),T=Y}function t4(X,Y){return!X||X.length!==Y.length||Y.some(function(Z,J){return Z!==X[J]})}function n4(X,Y){return typeof Y=="function"?Y(X):Y}function u5(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function e4(X,Y){for(var Z in X)if(Z!=="__source"&&!(Z in Y))return!0;for(var J in Y)if(J!=="__source"&&X[J]!==Y[J])return!0;return!1}function X5(X,Y){this.props=X,this.context=Y}(X5.prototype=new g).isPureReactComponent=!0,X5.prototype.shouldComponentUpdate=function(X,Y){return e4(this.props,X)||e4(this.state,Y)};var Y5=P.__b;P.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),Y5&&Y5(X)};var r5=P.__e;P.__e=function(X,Y,Z,J){if(X.then){for(var q,K=Y;K=K.__;)if((q=K.__c)&&q.__c)return Y.__e==null&&(Y.__e=Z.__e,Y.__k=Z.__k),q.__c(X,Y)}r5(X,Y,Z,J)};var Z5=P.unmount;function W5(X,Y,Z){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(J){typeof J.__c=="function"&&J.__c()}),X.__c.__H=null),(X=u5({},X)).__c!=null&&(X.__c.__P===Z&&(X.__c.__P=Y),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(J){return W5(J,Y,Z)})),X}function L5(X,Y,Z){return X&&Z&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(J){return L5(J,Y,Z)}),X.__c&&X.__c.__P===Y&&(X.__e&&Z.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=Z)),X}function G4(){this.__u=0,this.o=null,this.__b=null}function z5(X){var Y=X.__&&X.__.__c;return Y&&Y.__a&&Y.__a(X)}function y0(){this.i=null,this.l=null}P.unmount=function(X){var Y=X.__c;Y&&(Y.__z=!0),Y&&Y.__R&&Y.__R(),Y&&32&X.__u&&(X.type=null),Z5&&Z5(X)},(G4.prototype=new g).__c=function(X,Y){var Z=Y.__c,J=this;J.o==null&&(J.o=[]),J.o.push(Z);var q=z5(J.__v),K=!1,Q=function(){K||J.__z||(K=!0,Z.__R=null,q?q(G):G())};Z.__R=Q;var z=Z.__P;Z.__P=null;var G=function(){if(!--J.__u){if(J.state.__a){var L=J.state.__a;J.__v.__k[0]=L5(L,L.__c.__P,L.__c.__O)}var D;for(J.setState({__a:J.__b=null});D=J.o.pop();)D.__P=z,D.forceUpdate()}};J.__u++||32&Y.__u||J.setState({__a:J.__b=J.__v.__k[0]}),X.then(Q,Q)},G4.prototype.componentWillUnmount=function(){this.o=[]},G4.prototype.render=function(X,Y){if(this.__b){if(this.__v.__k){var Z=document.createElement("div"),J=this.__v.__k[0].__c;this.__v.__k[0]=W5(this.__b,Z,J.__O=J.__P)}this.__b=null}var q=Y.__a&&Y0(x,null,X.fallback);return q&&(q.__u&=-33),[Y0(x,null,Y.__a?null:X.children),q]};var J5=function(X,Y,Z){if(++Z[1]===Z[0]&&X.l.delete(Y),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(Z=X.i;Z;){for(;Z.length>3;)Z.pop()();if(Z[1]<Z[0])break;X.i=Z=Z[2]}};(y0.prototype=new g).__a=function(X){var Y=this,Z=z5(Y.__v),J=Y.l.get(X);return J[0]++,function(q){var K=function(){Y.props.revealOrder?(J.push(q),J5(Y,X,J)):q()};Z?Z(K):K()}},y0.prototype.render=function(X){this.i=null,this.l=new Map;var Y=Z0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Y.reverse();for(var Z=Y.length;Z--;)this.l.set(Y[Z],this.i=[1,0,this.i]);return X.children},y0.prototype.componentDidUpdate=y0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Y,Z){J5(X,Z,Y)})};var t5=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,n5=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,e5=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,X6=/[A-Z0-9]/g,Y6=typeof document<"u",Z6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};function N5(X,Y,Z){return Y.__k==null&&(Y.textContent=""),p0(X,Y),typeof Z=="function"&&Z(),X?X.__c:null}g.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(g.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Y){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Y})}})});var q5=P.event;P.event=function(X){return q5&&(X=q5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var G5,J6={configurable:!0,get:function(){return this.class}},K5=P.vnode;P.vnode=function(X){typeof X.type=="string"&&function(Y){var{props:Z,type:J}=Y,q={},K=J.indexOf("-")==-1;for(var Q in Z){var z=Z[Q];if(!(Q==="value"&&("defaultValue"in Z)&&z==null||Y6&&Q==="children"&&J==="noscript"||Q==="class"||Q==="className")){var G=Q.toLowerCase();Q==="defaultValue"&&"value"in Z&&Z.value==null?Q="value":Q==="download"&&z===!0?z="":G==="translate"&&z==="no"?z=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?Q="ondblclick":G!=="onchange"||J!=="input"&&J!=="textarea"||Z6(Z.type)?G==="onfocus"?Q="onfocusin":G==="onblur"?Q="onfocusout":e5.test(Q)&&(Q=G):G=Q="oninput":K&&n5.test(Q)?Q=Q.replace(X6,"-$&").toLowerCase():z===null&&(z=void 0),G==="oninput"&&q[Q=G]&&(Q="oninputCapture"),q[Q]=z}}J=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.value.indexOf(L.props.value)!=-1})),q.defaultValue!=null&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.multiple?q.defaultValue.indexOf(L.props.value)!=-1:q.defaultValue==L.props.value}))),Z.class&&!Z.className?(q.class=Z.class,Object.defineProperty(q,"className",J6)):Z.className&&(q.class=q.className=Z.className),Y.props=q}(X),X.$$typeof=t5,K5&&K5(X)};var Q5=P.__r;P.__r=function(X){Q5&&Q5(X),G5=X.__c};var $5=P.diffed;P.diffed=function(X){$5&&$5(X);var{props:Y,__e:Z}=X;Z!=null&&X.type==="textarea"&&"value"in Y&&Y.value!==Z.value&&(Z.value=Y.value==null?"":Y.value),G5=null};function V5(X){return!!X.__k&&(p0(null,X),!0)}function H5(X){return{render:function(Y){N5(Y,X)},unmount:function(){V5(X)}}}function I5(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function O5(X,Y){for(var Z in X)if(Z!=="__source"&&!(Z in Y))return!0;for(var J in Y)if(J!=="__source"&&X[J]!==Y[J])return!0;return!1}function U5(X,Y){this.props=X,this.context=Y}(U5.prototype=new g).isPureReactComponent=!0,U5.prototype.shouldComponentUpdate=function(X,Y){return O5(this.props,X)||O5(this.state,Y)};var A5=P.__b;P.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),A5&&A5(X)};var q6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.forward_ref")||3911;function G0(X){function Y(Z){var J=I5({},Z);return delete J.ref,X(J,Z.ref||null)}return Y.$$typeof=q6,Y.render=X,Y.prototype.isReactComponent=Y.__f=!0,Y.displayName="ForwardRef("+(X.displayName||X.name)+")",Y}var K6=P.__e;P.__e=function(X,Y,Z,J){if(X.then){for(var q,K=Y;K=K.__;)if((q=K.__c)&&q.__c)return Y.__e==null&&(Y.__e=Z.__e,Y.__k=Z.__k),q.__c(X,Y)}K6(X,Y,Z,J)};var D5=P.unmount;function M5(X,Y,Z){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(J){typeof J.__c=="function"&&J.__c()}),X.__c.__H=null),(X=I5({},X)).__c!=null&&(X.__c.__P===Z&&(X.__c.__P=Y),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(J){return M5(J,Y,Z)})),X}function C5(X,Y,Z){return X&&Z&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(J){return C5(J,Y,Z)}),X.__c&&X.__c.__P===Y&&(X.__e&&Z.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=Z)),X}function H4(){this.__u=0,this.o=null,this.__b=null}function E5(X){var Y=X.__&&X.__.__c;return Y&&Y.__a&&Y.__a(X)}function g0(){this.i=null,this.l=null}P.unmount=function(X){var Y=X.__c;Y&&(Y.__z=!0),Y&&Y.__R&&Y.__R(),Y&&32&X.__u&&(X.type=null),D5&&D5(X)},(H4.prototype=new g).__c=function(X,Y){var Z=Y.__c,J=this;J.o==null&&(J.o=[]),J.o.push(Z);var q=E5(J.__v),K=!1,Q=function(){K||J.__z||(K=!0,Z.__R=null,q?q(G):G())};Z.__R=Q;var z=Z.__P;Z.__P=null;var G=function(){if(!--J.__u){if(J.state.__a){var L=J.state.__a;J.__v.__k[0]=C5(L,L.__c.__P,L.__c.__O)}var D;for(J.setState({__a:J.__b=null});D=J.o.pop();)D.__P=z,D.forceUpdate()}};J.__u++||32&Y.__u||J.setState({__a:J.__b=J.__v.__k[0]}),X.then(Q,Q)},H4.prototype.componentWillUnmount=function(){this.o=[]},H4.prototype.render=function(X,Y){if(this.__b){if(this.__v.__k){var Z=document.createElement("div"),J=this.__v.__k[0].__c;this.__v.__k[0]=M5(this.__b,Z,J.__O=J.__P)}this.__b=null}var q=Y.__a&&Y0(x,null,X.fallback);return q&&(q.__u&=-33),[Y0(x,null,Y.__a?null:X.children),q]};var P5=function(X,Y,Z){if(++Z[1]===Z[0]&&X.l.delete(Y),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(Z=X.i;Z;){for(;Z.length>3;)Z.pop()();if(Z[1]<Z[0])break;X.i=Z=Z[2]}};(g0.prototype=new g).__a=function(X){var Y=this,Z=E5(Y.__v),J=Y.l.get(X);return J[0]++,function(q){var K=function(){Y.props.revealOrder?(J.push(q),P5(Y,X,J)):q()};Z?Z(K):K()}},g0.prototype.render=function(X){this.i=null,this.l=new Map;var Y=Z0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Y.reverse();for(var Z=Y.length;Z--;)this.l.set(Y[Z],this.i=[1,0,this.i]);return X.children},g0.prototype.componentDidUpdate=g0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Y,Z){P5(X,Z,Y)})};var Q6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,$6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,W6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,L6=/[A-Z0-9]/g,z6=typeof document<"u",N6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};g.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(g.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Y){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Y})}})});var B5=P.event;P.event=function(X){return B5&&(X=B5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var w5,G6={configurable:!0,get:function(){return this.class}},_5=P.vnode;P.vnode=function(X){typeof X.type=="string"&&function(Y){var{props:Z,type:J}=Y,q={},K=J.indexOf("-")==-1;for(var Q in Z){var z=Z[Q];if(!(Q==="value"&&("defaultValue"in Z)&&z==null||z6&&Q==="children"&&J==="noscript"||Q==="class"||Q==="className")){var G=Q.toLowerCase();Q==="defaultValue"&&"value"in Z&&Z.value==null?Q="value":Q==="download"&&z===!0?z="":G==="translate"&&z==="no"?z=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?Q="ondblclick":G!=="onchange"||J!=="input"&&J!=="textarea"||N6(Z.type)?G==="onfocus"?Q="onfocusin":G==="onblur"?Q="onfocusout":W6.test(Q)&&(Q=G):G=Q="oninput":K&&$6.test(Q)?Q=Q.replace(L6,"-$&").toLowerCase():z===null&&(z=void 0),G==="oninput"&&q[Q=G]&&(Q="oninputCapture"),q[Q]=z}}J=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.value.indexOf(L.props.value)!=-1})),q.defaultValue!=null&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.multiple?q.defaultValue.indexOf(L.props.value)!=-1:q.defaultValue==L.props.value}))),Z.class&&!Z.className?(q.class=Z.class,Object.defineProperty(q,"className",G6)):Z.className&&(q.class=q.className=Z.className),Y.props=q}(X),X.$$typeof=Q6,_5&&_5(X)};var F5=P.__r;P.__r=function(X){F5&&F5(X),w5=X.__c};var k5=P.diffed;P.diffed=function(X){k5&&k5(X);var{props:Y,__e:Z}=X;Z!=null&&X.type==="textarea"&&"value"in Y&&Y.value!==Z.value&&(Z.value=Y.value==null?"":Y.value),w5=null};var V6=0;function $(X,Y,Z,J,q,K){Y||(Y={});var Q,z,G=Y;if("ref"in G)for(z in G={},Y)z=="ref"?Q=Y[z]:G[z]=Y[z];var L={type:X,props:G,key:Z,ref:Q,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--V6,__i:-1,__u:0,__source:q,__self:K};if(typeof X=="function"&&(Q=X.defaultProps))for(z in Q)G[z]===void 0&&(G[z]=Q[z]);return P.vnode&&P.vnode(L),L}var O4=`url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle cx='10' cy='10' r='9' fill='rgba(255,255,255,0.4)' stroke='rgba(255,255,255,0.7)' stroke-width='1'/%3E%3C/svg%3E") 10 10, pointer`,H6=3,O6=4,U6=5;function x0({url:X,wsUrl:Y,style:Z,imageStyle:J,className:q,onHomePress:K,onStreamTouch:Q,onStreamMultiTouch:z,onStreamButton:G,subscribeFrame:L,streamFrame:D,streamConfig:W,hideControls:O,onStreamingChange:U,connectionQuality:k}){let _=!!Q,C=w(null),M=w(null),F=w(null),[E,I]=p(!1),[v,r]=p(null),[f,i]=p(null),y=w(null),[m,c0]=p(null);d(()=>{let V=y.current;if(!V||typeof ResizeObserver>"u")return;let H=new ResizeObserver((N)=>{let A=N[0]?.contentRect;if(A)c0({width:A.width,height:A.height})});return H.observe(V),()=>H.disconnect()},[]);let[D4,P4]=p(0),W0=w(0),[p5,l0]=p(!1),t=w(null);d(()=>{if(k==="poor"){if(l0(!0),t.current)clearTimeout(t.current);t.current=setTimeout(()=>{l0(!1),t.current=null},3000)}else if(l0(!1),t.current)clearTimeout(t.current),t.current=null;return()=>{if(t.current)clearTimeout(t.current)}},[k]);let i0=`${X}/stream.mjpeg`,B4=w(U);B4.current=U,d(()=>{B4.current?.(E)},[E]),d(()=>{if(_&&W)i(W)},[_,W]);let _4=w(!1);_4.current=E;let s0=w(null);d(()=>{if(!_||!L)return;return L((V)=>{W0.current++;let H=M.current;if(H){if(s0.current)URL.revokeObjectURL(s0.current);s0.current=V,H.src=V}if(!_4.current)console.log("[serve-sim] first frame received, rendering"),I(!0),r(null)})},[_,L]);let c=j((V)=>{if(_){Q?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify(V)),A=new Uint8Array(1+N.length);A[0]=H6,A.set(N,1),H.send(A)},[_,Q]),o0=j((V)=>{if(_){G?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify({button:V})),A=new Uint8Array(1+N.length);A[0]=O6,A.set(N,1),H.send(A)},[_,G]),n=j((V)=>{if(_){z?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify(V)),A=new Uint8Array(1+N.length);A[0]=U6,A.set(N,1),H.send(A)},[_,z]);d(()=>{if(_)return;fetch(`${X}/config`).then((B)=>B.json()).then((B)=>{if(B.width>0&&B.height>0)i(B)}).catch(()=>{});let V=Y??X.replace(/^http/,"ws")+"/ws",H=new WebSocket(V);H.binaryType="arraybuffer",F.current=H,H.onopen=()=>{I(!0),r(null)},H.onclose=()=>{I(!1)},H.onerror=()=>{r("WebSocket connection failed"),I(!1)};let N=new AbortController,A=setInterval(()=>{P4(W0.current),W0.current=0},1000);return(async()=>{try{let S=(await fetch(i0,{signal:N.signal})).body?.getReader();if(!S)return;let h=new TextEncoder().encode("--frame");while(!0){let{done:l,value:u}=await S.read();if(l)break;if(u)for(let e0=0;e0<=u.length-h.length;e0++){let E4=!0;for(let I0=0;I0<h.length;I0++)if(u[e0+I0]!==h[I0]){E4=!1;break}if(E4)W0.current++}}}catch{}})(),()=>{N.abort(),clearInterval(A),H.close(),F.current=null}},[X,i0,_]),d(()=>{if(!_)return;let V=setInterval(()=>{P4(W0.current),W0.current=0},1000);return()=>clearInterval(V)},[_]);let e=j(()=>{return _?M.current:C.current},[_]),B0=j((V,H)=>{let N=e();if(!N)return;let A=N.getBoundingClientRect(),B=(H.clientX-A.left)/A.width,S=(H.clientY-A.top)/A.height;c({type:V,x:B,y:S})},[c]),Q0=3,a=w(!1),o=w(!1),u0=w(!1),r0=w({dx:0,dy:0}),V0=w(!1),[t0,F4]=p(!1),k4=w({x:0.5,y:0.5}),[q0,s]=p(null);d(()=>{let V=(N)=>{if(N.key==="Alt")F4(!0)},H=(N)=>{if(N.key==="Alt"){if(F4(!1),!o.current)s(null)}};return window.addEventListener("keydown",V),window.addEventListener("keyup",H),()=>{window.removeEventListener("keydown",V),window.removeEventListener("keyup",H)}},[]),d(()=>{if(t0&&!o.current){let V=k4.current;s({x1:V.x,y1:V.y,x2:1-V.x,y2:1-V.y})}else if(!t0&&!o.current)s(null)},[t0]);let _0=w(null),n0=w(!1),H0=w(0),I4=j((V,H)=>{n0.current=!0;let N=_0.current;if(N)cancelAnimationFrame(H0.current),H0.current=requestAnimationFrame(()=>{N.style.left=`${V*100}%`,N.style.top=`${H*100}%`,N.style.display="block"})},[]),M4=j((V,H)=>{if(!n0.current)return;let N=_0.current;if(N)cancelAnimationFrame(H0.current),H0.current=requestAnimationFrame(()=>{N.style.left=`${V*100}%`,N.style.top=`${H*100}%`})},[]),F0=j(()=>{n0.current=!1;let V=_0.current;if(V)cancelAnimationFrame(H0.current),V.style.display="none"},[]),C4=w(0),O0=w(null),v5=j(()=>{let V=Date.now(),H=V-C4.current;if(C4.current=V,H<300){if(O0.current)clearTimeout(O0.current),O0.current=null;if(K)K();else o0("app_switcher")}else O0.current=setTimeout(()=>{if(K)K();else o0("home");O0.current=null},300)},[o0,K]),k0=(()=>{if(!f||!m)return null;if(m.width===0||m.height===0)return null;let V=Math.min(m.width/f.width,m.height/f.height);return{width:f.width*V,height:f.height*V}})();return $("div",{style:{display:"flex",flexDirection:"column",flex:1,...O?{}:{border:"1px solid rgba(255,255,255,0.12)"},overflow:"hidden",minWidth:0,minHeight:0,...Z},className:q,children:[$("div",{ref:y,style:{position:"relative",flex:1,minHeight:0,minWidth:0,display:"flex",alignItems:"center",justifyContent:"center"},children:$("div",{style:{position:"relative",width:k0?`${k0.width}px`:"100%",height:k0?`${k0.height}px`:"100%"},children:[$("img",{ref:C,src:_?void 0:i0,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)i((N)=>N&&N.width===H.naturalWidth&&N.height===H.naturalHeight?N:{width:H.naturalWidth,height:H.naturalHeight})},style:_?{display:"none"}:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:O4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...J}}),_&&$("img",{ref:M,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)i((N)=>N&&N.width===H.naturalWidth&&N.height===H.naturalHeight?N:{width:H.naturalWidth,height:H.naturalHeight})},style:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:O4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...J}}),$("div",{style:{position:"absolute",inset:0,cursor:O4,touchAction:"none"},onMouseDown:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(V.altKey){o.current=!0,u0.current=V.shiftKey;let S={x1:A,y1:B,x2:1-A,y2:1-B};r0.current={dx:1-A-A,dy:1-B-B},s(S),n({type:"begin",...S});return}if(I4(A,B),B>0.88)a.current=!0,c({type:"begin",x:A,y:B,edge:Q0});else a.current=!1,B0("begin",V)},onMouseMove:(V)=>{let H=e();if(!H)return;let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(k4.current={x:A,y:B},V.buttons===0){if(V.altKey)s({x1:A,y1:B,x2:1-A,y2:1-B});return}if(o.current){let S;if(u0.current){let h=r0.current;S={x1:A,y1:B,x2:A+h.dx,y2:B+h.dy}}else S={x1:A,y1:B,x2:1-A,y2:1-B};s(S),n({type:"move",...S});return}if(M4(A,B),a.current)c({type:"move",x:A,y:B,edge:Q0});else B0("move",V)},onMouseUp:(V)=>{if(o.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(u0.current){let S=r0.current;n({type:"end",x1:A,y1:B,x2:A+S.dx,y2:B+S.dy})}else n({type:"end",x1:A,y1:B,x2:1-A,y2:1-B})}if(o.current=!1,!V.altKey)s(null);return}if(F0(),a.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;c({type:"end",x:A,y:B,edge:Q0})}a.current=!1;return}B0("end",V)},onMouseLeave:(V)=>{if(o.current){if(q0)n({type:"end",...q0});o.current=!1,s(null);return}if(F0(),a.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;c({type:"end",x:A,y:B,edge:Q0})}a.current=!1;return}if(V.buttons>0)B0("end",V);s(null)},onTouchStart:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V.touches.length>=2){F0();let h=V.touches[0],l=V.touches[1],u={x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:(l.clientX-N.left)/N.width,y2:(l.clientY-N.top)/N.height};if(!V0.current&&!a.current)c({type:"end",x:u.x1,y:u.y1});V0.current=!0,o.current=!0,a.current=!1,s(u),n({type:"begin",...u});return}let A=V.touches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(I4(B,S),S>0.88)a.current=!0,c({type:"begin",x:B,y:S,edge:Q0});else a.current=!1,c({type:"begin",x:B,y:S})},onTouchMove:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V0.current&&V.touches.length>=2){let h=V.touches[0],l=V.touches[1],u={x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:(l.clientX-N.left)/N.width,y2:(l.clientY-N.top)/N.height};s(u),n({type:"move",...u});return}let A=V.touches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(M4(B,S),a.current)c({type:"move",x:B,y:S,edge:Q0});else c({type:"move",x:B,y:S})},onTouchEnd:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V0.current){if(V.touches.length<2){let h=V.changedTouches[0],l=q0;if(h&&l)n({type:"end",x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:l.x2,y2:l.y2});else if(l)n({type:"end",...l});V0.current=!1,o.current=!1,s(null)}return}let A=V.changedTouches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(F0(),a.current)c({type:"end",x:B,y:S,edge:Q0}),a.current=!1;else c({type:"end",x:B,y:S})}}),$("div",{ref:_0,"data-testid":"touch-indicator",style:{position:"absolute",display:"none",width:24,height:24,borderRadius:"50%",background:"rgba(59,130,246,0.5)",boxShadow:"0 0 8px rgba(59,130,246,0.3)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}),q0&&$(x,{children:[$("div",{"data-testid":"finger-dot",style:b5(q0.x1,q0.y1)}),$("div",{"data-testid":"finger-dot",style:b5(q0.x2,q0.y2)})]}),!E&&!v&&$("div",{style:S5,children:$("span",{style:{color:"#888",fontSize:14},children:"Connecting..."})}),v&&$("div",{style:S5,children:$("span",{style:{color:"#f44",fontSize:14,padding:20,textAlign:"center"},children:v})}),p5&&$("div",{style:A6,children:$("span",{style:{color:"#fbbf24",fontSize:13,fontFamily:"monospace"},children:"Slow connection"})})]})}),!O&&$("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 8px",borderTop:"1px solid rgba(255,255,255,0.12)"},children:[$("button",{onClick:v5,style:{background:"none",border:"1px solid rgba(255,255,255,0.2)",color:"#aaa",fontSize:11,fontFamily:"monospace",padding:"2px 10px",cursor:"pointer",borderRadius:4},children:"Home"}),$("span",{style:{color:D4>0?"#4f4":"#888",fontSize:12,fontFamily:"monospace",display:"flex",alignItems:"center",gap:6},children:[k&&$("span",{"data-testid":"quality-dot",style:{width:8,height:8,borderRadius:"50%",display:"inline-block",background:k==="good"?"#4ade80":k==="degraded"?"#facc15":"#ef4444"}}),D4," fps"]})]})]})}var A6={position:"absolute",top:8,left:"50%",transform:"translateX(-50%)",background:"rgba(0,0,0,0.7)",borderRadius:6,padding:"4px 12px",pointerEvents:"none"},S5={position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.8)"},T5=20;function b5(X,Y){return{position:"absolute",left:`${X*100}%`,top:`${Y*100}%`,width:T5,height:T5,borderRadius:"50%",background:"rgba(255,255,255,0.4)",border:"1px solid rgba(255,255,255,0.7)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}function d0(X){if(!X)return"iphone";let Y=X.toLowerCase();if(Y.includes("ipad"))return"ipad";if(Y.includes("watch"))return"watch";if(Y.includes("vision"))return"vision";return"iphone"}var R={iphone:{width:427,height:881,bezelX:18,bezelY:18,innerRadius:55},ipad:{width:430,height:605,bezelX:16,bezelY:16,innerRadius:12},watch:{width:274,height:322,bezelX:12,bezelY:12,innerRadius:79},vision:{width:640,height:400,bezelX:12,bezelY:12,innerRadius:32}},U7=R.iphone.width,A7=R.iphone.height,D7=R.iphone.bezelX,P7=R.iphone.bezelY,B7=R.iphone.innerRadius;function U4(X="iphone"){let Y=R[X];return{top:`${Y.bezelY/Y.height*100}%`,left:`${Y.bezelX/Y.width*100}%`,right:`${Y.bezelX/Y.width*100}%`,bottom:`${Y.bezelY/Y.height*100}%`}}function m0(X="iphone"){let Y=R[X],Z=Y.width-2*Y.bezelX,J=Y.height-2*Y.bezelY;return`${Y.innerRadius/Z*100}% / ${Y.innerRadius/J*100}%`}function h0({type:X="iphone",streaming:Y=!1}){switch(X){case"ipad":return $(B6,{streaming:Y});case"watch":return $(_6,{streaming:Y});case"vision":return $(F6,{streaming:Y});default:return $(P6,{streaming:Y})}}function P6({streaming:X=!1}){return $("svg",{viewBox:"0 0 427 881",style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"chrome-filter0",x:"-0.166992",y:"0.166504",width:"427",height:"880.667",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"effect1_foregroundBlur"})]}),$("filter",{id:"chrome-filter1",x:"6.33236",y:"6.33382",width:"414",height:"868",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333333",result:"effect1_foregroundBlur"})]})]}),$("rect",{x:"3.83268",y:"3.83366",width:"419",height:"873",rx:"66.1667",stroke:"#454548",strokeWidth:"4.33333"}),$("rect",{x:"0.833333",y:"0.833333",width:"425",height:"879",rx:"69.1667",stroke:"#37373a",strokeWidth:"1.66667"}),$("g",{opacity:"0.9",filter:"url(#chrome-filter0)",children:$("rect",{x:"1.66602",y:"2",width:"423.333",height:"877",rx:"68.6667",stroke:"#454548",strokeWidth:"1.66667"})}),$("g",{opacity:"0.8",filter:"url(#chrome-filter1)",children:$("rect",{x:"7.33268",y:"7.33366",width:"412",height:"866",rx:"62.6667",stroke:"#646464",strokeWidth:"0.666667"})}),$("rect",{x:"151.666",y:"31.667",width:"123.333",height:"36",rx:"18",fill:"black",style:{opacity:X?0:1,transition:"opacity 0.3s ease"}})]})}function B6({streaming:X=!1}){let Y=R.ipad.width,Z=R.ipad.height,J=30,q=26;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"ipad-glow0",x:"0",y:"0",width:Y,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]}),$("filter",{id:"ipad-glow1",x:"5",y:"5",width:Y-10,height:Z-10,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333333",result:"blur"})]})]}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:26,stroke:"#454548",strokeWidth:"4"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:30,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#ipad-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:29,stroke:"#454548",strokeWidth:"1.666"})}),$("g",{opacity:"0.8",filter:"url(#ipad-glow1)",children:$("rect",{x:"6",y:"6",width:Y-12,height:Z-12,rx:24,stroke:"#646464",strokeWidth:"0.666"})}),$("circle",{cx:Y/2,cy:R.ipad.bezelY/2+1,r:"3",fill:"#1a1a1a",style:{opacity:X?0:0.8,transition:"opacity 0.3s ease"}}),$("rect",{x:(Y-120)/2,y:Z-R.ipad.bezelY/2-2.5,width:"120",height:"5",rx:"2.5",fill:"white",style:{opacity:X?0:0.35,mixBlendMode:"difference",transition:"opacity 0.3s ease"}})]})}function _6({streaming:X=!1}){let Y=R.watch.width,Z=R.watch.height,J=88,q=82,K=8,Q=36,z=Z/2-18-16,G=22,L=Z/2-11+16;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%",overflow:"visible"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:$("filter",{id:"watch-glow0",x:"0",y:"0",width:Y+12,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]})}),$("rect",{x:Y-2,y:z,width:8,height:36,rx:"3",fill:"#2a2a2c",stroke:"#454548",strokeWidth:"1"}),$("rect",{x:Y-1,y:L,width:6,height:22,rx:"2.5",fill:"#2a2a2c",stroke:"#454548",strokeWidth:"0.8"}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:82,stroke:"#454548",strokeWidth:"3.5"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:88,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#watch-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:87,stroke:"#454548",strokeWidth:"1.666"})})]})}function F6({streaming:X=!1}){let Y=R.vision.width,Z=R.vision.height,J=40,q=34;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"vision-glow0",x:"0",y:"0",width:Y,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]}),$("filter",{id:"vision-glow1",x:"5",y:"5",width:Y-10,height:Z-10,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333",result:"blur"})]}),$("linearGradient",{id:"vision-glass",x1:"0",y1:"0",x2:"0",y2:"1",children:[$("stop",{offset:"0%",stopColor:"#555558",stopOpacity:"0.3"}),$("stop",{offset:"100%",stopColor:"#3a3a3d",stopOpacity:"0.1"})]})]}),$("rect",{x:"0",y:"0",width:Y,height:Z,rx:40,fill:"url(#vision-glass)"}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:34,stroke:"#454548",strokeWidth:"3"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:40,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#vision-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:39,stroke:"#454548",strokeWidth:"1.666"})}),$("g",{opacity:"0.8",filter:"url(#vision-glow1)",children:$("rect",{x:"6",y:"6",width:Y-12,height:Z-12,rx:32,stroke:"#646464",strokeWidth:"0.666"})}),$("ellipse",{cx:Y/2,cy:Z/2,rx:Y/2-30,ry:Z/2-24,stroke:"#4a4a4d",strokeWidth:"0.5",opacity:"0.3",style:{opacity:X?0:0.3,transition:"opacity 0.3s ease"}})]})}var A4=z0(null);function f0(X){let Y=P0(A4);if(!Y)throw Error(`<SimulatorToolbar.${X}> must be rendered inside <SimulatorToolbar>`);return Y}var M6={display:"flex",flexWrap:"wrap",alignItems:"center",justifyContent:"space-between",gap:"4px 12px",padding:"8px 12px",borderRadius:24,background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.1)",boxShadow:"0 1px 2px rgba(0,0,0,0.2)",minWidth:240,width:"100%"};function C6({exec:X,deviceUdid:Y,deviceName:Z,deviceRuntime:J,streaming:q=!1,disabled:K=!1,children:Q,style:z,...G}){let L=d0(Z),W={exec:X,deviceUdid:Y,deviceName:Z,deviceRuntime:J,deviceType:L,streaming:q,disabled:K||!Y||!q};return $(A4.Provider,{value:W,children:$("div",{"data-simulator-toolbar":!0,style:{...M6,...z},...G,children:Q})})}var E6={display:"flex",flexDirection:"column",alignItems:"flex-start",textAlign:"left",background:"transparent",border:"none",color:"#fff",padding:"2px 4px",margin:"-2px -4px",borderRadius:6,cursor:"pointer",minWidth:0,maxWidth:"100%",lineHeight:1.2,fontFamily:"inherit"},w6=G0(function({name:Y,subtitle:Z,hideChevron:J,style:q,onMouseEnter:K,onMouseLeave:Q,...z},G){let L=f0("Title"),[D,W]=p(!1),O=Y??L.deviceName??"No simulator",U=Z??(L.deviceRuntime?L.deviceRuntime.replace(/\./," "):"—");return $("button",{ref:G,type:"button","data-simulator-toolbar-title":!0,onMouseEnter:(k)=>{W(!0),K?.(k)},onMouseLeave:(k)=>{W(!1),Q?.(k)},style:{...E6,background:D?"rgba(255,255,255,0.1)":"transparent",...q},...z,children:[$("span",{style:{display:"inline-flex",alignItems:"center",gap:4,fontSize:12,fontWeight:600,color:"#fff",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:[O,!J&&$("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"rgba(255,255,255,0.6)",flexShrink:0},children:$("polyline",{points:"6 9 12 15 18 9"})})]}),$("span",{style:{fontSize:10,color:"rgba(255,255,255,0.5)",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:U})]})}),S6={display:"flex",alignItems:"center",gap:4,flexShrink:0};function T6({style:X,...Y}){return $("div",{style:{...S6,...X},...Y})}var b6={background:"transparent",border:"none",padding:6,borderRadius:6,cursor:"pointer",display:"inline-flex",alignItems:"center",justifyContent:"center",color:"rgba(255,255,255,0.8)",transition:"background-color 0.15s, color 0.15s"},a0=G0(function({forceDisabled:Y,style:Z,disabled:J,onMouseEnter:q,onMouseLeave:K,children:Q,...z},G){let L=P0(A4),D=J||Y||L?.disabled,[W,O]=p(!1);return $("button",{ref:G,type:"button",disabled:D,onMouseEnter:(U)=>{O(!0),q?.(U)},onMouseLeave:(U)=>{O(!1),K?.(U)},style:{...b6,color:D?"rgba(255,255,255,0.25)":"rgba(255,255,255,0.8)",background:W&&!D?"rgba(255,255,255,0.1)":"transparent",cursor:D?"not-allowed":"pointer",...Z},...z,children:Q})});function p6(){return['tell application "System Events" to tell process "Simulator" to set frontmost to true','tell application "System Events" to tell process "Simulator" to perform action "AXRaise" of (first window whose name contains "watchOS")','tell application "System Events" to tell process "Simulator" to click menu item "Home" of menu "Device" of menu bar item "Device" of menu bar 1'].map((Y)=>`-e '${Y}'`).reduce((Y,Z)=>`${Y} ${Z}`,"osascript")}var v6=$("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:$("path",{d:"M3 10.5 12 3l9 7.5V20a1 1 0 0 1-1 1h-5v-7h-6v7H4a1 1 0 0 1-1-1z"})}),j6=$("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[$("path",{d:"M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3z"}),$("circle",{cx:"12",cy:"13",r:"4"})]}),R6=$("svg",{width:"18",height:"18",viewBox:"0 0 12 13",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",children:$("path",{d:"M10.2305 12.8077H4.42383C3.92383 12.8077 3.54688 12.6846 3.29297 12.4385C3.04297 12.1963 2.91797 11.8194 2.91797 11.3077V5.51274C2.91797 4.99711 3.04297 4.61821 3.29297 4.37602C3.54688 4.12993 3.92383 4.00688 4.42383 4.00688H10.2305C10.7344 4.00688 11.1113 4.12993 11.3613 4.37602C11.6113 4.61821 11.7363 4.99711 11.7363 5.51274V11.3077C11.7363 11.8194 11.6113 12.1963 11.3613 12.4385C11.1113 12.6846 10.7344 12.8077 10.2305 12.8077ZM10.2129 11.8643C10.416 11.8643 10.5625 11.8194 10.6523 11.7295C10.7461 11.6436 10.793 11.4971 10.793 11.2901V5.52446C10.793 5.31743 10.7461 5.17094 10.6523 5.08501C10.5625 4.99516 10.416 4.95024 10.2129 4.95024H4.44141C4.24219 4.95024 4.0957 4.99516 4.00195 5.08501C3.9082 5.17094 3.86133 5.31743 3.86133 5.52446V11.2901C3.86133 11.4971 3.9082 11.6436 4.00195 11.7295C4.0957 11.8194 4.24219 11.8643 4.44141 11.8643H10.2129ZM2.91797 2.58305V0.415083C2.91797 0.20024 2.98633 0.0693803 3.12305 0.0225053C3.25977 -0.0282759 3.41016 0.00688033 3.57422 0.127974L5.05078 1.21196C5.17578 1.30571 5.23828 1.40141 5.23828 1.49907C5.23828 1.59672 5.17578 1.69243 5.05078 1.78618L3.57422 2.8643C3.41016 2.9854 3.25977 3.02251 3.12305 2.97563C2.98633 2.92485 2.91797 2.79399 2.91797 2.58305ZM3.5332 1.15336C3.62695 1.15336 3.70703 1.18657 3.77344 1.25297C3.84375 1.31938 3.87891 1.39751 3.87891 1.48735C3.87891 1.5811 3.84375 1.66313 3.77344 1.73344C3.70703 1.79985 3.62695 1.83305 3.5332 1.83305H2.80664C2.38086 1.83305 2.01172 1.92485 1.69922 2.10844C1.39062 2.28813 1.15234 2.53813 0.984375 2.85844C0.816406 3.17876 0.732422 3.54594 0.732422 3.96001V4.83891C0.732422 4.93657 0.697266 5.02251 0.626953 5.09672C0.552734 5.16704 0.464844 5.20219 0.363281 5.20219C0.265625 5.20219 0.181641 5.16704 0.111328 5.09672C0.0371094 5.02251 0 4.93657 0 4.83891V3.96001C0 3.40141 0.117188 2.91118 0.351562 2.4893C0.582031 2.06743 0.908203 1.7393 1.33008 1.50493C1.74805 1.27055 2.23828 1.15336 2.80078 1.15336H3.5332Z"})}),y6=G0(function({onClick:Y,...Z},J){let q=f0("HomeButton");return $(a0,{ref:J,"aria-label":"Home",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceType==="watch")q.exec(p6());else q.exec("serve-sim button home")},...Z,children:v6})}),g6=G0(function({onClick:Y,...Z},J){let q=f0("ScreenshotButton");return $(a0,{ref:J,"aria-label":"Screenshot",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceUdid)q.exec(`xcrun simctl io ${q.deviceUdid} screenshot ~/Desktop/hatch-screenshot-$(date +%s).png`)},...Z,children:j6})}),x6=G0(function({onClick:Y,...Z},J){let q=f0("RotateButton");return $(a0,{ref:J,"aria-label":"Rotate device",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceUdid)q.exec(`osascript -e 'tell application "Simulator" to activate' -e 'tell application "System Events" to key code 124 using {command down}'`)},...Z,children:R6})}),$0=C6;$0.Title=w6;$0.Actions=T6;$0.Button=a0;$0.HomeButton=y6;$0.ScreenshotButton=g6;$0.RotateButton=x6;function d6(X){let[Y,Z]=p(null),J=w(new Set),[q,K]=p(null),Q=j((z)=>{return J.current.add(z),()=>{J.current.delete(z)}},[]);return d(()=>{if(!X)return;let z=new AbortController,G=X.replace(/\/stream\.mjpeg$/,"");return fetch(`${G}/config`,{signal:z.signal}).then((L)=>L.json()).then((L)=>{if(L.width>0&&L.height>0)Z(L)}).catch(()=>{}),(async()=>{try{let D=(await fetch(X,{signal:z.signal})).body?.getReader();if(!D)return;let W=new Uint8Array(0);while(!0){let{done:O,value:U}=await D.read();if(O)break;let k=new Uint8Array(W.length+U.length);k.set(W),k.set(U,W.length),W=k;while(!0){let _=-1;for(let I=0;I<W.length-1;I++)if(W[I]===255&&W[I+1]===216){_=I;break}if(_===-1)break;let C=-1;for(let I=_+2;I<W.length-1;I++)if(W[I]===255&&W[I+1]===217){C=I+2;break}if(C===-1)break;let M=W.slice(_,C);W=W.slice(C);let F=new Blob([M],{type:"image/jpeg"}),E=URL.createObjectURL(F);K(E);for(let I of J.current)I(E)}}}catch{}})(),()=>z.abort()},[X]),{subscribeFrame:Q,frame:q,config:Y}}function m6(){let X=window.__SIM_PREVIEW__,[Y,Z]=p(!1);if(d(()=>{if(!X?.logsEndpoint)return;let O=new EventSource(X.logsEndpoint),U=new Map,k=["#8be9fd","#50fa7b","#ffb86c","#ff79c6","#bd93f9","#f1fa8c","#6272a4","#ff5555","#69ff94","#d6acff","#ffffa5","#a4ffff","#ff6e6e","#caa9fa","#5af78e"];function _(F){let E=U.get(F);if(!E){let I=0;for(let v=0;v<F.length;v++)I=(I<<5)-I+F.charCodeAt(v)|0;E=k[Math.abs(I)%k.length],U.set(F,E)}return E}let C="",M=!1;return O.onmessage=(F)=>{try{let E=JSON.parse(F.data),I=E.processImagePath?.split("/").pop()??E.senderImagePath?.split("/").pop()??"",v=E.subsystem??"",r=E.category??"",f=E.eventMessage??"";if(!f)return;if(I!==C){if(M)console.groupEnd();let c0=_(I);console.groupCollapsed(`%c${I}${v?` %c${v}${r?":"+r:""}`:""}`,`color:${c0};font-weight:bold`,...v?["color:#888;font-weight:normal"]:[]),M=!0,C=I}let i=(E.messageType??"").toLowerCase(),y=v&&I===C?`%c${r||v}%c `:"",m=y?["color:#888;font-style:italic","color:inherit"]:[];if(i==="fault"||i==="error")console.log(`${y}%c${f}`,...m,"color:#ff5555");else if(i==="debug")console.log(`${y}%c${f}`,...m,"color:#6272a4");else console.log(`${y}%c${f}`,...m,"color:inherit")}catch{}},()=>{if(M)console.groupEnd();O.close()}},[X?.logsEndpoint]),!X)return $("div",{style:J0.page,children:$("div",{style:J0.empty,children:[$("h1",{style:J0.emptyTitle,children:"No serve-sim stream running"}),$("p",{style:J0.emptyHint,children:["Boot an iOS simulator and start a Hatch stream with"," ",$("code",{style:J0.code,children:"bunx serve-sim --detach"}),", then reload."]})]})});let J=R.iphone,q=U4("iphone"),K=m0("iphone"),Q=d6(X.streamUrl),z=w(null);d(()=>{let O=new WebSocket(X.wsUrl);return O.binaryType="arraybuffer",z.current=O,()=>{O.close(),z.current=null}},[X.wsUrl]);let G=j((O,U)=>{let k=z.current;if(!k||k.readyState!==WebSocket.OPEN)return;let _=new TextEncoder().encode(JSON.stringify(U)),C=new Uint8Array(1+_.length);C[0]=O,C.set(_,1),k.send(C)},[]),L=j((O)=>G(3,O),[G]),D=j((O)=>G(5,O),[G]),W=j((O)=>G(4,{button:O}),[G]);return $("div",{style:J0.page,children:[$("div",{style:{position:"relative",maxWidth:320,width:"100%",aspectRatio:`${J.width} / ${J.height}`},children:[$("div",{style:{position:"absolute",...q},children:$(x0,{url:X.url,style:{width:"100%",height:"100%",border:"none"},imageStyle:{borderRadius:K,cornerShape:"superellipse(1.3)"},hideControls:!0,onStreamingChange:Z,onStreamTouch:L,onStreamMultiTouch:D,onStreamButton:W,subscribeFrame:Q.subscribeFrame,streamFrame:Q.frame,streamConfig:Q.config})}),$("div",{style:{position:"absolute",inset:0,pointerEvents:"none",zIndex:10},children:$(h0,{type:"iphone",streaming:Y})})]}),$("div",{style:J0.bar,children:$("span",{style:{...J0.live,color:Y?"#4ade80":"#666"},children:[$("span",{style:{...J0.dot,background:Y?"#4ade80":"#666"}}),Y?"live":"connecting"]})})]})}var J0={page:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",background:"#0a0a0a",padding:24,gap:12,fontFamily:"-apple-system, system-ui, sans-serif"},bar:{display:"flex",alignItems:"center",gap:10,fontSize:12,fontFamily:"ui-monospace, monospace",color:"#666"},live:{display:"flex",alignItems:"center",gap:5,transition:"color 0.3s"},dot:{width:6,height:6,borderRadius:"50%",transition:"background 0.3s"},empty:{display:"flex",flexDirection:"column",alignItems:"center",gap:12,textAlign:"center"},emptyTitle:{fontSize:18,margin:0,color:"#eee"},emptyHint:{color:"#888",fontSize:14,maxWidth:480},code:{background:"#222",padding:"2px 6px",borderRadius:4,fontSize:13}};H5(document.getElementById("root")).render($(m6,{}));
</script>
</body></html>","base64").toString("utf-8");return $}function y(U){let B=(U?.basePath??"/.sim").replace(/\/+$/,"");return(G,z,w)=>{let M=G.url??"";if(M===B||M===B+"/"){let V=Z()[0]??null,K=D();if(V){let X=`<script>window.__SIM_PREVIEW__=${JSON.stringify({...V,logsEndpoint:B+"/logs"})}</script>`;K=K.replace("<!--__SIM_PREVIEW_CONFIG__-->",X)}z.writeHead(200,{"Content-Type":"text/html; charset=utf-8","Cache-Control":"no-store"}),z.end(K);return}if(M===B+"/api"){let Q=Z();z.writeHead(200,{"Content-Type":"application/json","Cache-Control":"no-store"}),z.end(JSON.stringify(Q[0]||null));return}if(M===B+"/logs"||M.startsWith(B+"/logs?")){let Q=Z();if(Q.length===0){z.writeHead(404),z.end("No serve-sim device");return}let V=Q[0].device;z.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),z.write(`:
|
|
2
|
+
import{readdirSync as y,readFileSync as x,existsSync as E}from"fs";import{spawn as U,exec as g,execFile as N}from"child_process";import{tmpdir as k}from"os";import{join as j}from"path";var B=j(k(),"serve-sim"),R=new Set(["host.exp.Exponent","dev.expo.Exponent"]),q=["Frameworks/React.framework","Frameworks/hermes.framework","Frameworks/Hermes.framework","Frameworks/ExpoModulesCore.framework","main.jsbundle"],_=/(WidgetRenderer|ExtensionHost|\.extension(\.|$)|Service|PlaceholderApp|InCallService|CallUI|InCallUI|com\.apple\.Preferences\.Cellular|com\.apple\.purplebuddy|com\.apple\.chrono|com\.apple\.shuttle|com\.apple\.usernotificationsui)/i;function I($){return!_.test($)}function v($,C){if(R.has(C))return Promise.resolve(!0);return new Promise((J)=>{N("xcrun",["simctl","get_app_container",$,C,"app"],{timeout:2000},(z,K)=>{if(z)return J(!1);let X=K.trim();if(!X)return J(!1);for(let W of q)if(E(j(X,W)))return J(!0);J(!1)})})}function O(){let $;try{$=y(B).filter((J)=>J.startsWith("server-")&&J.endsWith(".json"))}catch{return[]}let C=[];for(let J of $)try{let z=JSON.parse(x(j(B,J),"utf-8"));try{process.kill(z.pid,0),C.push(z)}catch{}}catch{}return C}var P=null;function p(){if(!P)P=Buffer.from("<!doctype html>
<html><head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Simulator Preview</title>
<style>*,*::before,*::after{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}</style>
</head><body>
<div id="root"></div>
<!--__SIM_PREVIEW_CONFIG__-->
<script type="module">var c0,B,R4,x5,P0,T4,j4,v4,K4,m0,T0,y4,N4,$4,z4,p4,f0={},a0=[],h5=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,b0=Array.isArray;function z0(X,Z){for(var J in Z)X[J]=Z[J];return X}function G4(X){X&&X.parentNode&&X.parentNode.removeChild(X)}function W0(X,Z,J){var Y,q,Q,K={};for(Q in Z)Q=="key"?Y=Z[Q]:Q=="ref"?q=Z[Q]:K[Q]=Z[Q];if(arguments.length>2&&(K.children=arguments.length>3?c0.call(arguments,2):J),typeof X=="function"&&X.defaultProps!=null)for(Q in X.defaultProps)K[Q]===void 0&&(K[Q]=X.defaultProps[Q]);return d0(X,K,Y,q,null)}function d0(X,Z,J,Y,q){var Q={type:X,props:Z,key:J,ref:Y,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:q==null?++R4:q,__i:-1,__u:0};return q==null&&B.vnode!=null&&B.vnode(Q),Q}function d(X){return X.children}function c(X,Z){this.props=X,this.context=Z}function B0(X,Z){if(Z==null)return X.__?B0(X.__,X.__i+1):null;for(var J;Z<X.__k.length;Z++)if((J=X.__k[Z])!=null&&J.__e!=null)return J.__e;return typeof X.type=="function"?B0(X):null}function m5(X){if(X.__P&&X.__d){var Z=X.__v,J=Z.__e,Y=[],q=[],Q=z0({},Z);Q.__v=Z.__v+1,B.vnode&&B.vnode(Q),V4(X.__P,Q,Z,X.__n,X.__P.namespaceURI,32&Z.__u?[J]:null,Y,J==null?B0(Z):J,!!(32&Z.__u),q),Q.__v=Z.__v,Q.__.__k[Q.__i]=Q,m4(Y,Q,q),Z.__e=Z.__=null,Q.__e!=J&&g4(Q)}}function g4(X){if((X=X.__)!=null&&X.__c!=null)return X.__e=X.__c.base=null,X.__k.some(function(Z){if(Z!=null&&Z.__e!=null)return X.__e=X.__c.base=Z.__e}),g4(X)}function W4(X){(!X.__d&&(X.__d=!0)&&P0.push(X)&&!l0.__r++||T4!=B.debounceRendering)&&((T4=B.debounceRendering)||j4)(l0)}function l0(){try{for(var X,Z=1;P0.length;)P0.length>Z&&P0.sort(v4),X=P0.shift(),Z=P0.length,m5(X)}finally{P0.length=l0.__r=0}}function x4(X,Z,J,Y,q,Q,K,W,G,z,P){var $,_,O,C,A,k,I,M=Y&&Y.__k||a0,h=Z.length;for(G=d5(J,Z,M,G,h),$=0;$<h;$++)(O=J.__k[$])!=null&&(_=O.__i!=-1&&M[O.__i]||f0,O.__i=$,k=V4(X,O,_,q,Q,K,W,G,z,P),C=O.__e,O.ref&&_.ref!=O.ref&&(_.ref&&H4(_.ref,null,O),P.push(O.ref,O.__c||C,O)),A==null&&C!=null&&(A=C),(I=!!(4&O.__u))||_.__k===O.__k?(G=h4(O,G,X,I),I&&_.__e&&(_.__e=null)):typeof O.type=="function"&&k!==void 0?G=k:C&&(G=C.nextSibling),O.__u&=-7);return J.__e=A,G}function d5(X,Z,J,Y,q){var Q,K,W,G,z,P=J.length,$=P,_=0;for(X.__k=Array(q),Q=0;Q<q;Q++)(K=Z[Q])!=null&&typeof K!="boolean"&&typeof K!="function"?(typeof K=="string"||typeof K=="number"||typeof K=="bigint"||K.constructor==String?K=X.__k[Q]=d0(null,K,null,null,null):b0(K)?K=X.__k[Q]=d0(d,{children:K},null,null,null):K.constructor===void 0&&K.__b>0?K=X.__k[Q]=d0(K.type,K.props,K.key,K.ref?K.ref:null,K.__v):X.__k[Q]=K,G=Q+_,K.__=X,K.__b=X.__b+1,W=null,(z=K.__i=f5(K,J,G,$))!=-1&&($--,(W=J[z])&&(W.__u|=2)),W==null||W.__v==null?(z==-1&&(q>P?_--:q<P&&_++),typeof K.type!="function"&&(K.__u|=4)):z!=G&&(z==G-1?_--:z==G+1?_++:(z>G?_--:_++,K.__u|=4))):X.__k[Q]=null;if($)for(Q=0;Q<P;Q++)(W=J[Q])!=null&&(2&W.__u)==0&&(W.__e==Y&&(Y=B0(W)),f4(W,W));return Y}function h4(X,Z,J,Y){var q,Q;if(typeof X.type=="function"){for(q=X.__k,Q=0;q&&Q<q.length;Q++)q[Q]&&(q[Q].__=X,Z=h4(q[Q],Z,J,Y));return Z}X.__e!=Z&&(Y&&(Z&&X.type&&!Z.parentNode&&(Z=B0(X)),J.insertBefore(X.__e,Z||null)),Z=X.__e);do Z=Z&&Z.nextSibling;while(Z!=null&&Z.nodeType==8);return Z}function L0(X,Z){return Z=Z||[],X==null||typeof X=="boolean"||(b0(X)?X.some(function(J){L0(J,Z)}):Z.push(X)),Z}function f5(X,Z,J,Y){var q,Q,K,W=X.key,G=X.type,z=Z[J],P=z!=null&&(2&z.__u)==0;if(z===null&&W==null||P&&W==z.key&&G==z.type)return J;if(Y>(P?1:0)){for(q=J-1,Q=J+1;q>=0||Q<Z.length;)if((z=Z[K=q>=0?q--:Q++])!=null&&(2&z.__u)==0&&W==z.key&&G==z.type)return K}return-1}function b4(X,Z,J){Z[0]=="-"?X.setProperty(Z,J==null?"":J):X[Z]=J==null?"":typeof J!="number"||h5.test(Z)?J:J+"px"}function h0(X,Z,J,Y,q){var Q,K;X:if(Z=="style")if(typeof J=="string")X.style.cssText=J;else{if(typeof Y=="string"&&(X.style.cssText=Y=""),Y)for(Z in Y)J&&Z in J||b4(X.style,Z,"");if(J)for(Z in J)Y&&J[Z]==Y[Z]||b4(X.style,Z,J[Z])}else if(Z[0]=="o"&&Z[1]=="n")Q=Z!=(Z=Z.replace(y4,"$1")),K=Z.toLowerCase(),Z=K in X||Z=="onFocusOut"||Z=="onFocusIn"?K.slice(2):Z.slice(2),X.l||(X.l={}),X.l[Z+Q]=J,J?Y?J[T0]=Y[T0]:(J[T0]=N4,X.addEventListener(Z,Q?z4:$4,Q)):X.removeEventListener(Z,Q?z4:$4,Q);else{if(q=="http://www.w3.org/2000/svg")Z=Z.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if(Z!="width"&&Z!="height"&&Z!="href"&&Z!="list"&&Z!="form"&&Z!="tabIndex"&&Z!="download"&&Z!="rowSpan"&&Z!="colSpan"&&Z!="role"&&Z!="popover"&&Z in X)try{X[Z]=J==null?"":J;break X}catch(W){}typeof J=="function"||(J==null||J===!1&&Z[4]!="-"?X.removeAttribute(Z):X.setAttribute(Z,Z=="popover"&&J==1?"":J))}}function S4(X){return function(Z){if(this.l){var J=this.l[Z.type+X];if(Z[m0]==null)Z[m0]=N4++;else if(Z[m0]<J[T0])return;return J(B.event?B.event(Z):Z)}}}function V4(X,Z,J,Y,q,Q,K,W,G,z){var P,$,_,O,C,A,k,I,M,h,E,n,Q0,g,K0,s=Z.type;if(Z.constructor!==void 0)return null;128&J.__u&&(G=!!(32&J.__u),Q=[W=Z.__e=J.__e]),(P=B.__b)&&P(Z);X:if(typeof s=="function")try{if(I=Z.props,M=s.prototype&&s.prototype.render,h=(P=s.contextType)&&Y[P.__c],E=P?h?h.props.value:P.__:Y,J.__c?k=($=Z.__c=J.__c).__=$.__E:(M?Z.__c=$=new s(I,E):(Z.__c=$=new c(I,E),$.constructor=s,$.render=l5),h&&h.sub($),$.state||($.state={}),$.__n=Y,_=$.__d=!0,$.__h=[],$._sb=[]),M&&$.__s==null&&($.__s=$.state),M&&s.getDerivedStateFromProps!=null&&($.__s==$.state&&($.__s=z0({},$.__s)),z0($.__s,s.getDerivedStateFromProps(I,$.__s))),O=$.props,C=$.state,$.__v=Z,_)M&&s.getDerivedStateFromProps==null&&$.componentWillMount!=null&&$.componentWillMount(),M&&$.componentDidMount!=null&&$.__h.push($.componentDidMount);else{if(M&&s.getDerivedStateFromProps==null&&I!==O&&$.componentWillReceiveProps!=null&&$.componentWillReceiveProps(I,E),Z.__v==J.__v||!$.__e&&$.shouldComponentUpdate!=null&&$.shouldComponentUpdate(I,$.__s,E)===!1){Z.__v!=J.__v&&($.props=I,$.state=$.__s,$.__d=!1),Z.__e=J.__e,Z.__k=J.__k,Z.__k.some(function(r){r&&(r.__=Z)}),a0.push.apply($.__h,$._sb),$._sb=[],$.__h.length&&K.push($);break X}$.componentWillUpdate!=null&&$.componentWillUpdate(I,$.__s,E),M&&$.componentDidUpdate!=null&&$.__h.push(function(){$.componentDidUpdate(O,C,A)})}if($.context=E,$.props=I,$.__P=X,$.__e=!1,n=B.__r,Q0=0,M)$.state=$.__s,$.__d=!1,n&&n(Z),P=$.render($.props,$.state,$.context),a0.push.apply($.__h,$._sb),$._sb=[];else do $.__d=!1,n&&n(Z),P=$.render($.props,$.state,$.context),$.state=$.__s;while($.__d&&++Q0<25);$.state=$.__s,$.getChildContext!=null&&(Y=z0(z0({},Y),$.getChildContext())),M&&!_&&$.getSnapshotBeforeUpdate!=null&&(A=$.getSnapshotBeforeUpdate(O,C)),g=P!=null&&P.type===d&&P.key==null?d4(P.props.children):P,W=x4(X,b0(g)?g:[g],Z,J,Y,q,Q,K,W,G,z),$.base=Z.__e,Z.__u&=-161,$.__h.length&&K.push($),k&&($.__E=$.__=null)}catch(r){if(Z.__v=null,G||Q!=null)if(r.then){for(Z.__u|=G?160:128;W&&W.nodeType==8&&W.nextSibling;)W=W.nextSibling;Q[Q.indexOf(W)]=null,Z.__e=W}else{for(K0=Q.length;K0--;)G4(Q[K0]);L4(Z)}else Z.__e=J.__e,Z.__k=J.__k,r.then||L4(Z);B.__e(r,Z,J)}else Q==null&&Z.__v==J.__v?(Z.__k=J.__k,Z.__e=J.__e):W=Z.__e=a5(J.__e,Z,J,Y,q,Q,K,G,z);return(P=B.diffed)&&P(Z),128&Z.__u?void 0:W}function L4(X){X&&(X.__c&&(X.__c.__e=!0),X.__k&&X.__k.some(L4))}function m4(X,Z,J){for(var Y=0;Y<J.length;Y++)H4(J[Y],J[++Y],J[++Y]);B.__c&&B.__c(Z,X),X.some(function(q){try{X=q.__h,q.__h=[],X.some(function(Q){Q.call(q)})}catch(Q){B.__e(Q,q.__v)}})}function d4(X){return typeof X!="object"||X==null||X.__b>0?X:b0(X)?X.map(d4):z0({},X)}function a5(X,Z,J,Y,q,Q,K,W,G){var z,P,$,_,O,C,A,k=J.props||f0,I=Z.props,M=Z.type;if(M=="svg"?q="http://www.w3.org/2000/svg":M=="math"?q="http://www.w3.org/1998/Math/MathML":q||(q="http://www.w3.org/1999/xhtml"),Q!=null){for(z=0;z<Q.length;z++)if((O=Q[z])&&"setAttribute"in O==!!M&&(M?O.localName==M:O.nodeType==3)){X=O,Q[z]=null;break}}if(X==null){if(M==null)return document.createTextNode(I);X=document.createElementNS(q,M,I.is&&I),W&&(B.__m&&B.__m(Z,Q),W=!1),Q=null}if(M==null)k===I||W&&X.data==I||(X.data=I);else{if(Q=Q&&c0.call(X.childNodes),!W&&Q!=null)for(k={},z=0;z<X.attributes.length;z++)k[(O=X.attributes[z]).name]=O.value;for(z in k)O=k[z],z=="dangerouslySetInnerHTML"?$=O:z=="children"||(z in I)||z=="value"&&("defaultValue"in I)||z=="checked"&&("defaultChecked"in I)||h0(X,z,null,O,q);for(z in I)O=I[z],z=="children"?_=O:z=="dangerouslySetInnerHTML"?P=O:z=="value"?C=O:z=="checked"?A=O:W&&typeof O!="function"||k[z]===O||h0(X,z,O,k[z],q);if(P)W||$&&(P.__html==$.__html||P.__html==X.innerHTML)||(X.innerHTML=P.__html),Z.__k=[];else if($&&(X.innerHTML=""),x4(Z.type=="template"?X.content:X,b0(_)?_:[_],Z,J,Y,M=="foreignObject"?"http://www.w3.org/1999/xhtml":q,Q,K,Q?Q[0]:J.__k&&B0(J,0),W,G),Q!=null)for(z=Q.length;z--;)G4(Q[z]);W||(z="value",M=="progress"&&C==null?X.removeAttribute("value"):C!=null&&(C!==X[z]||M=="progress"&&!C||M=="option"&&C!=k[z])&&h0(X,z,C,k[z],q),z="checked",A!=null&&A!=X[z]&&h0(X,z,A,k[z],q))}return X}function H4(X,Z,J){try{if(typeof X=="function"){var Y=typeof X.__u=="function";Y&&X.__u(),Y&&Z==null||(X.__u=X(Z))}else X.current=Z}catch(q){B.__e(q,J)}}function f4(X,Z,J){var Y,q;if(B.unmount&&B.unmount(X),(Y=X.ref)&&(Y.current&&Y.current!=X.__e||H4(Y,null,Z)),(Y=X.__c)!=null){if(Y.componentWillUnmount)try{Y.componentWillUnmount()}catch(Q){B.__e(Q,Z)}Y.base=Y.__P=null}if(Y=X.__k)for(q=0;q<Y.length;q++)Y[q]&&f4(Y[q],Z,J||typeof X.type!="function");J||G4(X.__e),X.__c=X.__=X.__e=void 0}function l5(X,Z,J){return this.constructor(X,J)}function i0(X,Z,J){var Y,q,Q,K;Z==document&&(Z=document.documentElement),B.__&&B.__(X,Z),q=(Y=typeof J=="function")?null:J&&J.__k||Z.__k,Q=[],K=[],V4(Z,X=(!Y&&J||Z).__k=W0(d,null,[X]),q||f0,f0,Z.namespaceURI,!Y&&J?[J]:q?null:Z.firstChild?c0.call(Z.childNodes):null,Q,!Y&&J?J:q?q.__e:Z.firstChild,Y,K),m4(Q,X,K)}function _0(X){function Z(J){var Y,q;return this.getChildContext||(Y=new Set,(q={})[Z.__c]=this,this.getChildContext=function(){return q},this.componentWillUnmount=function(){Y=null},this.shouldComponentUpdate=function(Q){this.props.value!=Q.value&&Y.forEach(function(K){K.__e=!0,W4(K)})},this.sub=function(Q){Y.add(Q);var K=Q.componentWillUnmount;Q.componentWillUnmount=function(){Y&&Y.delete(Q),K&&K.call(Q)}}),J.children}return Z.__c="__cC"+p4++,Z.__=X,Z.Provider=Z.__l=(Z.Consumer=function(J,Y){return J.children(Y)}).contextType=Z,Z}c0=a0.slice,B={__e:function(X,Z,J,Y){for(var q,Q,K;Z=Z.__;)if((q=Z.__c)&&!q.__)try{if((Q=q.constructor)&&Q.getDerivedStateFromError!=null&&(q.setState(Q.getDerivedStateFromError(X)),K=q.__d),q.componentDidCatch!=null&&(q.componentDidCatch(X,Y||{}),K=q.__d),K)return q.__E=q}catch(W){X=W}throw X}},R4=0,x5=function(X){return X!=null&&X.constructor===void 0},c.prototype.setState=function(X,Z){var J;J=this.__s!=null&&this.__s!=this.state?this.__s:this.__s=z0({},this.state),typeof X=="function"&&(X=X(z0({},J),this.props)),X&&z0(J,X),X!=null&&this.__v&&(Z&&this._sb.push(Z),W4(this))},c.prototype.forceUpdate=function(X){this.__v&&(this.__e=!0,X&&this.__h.push(X),W4(this))},c.prototype.render=d,P0=[],j4=typeof Promise=="function"?Promise.prototype.then.bind(Promise.resolve()):setTimeout,v4=function(X,Z){return X.__v.__b-Z.__v.__b},l0.__r=0,K4=Math.random().toString(8),m0="__d"+K4,T0="__a"+K4,y4=/(PointerCapture)$|Capture$/i,N4=0,$4=S4(!1),z4=S4(!0),p4=0;var F0,p,P4,a4,S0=0,t4=[],f=B,l4=f.__b,c4=f.__r,i4=f.diffed,u4=f.__c,o4=f.unmount,s4=f.__;function o0(X,Z){f.__h&&f.__h(p,X,S0||Z),S0=0;var J=p.__H||(p.__H={__:[],__h:[]});return X>=J.__.length&&J.__.push({}),J.__[X]}function S(X){return S0=1,O4(e4,X)}function O4(X,Z,J){var Y=o0(F0++,2);if(Y.t=X,!Y.__c&&(Y.__=[J?J(Z):e4(void 0,Z),function(W){var G=Y.__N?Y.__N[0]:Y.__[0],z=Y.t(G,W);G!==z&&(Y.__N=[z,Y.__[1]],Y.__c.setState({}))}],Y.__c=p,!p.__f)){var q=function(W,G,z){if(!Y.__c.__H)return!0;var P=Y.__c.__H.__.filter(function(_){return _.__c});if(P.every(function(_){return!_.__N}))return!Q||Q.call(this,W,G,z);var $=Y.__c.props!==W;return P.some(function(_){if(_.__N){var O=_.__[0];_.__=_.__N,_.__N=void 0,O!==_.__[0]&&($=!0)}}),Q&&Q.call(this,W,G,z)||$};p.__f=!0;var{shouldComponentUpdate:Q,componentWillUpdate:K}=p;p.componentWillUpdate=function(W,G,z){if(this.__e){var P=Q;Q=void 0,q(W,G,z),Q=P}K&&K.call(this,W,G,z)},p.shouldComponentUpdate=q}return Y.__N||Y.__}function x(X,Z){var J=o0(F0++,3);!f.__s&&n4(J.__H,Z)&&(J.__=X,J.u=Z,p.__H.__h.push(J))}function w(X){return S0=5,s0(function(){return{current:X}},[])}function s0(X,Z){var J=o0(F0++,7);return n4(J.__H,Z)&&(J.__=X(),J.__H=Z,J.__h=X),J.__}function j(X,Z){return S0=8,s0(function(){return X},Z)}function R0(X){var Z=p.context[X.__c],J=o0(F0++,9);return J.c=X,Z?(J.__==null&&(J.__=!0,Z.sub(p)),Z.props.value):X.__}function c5(){for(var X;X=t4.shift();){var Z=X.__H;if(X.__P&&Z)try{Z.__h.some(u0),Z.__h.some(A4),Z.__h=[]}catch(J){Z.__h=[],f.__e(J,X.__v)}}}f.__b=function(X){p=null,l4&&l4(X)},f.__=function(X,Z){X&&Z.__k&&Z.__k.__m&&(X.__m=Z.__k.__m),s4&&s4(X,Z)},f.__r=function(X){c4&&c4(X),F0=0;var Z=(p=X.__c).__H;Z&&(P4===p?(Z.__h=[],p.__h=[],Z.__.some(function(J){J.__N&&(J.__=J.__N),J.u=J.__N=void 0})):(Z.__h.some(u0),Z.__h.some(A4),Z.__h=[],F0=0)),P4=p},f.diffed=function(X){i4&&i4(X);var Z=X.__c;Z&&Z.__H&&(Z.__H.__h.length&&(t4.push(Z)!==1&&a4===f.requestAnimationFrame||((a4=f.requestAnimationFrame)||i5)(c5)),Z.__H.__.some(function(J){J.u&&(J.__H=J.u),J.u=void 0})),P4=p=null},f.__c=function(X,Z){Z.some(function(J){try{J.__h.some(u0),J.__h=J.__h.filter(function(Y){return!Y.__||A4(Y)})}catch(Y){Z.some(function(q){q.__h&&(q.__h=[])}),Z=[],f.__e(Y,J.__v)}}),u4&&u4(X,Z)},f.unmount=function(X){o4&&o4(X);var Z,J=X.__c;J&&J.__H&&(J.__H.__.some(function(Y){try{u0(Y)}catch(q){Z=q}}),J.__H=void 0,Z&&f.__e(Z,J.__v))};var r4=typeof requestAnimationFrame=="function";function i5(X){var Z,J=function(){clearTimeout(Y),r4&&cancelAnimationFrame(Z),setTimeout(X)},Y=setTimeout(J,35);r4&&(Z=requestAnimationFrame(J))}function u0(X){var Z=p,J=X.__c;typeof J=="function"&&(X.__c=void 0,J()),p=Z}function A4(X){var Z=p;X.__c=X.__(),p=Z}function n4(X,Z){return!X||X.length!==Z.length||Z.some(function(J,Y){return J!==X[Y]})}function e4(X,Z){return typeof Z=="function"?Z(X):Z}function e5(X,Z){for(var J in Z)X[J]=Z[J];return X}function X5(X,Z){for(var J in X)if(J!=="__source"&&!(J in Z))return!0;for(var Y in Z)if(Y!=="__source"&&X[Y]!==Z[Y])return!0;return!1}function Z5(X,Z){this.props=X,this.context=Z}(Z5.prototype=new c).isPureReactComponent=!0,Z5.prototype.shouldComponentUpdate=function(X,Z){return X5(this.props,X)||X5(this.state,Z)};var J5=B.__b;B.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),J5&&J5(X)};var X6=B.__e;B.__e=function(X,Z,J,Y){if(X.then){for(var q,Q=Z;Q=Q.__;)if((q=Q.__c)&&q.__c)return Z.__e==null&&(Z.__e=J.__e,Z.__k=J.__k),q.__c(X,Z)}X6(X,Z,J,Y)};var Y5=B.unmount;function W5(X,Z,J){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(Y){typeof Y.__c=="function"&&Y.__c()}),X.__c.__H=null),(X=e5({},X)).__c!=null&&(X.__c.__P===J&&(X.__c.__P=Z),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(Y){return W5(Y,Z,J)})),X}function L5(X,Z,J){return X&&J&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(Y){return L5(Y,Z,J)}),X.__c&&X.__c.__P===Z&&(X.__e&&J.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=J)),X}function U4(){this.__u=0,this.o=null,this.__b=null}function N5(X){var Z=X.__&&X.__.__c;return Z&&Z.__a&&Z.__a(X)}function r0(){this.i=null,this.l=null}B.unmount=function(X){var Z=X.__c;Z&&(Z.__z=!0),Z&&Z.__R&&Z.__R(),Z&&32&X.__u&&(X.type=null),Y5&&Y5(X)},(U4.prototype=new c).__c=function(X,Z){var J=Z.__c,Y=this;Y.o==null&&(Y.o=[]),Y.o.push(J);var q=N5(Y.__v),Q=!1,K=function(){Q||Y.__z||(Q=!0,J.__R=null,q?q(G):G())};J.__R=K;var W=J.__P;J.__P=null;var G=function(){if(!--Y.__u){if(Y.state.__a){var z=Y.state.__a;Y.__v.__k[0]=L5(z,z.__c.__P,z.__c.__O)}var P;for(Y.setState({__a:Y.__b=null});P=Y.o.pop();)P.__P=W,P.forceUpdate()}};Y.__u++||32&Z.__u||Y.setState({__a:Y.__b=Y.__v.__k[0]}),X.then(K,K)},U4.prototype.componentWillUnmount=function(){this.o=[]},U4.prototype.render=function(X,Z){if(this.__b){if(this.__v.__k){var J=document.createElement("div"),Y=this.__v.__k[0].__c;this.__v.__k[0]=W5(this.__b,J,Y.__O=Y.__P)}this.__b=null}var q=Z.__a&&W0(d,null,X.fallback);return q&&(q.__u&=-33),[W0(d,null,Z.__a?null:X.children),q]};var q5=function(X,Z,J){if(++J[1]===J[0]&&X.l.delete(Z),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(J=X.i;J;){for(;J.length>3;)J.pop()();if(J[1]<J[0])break;X.i=J=J[2]}};(r0.prototype=new c).__a=function(X){var Z=this,J=N5(Z.__v),Y=Z.l.get(X);return Y[0]++,function(q){var Q=function(){Z.props.revealOrder?(Y.push(q),q5(Z,X,Y)):q()};J?J(Q):Q()}},r0.prototype.render=function(X){this.i=null,this.l=new Map;var Z=L0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Z.reverse();for(var J=Z.length;J--;)this.l.set(Z[J],this.i=[1,0,this.i]);return X.children},r0.prototype.componentDidUpdate=r0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Z,J){q5(X,J,Z)})};var Z6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,J6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,Y6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,q6=/[A-Z0-9]/g,Q6=typeof document<"u",K6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};function G5(X,Z,J){return Z.__k==null&&(Z.textContent=""),i0(X,Z),typeof J=="function"&&J(),X?X.__c:null}c.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(c.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Z){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Z})}})});var Q5=B.event;B.event=function(X){return Q5&&(X=Q5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var V5,$6={configurable:!0,get:function(){return this.class}},K5=B.vnode;B.vnode=function(X){typeof X.type=="string"&&function(Z){var{props:J,type:Y}=Z,q={},Q=Y.indexOf("-")==-1;for(var K in J){var W=J[K];if(!(K==="value"&&("defaultValue"in J)&&W==null||Q6&&K==="children"&&Y==="noscript"||K==="class"||K==="className")){var G=K.toLowerCase();K==="defaultValue"&&"value"in J&&J.value==null?K="value":K==="download"&&W===!0?W="":G==="translate"&&W==="no"?W=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?K="ondblclick":G!=="onchange"||Y!=="input"&&Y!=="textarea"||K6(J.type)?G==="onfocus"?K="onfocusin":G==="onblur"?K="onfocusout":Y6.test(K)&&(K=G):G=K="oninput":Q&&J6.test(K)?K=K.replace(q6,"-$&").toLowerCase():W===null&&(W=void 0),G==="oninput"&&q[K=G]&&(K="oninputCapture"),q[K]=W}}Y=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.value.indexOf(z.props.value)!=-1})),q.defaultValue!=null&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.multiple?q.defaultValue.indexOf(z.props.value)!=-1:q.defaultValue==z.props.value}))),J.class&&!J.className?(q.class=J.class,Object.defineProperty(q,"className",$6)):J.className&&(q.class=q.className=J.className),Z.props=q}(X),X.$$typeof=Z6,K5&&K5(X)};var $5=B.__r;B.__r=function(X){$5&&$5(X),V5=X.__c};var z5=B.diffed;B.diffed=function(X){z5&&z5(X);var{props:Z,__e:J}=X;J!=null&&X.type==="textarea"&&"value"in Z&&Z.value!==J.value&&(J.value=Z.value==null?"":Z.value),V5=null};function H5(X){return!!X.__k&&(i0(null,X),!0)}function P5(X){return{render:function(Z){G5(Z,X)},unmount:function(){H5(X)}}}function M5(X,Z){for(var J in Z)X[J]=Z[J];return X}function A5(X,Z){for(var J in X)if(J!=="__source"&&!(J in Z))return!0;for(var Y in Z)if(Y!=="__source"&&X[Y]!==Z[Y])return!0;return!1}function O5(X,Z){this.props=X,this.context=Z}(O5.prototype=new c).isPureReactComponent=!0,O5.prototype.shouldComponentUpdate=function(X,Z){return A5(this.props,X)||A5(this.state,Z)};var U5=B.__b;B.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),U5&&U5(X)};var z6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.forward_ref")||3911;function D0(X){function Z(J){var Y=M5({},J);return delete Y.ref,X(Y,J.ref||null)}return Z.$$typeof=z6,Z.render=X,Z.prototype.isReactComponent=Z.__f=!0,Z.displayName="ForwardRef("+(X.displayName||X.name)+")",Z}var W6=B.__e;B.__e=function(X,Z,J,Y){if(X.then){for(var q,Q=Z;Q=Q.__;)if((q=Q.__c)&&q.__c)return Z.__e==null&&(Z.__e=J.__e,Z.__k=J.__k),q.__c(X,Z)}W6(X,Z,J,Y)};var B5=B.unmount;function C5(X,Z,J){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(Y){typeof Y.__c=="function"&&Y.__c()}),X.__c.__H=null),(X=M5({},X)).__c!=null&&(X.__c.__P===J&&(X.__c.__P=Z),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(Y){return C5(Y,Z,J)})),X}function E5(X,Z,J){return X&&J&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(Y){return E5(Y,Z,J)}),X.__c&&X.__c.__P===Z&&(X.__e&&J.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=J)),X}function _4(){this.__u=0,this.o=null,this.__b=null}function w5(X){var Z=X.__&&X.__.__c;return Z&&Z.__a&&Z.__a(X)}function t0(){this.i=null,this.l=null}B.unmount=function(X){var Z=X.__c;Z&&(Z.__z=!0),Z&&Z.__R&&Z.__R(),Z&&32&X.__u&&(X.type=null),B5&&B5(X)},(_4.prototype=new c).__c=function(X,Z){var J=Z.__c,Y=this;Y.o==null&&(Y.o=[]),Y.o.push(J);var q=w5(Y.__v),Q=!1,K=function(){Q||Y.__z||(Q=!0,J.__R=null,q?q(G):G())};J.__R=K;var W=J.__P;J.__P=null;var G=function(){if(!--Y.__u){if(Y.state.__a){var z=Y.state.__a;Y.__v.__k[0]=E5(z,z.__c.__P,z.__c.__O)}var P;for(Y.setState({__a:Y.__b=null});P=Y.o.pop();)P.__P=W,P.forceUpdate()}};Y.__u++||32&Z.__u||Y.setState({__a:Y.__b=Y.__v.__k[0]}),X.then(K,K)},_4.prototype.componentWillUnmount=function(){this.o=[]},_4.prototype.render=function(X,Z){if(this.__b){if(this.__v.__k){var J=document.createElement("div"),Y=this.__v.__k[0].__c;this.__v.__k[0]=C5(this.__b,J,Y.__O=Y.__P)}this.__b=null}var q=Z.__a&&W0(d,null,X.fallback);return q&&(q.__u&=-33),[W0(d,null,Z.__a?null:X.children),q]};var _5=function(X,Z,J){if(++J[1]===J[0]&&X.l.delete(Z),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(J=X.i;J;){for(;J.length>3;)J.pop()();if(J[1]<J[0])break;X.i=J=J[2]}};(t0.prototype=new c).__a=function(X){var Z=this,J=w5(Z.__v),Y=Z.l.get(X);return Y[0]++,function(q){var Q=function(){Z.props.revealOrder?(Y.push(q),_5(Z,X,Y)):q()};J?J(Q):Q()}},t0.prototype.render=function(X){this.i=null,this.l=new Map;var Z=L0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Z.reverse();for(var J=Z.length;J--;)this.l.set(Z[J],this.i=[1,0,this.i]);return X.children},t0.prototype.componentDidUpdate=t0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Z,J){_5(X,J,Z)})};var L6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,N6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,G6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,V6=/[A-Z0-9]/g,H6=typeof document<"u",P6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};c.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(c.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Z){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Z})}})});var F5=B.event;B.event=function(X){return F5&&(X=F5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var T5,A6={configurable:!0,get:function(){return this.class}},D5=B.vnode;B.vnode=function(X){typeof X.type=="string"&&function(Z){var{props:J,type:Y}=Z,q={},Q=Y.indexOf("-")==-1;for(var K in J){var W=J[K];if(!(K==="value"&&("defaultValue"in J)&&W==null||H6&&K==="children"&&Y==="noscript"||K==="class"||K==="className")){var G=K.toLowerCase();K==="defaultValue"&&"value"in J&&J.value==null?K="value":K==="download"&&W===!0?W="":G==="translate"&&W==="no"?W=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?K="ondblclick":G!=="onchange"||Y!=="input"&&Y!=="textarea"||P6(J.type)?G==="onfocus"?K="onfocusin":G==="onblur"?K="onfocusout":G6.test(K)&&(K=G):G=K="oninput":Q&&N6.test(K)?K=K.replace(V6,"-$&").toLowerCase():W===null&&(W=void 0),G==="oninput"&&q[K=G]&&(K="oninputCapture"),q[K]=W}}Y=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.value.indexOf(z.props.value)!=-1})),q.defaultValue!=null&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.multiple?q.defaultValue.indexOf(z.props.value)!=-1:q.defaultValue==z.props.value}))),J.class&&!J.className?(q.class=J.class,Object.defineProperty(q,"className",A6)):J.className&&(q.class=q.className=J.className),Z.props=q}(X),X.$$typeof=L6,D5&&D5(X)};var k5=B.__r;B.__r=function(X){k5&&k5(X),T5=X.__c};var I5=B.diffed;B.diffed=function(X){I5&&I5(X);var{props:Z,__e:J}=X;J!=null&&X.type==="textarea"&&"value"in Z&&Z.value!==J.value&&(J.value=Z.value==null?"":Z.value),T5=null};var O6=0;function N(X,Z,J,Y,q,Q){Z||(Z={});var K,W,G=Z;if("ref"in G)for(W in G={},Z)W=="ref"?K=Z[W]:G[W]=Z[W];var z={type:X,props:G,key:J,ref:K,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--O6,__i:-1,__u:0,__source:q,__self:Q};if(typeof X=="function"&&(K=X.defaultProps))for(W in K)G[W]===void 0&&(G[W]=K[W]);return B.vnode&&B.vnode(z),z}var F4=`url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle cx='10' cy='10' r='9' fill='rgba(255,255,255,0.4)' stroke='rgba(255,255,255,0.7)' stroke-width='1'/%3E%3C/svg%3E") 10 10, pointer`,U6=3,B6=4,_6=5;function n0({url:X,wsUrl:Z,style:J,imageStyle:Y,className:q,onHomePress:Q,onStreamTouch:K,onStreamMultiTouch:W,onStreamButton:G,subscribeFrame:z,streamFrame:P,streamConfig:$,hideControls:_,onStreamingChange:O,connectionQuality:C}){let A=!!K,k=w(null),I=w(null),M=w(null),[h,E]=S(!1),[n,Q0]=S(null),[g,K0]=S(null),s=w(null),[r,O0]=S(null);x(()=>{let V=s.current;if(!V||typeof ResizeObserver>"u")return;let H=new ResizeObserver((L)=>{let U=L[0]?.contentRect;if(U)O0({width:U.width,height:U.height})});return H.observe(V),()=>H.disconnect()},[]);let[j0,v0]=S(0),G0=w(0),[J4,I0]=S(!1),F=w(null);x(()=>{if(C==="poor"){if(I0(!0),F.current)clearTimeout(F.current);F.current=setTimeout(()=>{I0(!1),F.current=null},3000)}else if(I0(!1),F.current)clearTimeout(F.current),F.current=null;return()=>{if(F.current)clearTimeout(F.current)}},[C]);let R=`${X}/stream.mjpeg`,v=w(O);v.current=O,x(()=>{v.current?.(h)},[h]),x(()=>{if(A&&$)K0($)},[A,$]);let T=w(!1);T.current=h;let i=w(null);x(()=>{if(!A||!z)return;return z((V)=>{G0.current++,e.current=Date.now();let H=I.current;if(H){if(i.current)URL.revokeObjectURL(i.current);i.current=V,H.src=V}if(!T.current)E(!0),Q0(null)})},[A,z]);let m=j((V)=>{if(A){K?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify(V)),U=new Uint8Array(1+L.length);U[0]=U6,U.set(L,1),H.send(U)},[A,K]),Z0=j((V)=>{if(A){G?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify({button:V})),U=new Uint8Array(1+L.length);U[0]=B6,U.set(L,1),H.send(U)},[A,G]),y=j((V)=>{if(A){W?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify(V)),U=new Uint8Array(1+L.length);U[0]=_6,U.set(L,1),H.send(U)},[A,W]);x(()=>{if(A)return;fetch(`${X}/config`).then((D)=>D.json()).then((D)=>{if(D.width>0&&D.height>0)K0(D)}).catch(()=>{});let V=Z??X.replace(/^http/,"ws")+"/ws",H=new WebSocket(V);H.binaryType="arraybuffer",M.current=H,H.onopen=()=>{E(!0),Q0(null)},H.onclose=()=>{E(!1)},H.onerror=()=>{Q0("WebSocket connection failed"),E(!1)};let L=new AbortController,U=setInterval(()=>{v0(G0.current),G0.current=0},1000);return(async()=>{try{let b=(await fetch(R,{signal:L.signal})).body?.getReader();if(!b)return;let o=new TextEncoder().encode("--frame");while(!0){let{done:X0,value:q0}=await b.read();if(X0)break;if(q0)for(let Q4=0;Q4<=q0.length-o.length;Q4++){let w4=!0;for(let x0=0;x0<o.length;x0++)if(q0[Q4+x0]!==o[x0]){w4=!1;break}if(w4)G0.current++}}}catch{}})(),()=>{L.abort(),clearInterval(U),H.close(),M.current=null}},[X,R,A]);let e=w(0);x(()=>{if(!A)return;let V=2000,H=()=>{let D=e.current;if(!D||!T.current)return;if(Date.now()-D>V)E(!1)},L=setInterval(()=>{v0(G0.current),G0.current=0,H()},1000),U=()=>{if(!document.hidden)H()};return document.addEventListener("visibilitychange",U),()=>{clearInterval(L),document.removeEventListener("visibilitychange",U)}},[A]);let a=j(()=>{return A?I.current:k.current},[A]),V0=j((V,H)=>{let L=a();if(!L)return;let U=L.getBoundingClientRect(),D=(H.clientX-U.left)/U.width,b=(H.clientY-U.top)/U.height;m({type:V,x:D,y:b})},[m]),J0=3,l=w(!1),u=w(!1),U0=w(!1),M0=w({dx:0,dy:0}),C0=w(!1),[Y4,k4]=S(!1),I4=w({x:0.5,y:0.5}),[H0,Y0]=S(null);x(()=>{let V=(L)=>{if(L.key==="Alt")k4(!0)},H=(L)=>{if(L.key==="Alt"){if(k4(!1),!u.current)Y0(null)}};return window.addEventListener("keydown",V),window.addEventListener("keyup",H),()=>{window.removeEventListener("keydown",V),window.removeEventListener("keyup",H)}},[]),x(()=>{if(Y4&&!u.current){let V=I4.current;Y0({x1:V.x,y1:V.y,x2:1-V.x,y2:1-V.y})}else if(!Y4&&!u.current)Y0(null)},[Y4]);let y0=w(null),q4=w(!1),E0=w(0),M4=j((V,H)=>{q4.current=!0;let L=y0.current;if(L)cancelAnimationFrame(E0.current),E0.current=requestAnimationFrame(()=>{L.style.left=`${V*100}%`,L.style.top=`${H*100}%`,L.style.display="block"})},[]),C4=j((V,H)=>{if(!q4.current)return;let L=y0.current;if(L)cancelAnimationFrame(E0.current),E0.current=requestAnimationFrame(()=>{L.style.left=`${V*100}%`,L.style.top=`${H*100}%`})},[]),p0=j(()=>{q4.current=!1;let V=y0.current;if(V)cancelAnimationFrame(E0.current),V.style.display="none"},[]),E4=w(0),w0=w(null),g5=j(()=>{let V=Date.now(),H=V-E4.current;if(E4.current=V,H<300){if(w0.current)clearTimeout(w0.current),w0.current=null;if(Q)Q();else Z0("app_switcher")}else w0.current=setTimeout(()=>{if(Q)Q();else Z0("home");w0.current=null},300)},[Z0,Q]),g0=(()=>{if(!g||!r)return null;if(r.width===0||r.height===0)return null;let V=Math.min(r.width/g.width,r.height/g.height);return{width:g.width*V,height:g.height*V}})();return N("div",{style:{display:"flex",flexDirection:"column",flex:1,..._?{}:{border:"1px solid rgba(255,255,255,0.12)"},overflow:"hidden",minWidth:0,minHeight:0,...J},className:q,children:[N("div",{ref:s,style:{position:"relative",flex:1,minHeight:0,minWidth:0,display:"flex",alignItems:"center",justifyContent:"center"},children:N("div",{style:{position:"relative",width:g0?`${g0.width}px`:"100%",height:g0?`${g0.height}px`:"100%"},children:[N("img",{ref:k,src:A?void 0:R,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)K0((L)=>L&&L.width===H.naturalWidth&&L.height===H.naturalHeight?L:{width:H.naturalWidth,height:H.naturalHeight})},style:A?{display:"none"}:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:F4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...Y}}),A&&N("img",{ref:I,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)K0((L)=>L&&L.width===H.naturalWidth&&L.height===H.naturalHeight?L:{width:H.naturalWidth,height:H.naturalHeight})},style:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:F4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...Y}}),N("div",{style:{position:"absolute",inset:0,cursor:F4,touchAction:"none"},onMouseDown:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(V.altKey){u.current=!0,U0.current=V.shiftKey;let b={x1:U,y1:D,x2:1-U,y2:1-D};M0.current={dx:1-U-U,dy:1-D-D},Y0(b),y({type:"begin",...b});return}if(M4(U,D),D>0.88)l.current=!0,m({type:"begin",x:U,y:D,edge:J0});else l.current=!1,V0("begin",V)},onMouseMove:(V)=>{let H=a();if(!H)return;let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(I4.current={x:U,y:D},V.buttons===0){if(V.altKey)Y0({x1:U,y1:D,x2:1-U,y2:1-D});return}if(u.current){let b;if(U0.current){let o=M0.current;b={x1:U,y1:D,x2:U+o.dx,y2:D+o.dy}}else b={x1:U,y1:D,x2:1-U,y2:1-D};Y0(b),y({type:"move",...b});return}if(C4(U,D),l.current)m({type:"move",x:U,y:D,edge:J0});else V0("move",V)},onMouseUp:(V)=>{if(u.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(U0.current){let b=M0.current;y({type:"end",x1:U,y1:D,x2:U+b.dx,y2:D+b.dy})}else y({type:"end",x1:U,y1:D,x2:1-U,y2:1-D})}if(u.current=!1,!V.altKey)Y0(null);return}if(p0(),l.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;m({type:"end",x:U,y:D,edge:J0})}l.current=!1;return}V0("end",V)},onMouseLeave:(V)=>{if(u.current){if(H0)y({type:"end",...H0});u.current=!1,Y0(null);return}if(p0(),l.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;m({type:"end",x:U,y:D,edge:J0})}l.current=!1;return}if(V.buttons>0)V0("end",V);Y0(null)},onTouchStart:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(V.touches.length>=2){p0();let o=V.touches[0],X0=V.touches[1],q0={x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:(X0.clientX-L.left)/L.width,y2:(X0.clientY-L.top)/L.height};if(!C0.current&&!l.current)m({type:"end",x:q0.x1,y:q0.y1});C0.current=!0,u.current=!0,l.current=!1,Y0(q0),y({type:"begin",...q0});return}let U=V.touches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(M4(D,b),b>0.88)l.current=!0,m({type:"begin",x:D,y:b,edge:J0});else l.current=!1,m({type:"begin",x:D,y:b})},onTouchMove:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(C0.current&&V.touches.length>=2){let o=V.touches[0],X0=V.touches[1],q0={x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:(X0.clientX-L.left)/L.width,y2:(X0.clientY-L.top)/L.height};Y0(q0),y({type:"move",...q0});return}let U=V.touches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(C4(D,b),l.current)m({type:"move",x:D,y:b,edge:J0});else m({type:"move",x:D,y:b})},onTouchEnd:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(C0.current){if(V.touches.length<2){let o=V.changedTouches[0],X0=H0;if(o&&X0)y({type:"end",x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:X0.x2,y2:X0.y2});else if(X0)y({type:"end",...X0});C0.current=!1,u.current=!1,Y0(null)}return}let U=V.changedTouches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(p0(),l.current)m({type:"end",x:D,y:b,edge:J0}),l.current=!1;else m({type:"end",x:D,y:b})}}),N("div",{ref:y0,"data-testid":"touch-indicator",style:{position:"absolute",display:"none",width:24,height:24,borderRadius:"50%",background:"rgba(59,130,246,0.5)",boxShadow:"0 0 8px rgba(59,130,246,0.3)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}),H0&&N(d,{children:[N("div",{"data-testid":"finger-dot",style:R5(H0.x1,H0.y1)}),N("div",{"data-testid":"finger-dot",style:R5(H0.x2,H0.y2)})]}),!h&&!n&&N("div",{style:b5,children:N("span",{style:{color:"#888",fontSize:14},children:"Connecting..."})}),n&&N("div",{style:b5,children:N("span",{style:{color:"#f44",fontSize:14,padding:20,textAlign:"center"},children:n})}),J4&&N("div",{style:F6,children:N("span",{style:{color:"#fbbf24",fontSize:13,fontFamily:"monospace"},children:"Slow connection"})})]})}),!_&&N("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 8px",borderTop:"1px solid rgba(255,255,255,0.12)"},children:[N("button",{onClick:g5,style:{background:"none",border:"1px solid rgba(255,255,255,0.2)",color:"#aaa",fontSize:11,fontFamily:"monospace",padding:"2px 10px",cursor:"pointer",borderRadius:4},children:"Home"}),N("span",{style:{color:j0>0?"#4f4":"#888",fontSize:12,fontFamily:"monospace",display:"flex",alignItems:"center",gap:6},children:[C&&N("span",{"data-testid":"quality-dot",style:{width:8,height:8,borderRadius:"50%",display:"inline-block",background:C==="good"?"#4ade80":C==="degraded"?"#facc15":"#ef4444"}}),j0," fps"]})]})]})}var F6={position:"absolute",top:8,left:"50%",transform:"translateX(-50%)",background:"rgba(0,0,0,0.7)",borderRadius:6,padding:"4px 12px",pointerEvents:"none"},b5={position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.8)"},S5=20;function R5(X,Z){return{position:"absolute",left:`${X*100}%`,top:`${Z*100}%`,width:S5,height:S5,borderRadius:"50%",background:"rgba(255,255,255,0.4)",border:"1px solid rgba(255,255,255,0.7)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}function k0(X){if(!X)return"iphone";let Z=X.toLowerCase();if(Z.includes("ipad"))return"ipad";if(Z.includes("watch"))return"watch";if(Z.includes("vision"))return"vision";return"iphone"}var $0={iphone:{width:427,height:881,bezelX:18,bezelY:18,innerRadius:55},ipad:{width:430,height:605,bezelX:16,bezelY:16,innerRadius:12},watch:{width:274,height:322,bezelX:12,bezelY:12,innerRadius:79},vision:{width:640,height:400,bezelX:12,bezelY:12,innerRadius:32}},w7=$0.iphone.width,T7=$0.iphone.height,b7=$0.iphone.bezelX,S7=$0.iphone.bezelY,R7=$0.iphone.innerRadius;function e0(X="iphone"){let Z=$0[X],J=Z.width-2*Z.bezelX,Y=Z.height-2*Z.bezelY;return`${Z.innerRadius/J*100}% / ${Z.innerRadius/Y*100}%`}var D4=_0(null);function X4(X){let Z=R0(D4);if(!Z)throw Error(`<SimulatorToolbar.${X}> must be rendered inside <SimulatorToolbar>`);return Z}var C6={display:"flex",flexWrap:"wrap",alignItems:"center",justifyContent:"space-between",gap:"4px 12px",padding:"8px 12px",borderRadius:24,background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.1)",boxShadow:"0 1px 2px rgba(0,0,0,0.2)",minWidth:240,width:"100%"};function E6({exec:X,deviceUdid:Z,deviceName:J,deviceRuntime:Y,streaming:q=!1,disabled:Q=!1,children:K,style:W,...G}){let z=k0(J),$={exec:X,deviceUdid:Z,deviceName:J,deviceRuntime:Y,deviceType:z,streaming:q,disabled:Q||!Z||!q};return N(D4.Provider,{value:$,children:N("div",{"data-simulator-toolbar":!0,style:{...C6,...W},...G,children:K})})}var w6={display:"flex",flexDirection:"column",alignItems:"flex-start",textAlign:"left",background:"transparent",border:"none",color:"#fff",padding:"2px 4px",margin:"-2px -4px",borderRadius:6,cursor:"pointer",minWidth:0,maxWidth:"100%",lineHeight:1.2,fontFamily:"inherit"},T6=D0(function({name:Z,subtitle:J,hideChevron:Y,style:q,onMouseEnter:Q,onMouseLeave:K,...W},G){let z=X4("Title"),[P,$]=S(!1),_=Z??z.deviceName??"No simulator",O=J??(z.deviceRuntime?z.deviceRuntime.replace(/\./," "):"—");return N("button",{ref:G,type:"button","data-simulator-toolbar-title":!0,onMouseEnter:(C)=>{$(!0),Q?.(C)},onMouseLeave:(C)=>{$(!1),K?.(C)},style:{...w6,background:P?"rgba(255,255,255,0.1)":"transparent",...q},...W,children:[N("span",{style:{display:"inline-flex",alignItems:"center",gap:4,fontSize:12,fontWeight:600,color:"#fff",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:[_,!Y&&N("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"rgba(255,255,255,0.6)",flexShrink:0},children:N("polyline",{points:"6 9 12 15 18 9"})})]}),N("span",{style:{fontSize:10,color:"rgba(255,255,255,0.5)",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:O})]})}),b6={display:"flex",alignItems:"center",gap:4,flexShrink:0};function S6({style:X,...Z}){return N("div",{style:{...b6,...X},...Z})}var R6={background:"transparent",border:"none",padding:6,borderRadius:6,cursor:"pointer",display:"inline-flex",alignItems:"center",justifyContent:"center",color:"rgba(255,255,255,0.8)",transition:"background-color 0.15s, color 0.15s"},Z4=D0(function({forceDisabled:Z,style:J,disabled:Y,onMouseEnter:q,onMouseLeave:Q,children:K,...W},G){let z=R0(D4),P=Y||Z||z?.disabled,[$,_]=S(!1);return N("button",{ref:G,type:"button",disabled:P,onMouseEnter:(O)=>{_(!0),q?.(O)},onMouseLeave:(O)=>{_(!1),Q?.(O)},style:{...R6,color:P?"rgba(255,255,255,0.25)":"rgba(255,255,255,0.8)",background:$&&!P?"rgba(255,255,255,0.1)":"transparent",cursor:P?"not-allowed":"pointer",...J},...W,children:K})});function j6(){return['tell application "System Events" to tell process "Simulator" to set frontmost to true','tell application "System Events" to tell process "Simulator" to perform action "AXRaise" of (first window whose name contains "watchOS")','tell application "System Events" to tell process "Simulator" to click menu item "Home" of menu "Device" of menu bar item "Device" of menu bar 1'].map((Z)=>`-e '${Z}'`).reduce((Z,J)=>`${Z} ${J}`,"osascript")}var v6=N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:N("path",{d:"M3 10.5 12 3l9 7.5V20a1 1 0 0 1-1 1h-5v-7h-6v7H4a1 1 0 0 1-1-1z"})}),y6=N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[N("path",{d:"M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3z"}),N("circle",{cx:"12",cy:"13",r:"4"})]}),p6=N("svg",{width:"18",height:"18",viewBox:"0 0 12 13",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",children:N("path",{d:"M10.2305 12.8077H4.42383C3.92383 12.8077 3.54688 12.6846 3.29297 12.4385C3.04297 12.1963 2.91797 11.8194 2.91797 11.3077V5.51274C2.91797 4.99711 3.04297 4.61821 3.29297 4.37602C3.54688 4.12993 3.92383 4.00688 4.42383 4.00688H10.2305C10.7344 4.00688 11.1113 4.12993 11.3613 4.37602C11.6113 4.61821 11.7363 4.99711 11.7363 5.51274V11.3077C11.7363 11.8194 11.6113 12.1963 11.3613 12.4385C11.1113 12.6846 10.7344 12.8077 10.2305 12.8077ZM10.2129 11.8643C10.416 11.8643 10.5625 11.8194 10.6523 11.7295C10.7461 11.6436 10.793 11.4971 10.793 11.2901V5.52446C10.793 5.31743 10.7461 5.17094 10.6523 5.08501C10.5625 4.99516 10.416 4.95024 10.2129 4.95024H4.44141C4.24219 4.95024 4.0957 4.99516 4.00195 5.08501C3.9082 5.17094 3.86133 5.31743 3.86133 5.52446V11.2901C3.86133 11.4971 3.9082 11.6436 4.00195 11.7295C4.0957 11.8194 4.24219 11.8643 4.44141 11.8643H10.2129ZM2.91797 2.58305V0.415083C2.91797 0.20024 2.98633 0.0693803 3.12305 0.0225053C3.25977 -0.0282759 3.41016 0.00688033 3.57422 0.127974L5.05078 1.21196C5.17578 1.30571 5.23828 1.40141 5.23828 1.49907C5.23828 1.59672 5.17578 1.69243 5.05078 1.78618L3.57422 2.8643C3.41016 2.9854 3.25977 3.02251 3.12305 2.97563C2.98633 2.92485 2.91797 2.79399 2.91797 2.58305ZM3.5332 1.15336C3.62695 1.15336 3.70703 1.18657 3.77344 1.25297C3.84375 1.31938 3.87891 1.39751 3.87891 1.48735C3.87891 1.5811 3.84375 1.66313 3.77344 1.73344C3.70703 1.79985 3.62695 1.83305 3.5332 1.83305H2.80664C2.38086 1.83305 2.01172 1.92485 1.69922 2.10844C1.39062 2.28813 1.15234 2.53813 0.984375 2.85844C0.816406 3.17876 0.732422 3.54594 0.732422 3.96001V4.83891C0.732422 4.93657 0.697266 5.02251 0.626953 5.09672C0.552734 5.16704 0.464844 5.20219 0.363281 5.20219C0.265625 5.20219 0.181641 5.16704 0.111328 5.09672C0.0371094 5.02251 0 4.93657 0 4.83891V3.96001C0 3.40141 0.117188 2.91118 0.351562 2.4893C0.582031 2.06743 0.908203 1.7393 1.33008 1.50493C1.74805 1.27055 2.23828 1.15336 2.80078 1.15336H3.5332Z"})}),g6=D0(function({onClick:Z,...J},Y){let q=X4("HomeButton");return N(Z4,{ref:Y,"aria-label":"Home",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceType==="watch")q.exec(j6());else q.exec("serve-sim button home")},...J,children:v6})}),x6=D0(function({onClick:Z,...J},Y){let q=X4("ScreenshotButton");return N(Z4,{ref:Y,"aria-label":"Screenshot",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceUdid)q.exec(`xcrun simctl io ${q.deviceUdid} screenshot ~/Desktop/hatch-screenshot-$(date +%s).png`)},...J,children:y6})}),h6=D0(function({onClick:Z,...J},Y){let q=X4("RotateButton");return N(Z4,{ref:Y,"aria-label":"Rotate device",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceUdid)q.exec(`osascript -e 'tell application "Simulator" to activate' -e 'tell application "System Events" to key code 124 using {command down}'`)},...J,children:p6})}),t=E6;t.Title=T6;t.Actions=S6;t.Button=Z4;t.HomeButton=g6;t.ScreenshotButton=x6;t.RotateButton=h6;function m6(X){let[Z,J]=S(null),Y=w(new Set),[q,Q]=S(null),K=j((W)=>{return Y.current.add(W),()=>{Y.current.delete(W)}},[]);return x(()=>{if(!X)return;let W=new AbortController,G=X.replace(/\/stream\.mjpeg$/,"");return fetch(`${G}/config`,{signal:W.signal}).then((z)=>z.json()).then((z)=>{if(z.width>0&&z.height>0)J(z)}).catch(()=>{}),(async()=>{try{let P=(await fetch(X,{signal:W.signal})).body?.getReader();if(!P)return;let $=new Uint8Array(0);while(!0){let{done:_,value:O}=await P.read();if(_)break;let C=new Uint8Array($.length+O.length);C.set($),C.set(O,$.length),$=C;while(!0){let A=-1;for(let E=0;E<$.length-1;E++)if($[E]===255&&$[E+1]===216){A=E;break}if(A===-1)break;let k=-1;for(let E=A+2;E<$.length-1;E++)if($[E]===255&&$[E+1]===217){k=E+2;break}if(k===-1)break;let I=$.slice(A,k);$=$.slice(k);let M=new Blob([I],{type:"image/jpeg"}),h=URL.createObjectURL(M);Q(h);for(let E of Y.current)E(h)}}}catch{}})(),()=>W.abort()},[X]),{subscribeFrame:K,frame:q,config:Z}}var d6={KeyA:4,KeyB:5,KeyC:6,KeyD:7,KeyE:8,KeyF:9,KeyG:10,KeyH:11,KeyI:12,KeyJ:13,KeyK:14,KeyL:15,KeyM:16,KeyN:17,KeyO:18,KeyP:19,KeyQ:20,KeyR:21,KeyS:22,KeyT:23,KeyU:24,KeyV:25,KeyW:26,KeyX:27,KeyY:28,KeyZ:29,Digit1:30,Digit2:31,Digit3:32,Digit4:33,Digit5:34,Digit6:35,Digit7:36,Digit8:37,Digit9:38,Digit0:39,Enter:40,Escape:41,Backspace:42,Tab:43,Space:44,Minus:45,Equal:46,BracketLeft:47,BracketRight:48,Backslash:49,Semicolon:51,Quote:52,Backquote:53,Comma:54,Period:55,Slash:56,CapsLock:57,F1:58,F2:59,F3:60,F4:61,F5:62,F6:63,F7:64,F8:65,F9:66,F10:67,F11:68,F12:69,PrintScreen:70,ScrollLock:71,Pause:72,Insert:73,Home:74,PageUp:75,Delete:76,End:77,PageDown:78,ArrowRight:79,ArrowLeft:80,ArrowDown:81,ArrowUp:82,NumLock:83,NumpadDivide:84,NumpadMultiply:85,NumpadSubtract:86,NumpadAdd:87,NumpadEnter:88,Numpad1:89,Numpad2:90,Numpad3:91,Numpad4:92,Numpad5:93,Numpad6:94,Numpad7:95,Numpad8:96,Numpad9:97,Numpad0:98,NumpadDecimal:99,ControlLeft:224,ShiftLeft:225,AltLeft:226,MetaLeft:227,ControlRight:228,ShiftRight:229,AltRight:230,MetaRight:231};function f6(X){return d6[X]??null}async function A0(X){return(await fetch("/exec",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({command:X})})).json()}function a6(X){try{let Z=JSON.parse(X),J=[];for(let[Y,q]of Object.entries(Z.devices??{})){let Q=Y.replace(/^com\.apple\.CoreSimulator\.SimRuntime\./,"").replace(/-/g,".");for(let K of q)if(K.isAvailable)J.push({udid:K.udid,name:K.name,state:K.state,runtime:Q})}return J}catch{return[]}}function j5(X){let Z=X.toLowerCase();if(Z.includes("iphone"))return 0;if(Z.includes("ipad"))return 1;if(Z.includes("watch"))return 2;if(Z.includes("vision"))return 3;return 4}function v5(X){let Z=X.toLowerCase();if(Z.startsWith("ios"))return 0;if(Z.startsWith("ipados"))return 1;if(Z.startsWith("watchos"))return 2;if(Z.startsWith("visionos")||Z.startsWith("xros"))return 3;return 4}function l6({devices:X,selectedUdid:Z,loading:J,error:Y,stoppingUdids:q,onRefresh:Q,onSelect:K,onStop:W,trigger:G}){let[z,P]=S(!1),$=w(null);x(()=>{if(!z)return;let A=(k)=>{if(!$.current?.contains(k.target))P(!1)};return window.addEventListener("mousedown",A),()=>window.removeEventListener("mousedown",A)},[z]);let _=new Map;for(let A of X){if(A.udid===Z)continue;let k=_.get(A.runtime);if(!k)k=[],_.set(A.runtime,k);k.push(A)}for(let A of _.values())A.sort((k,I)=>j5(k.name)-j5(I.name)||k.name.localeCompare(I.name));let O=[..._.entries()].sort(([A],[k])=>v5(A)-v5(k)||A.localeCompare(k)),C=X.find((A)=>A.udid===Z)??null;return N("div",{ref:$,style:{position:"relative"},children:[N("div",{onClick:()=>{if(!z)Q();P((A)=>!A)},children:G}),z&&N("div",{style:i6,children:[N("div",{style:u6,children:[N("span",{style:{fontWeight:600},children:"Simulators"}),N("button",{onClick:(A)=>{A.stopPropagation(),Q()},disabled:J,style:o6,children:J?"...":"Refresh"})]}),Y&&N("div",{style:s6,children:Y}),C&&N(d,{children:[N("div",{style:{...p5,color:"#a5b4fc"},children:[N("span",{style:y5(C.state==="Booted"?"#4ade80":"#444")}),N("span",{style:{flex:1},children:C.name})]}),N("div",{style:r6})]}),X.length===0&&!J&&!Y&&N("div",{style:t6,children:"No available simulators found"}),O.map(([A,k])=>N("div",{children:[N("div",{style:n6,children:A}),k.map((I)=>{let M=q.has(I.udid),h=I.state==="Booted";return N("div",{style:p5,onMouseEnter:(E)=>E.currentTarget.style.background="rgba(255,255,255,0.08)",onMouseLeave:(E)=>E.currentTarget.style.background="transparent",onClick:()=>{K(I),P(!1)},children:[N("span",{style:y5(h?"#4ade80":"#444")}),N("span",{style:{flex:1},children:I.name}),h&&N("span",{role:"button",onClick:(E)=>{if(E.stopPropagation(),!M)W(I.udid)},style:{fontSize:10,padding:"1px 6px",borderRadius:4,color:M?"#888":"#f87171",background:M?"transparent":"rgba(248,113,113,0.1)",cursor:M?"default":"pointer"},children:M?"Stopping...":"Stop"})]},I.udid)})]},A))]})]})}function y5(X){return{width:6,height:6,borderRadius:"50%",background:X,flexShrink:0}}function c6(){let X=window.__SIM_PREVIEW__,[Z,J]=S(!1),[Y,q]=S([]),[Q,K]=S(!1),[W,G]=S(null),[z,P]=S(new Set),[$,_]=S(!1),O=j(async()=>{K(!0),G(null);try{let F=await A0("xcrun simctl list devices available -j");if(F.exitCode!==0)throw Error(F.stderr||"simctl list failed");q(a6(F.stdout))}catch(F){G(F instanceof Error?F.message:"Failed to list devices")}finally{K(!1)}},[]);if(x(()=>{O()},[O]),x(()=>{if(!X?.logsEndpoint)return;let F=new EventSource(X.logsEndpoint),R=new Map,v=["#8be9fd","#50fa7b","#ffb86c","#ff79c6","#bd93f9","#f1fa8c","#6272a4","#ff5555","#69ff94","#d6acff","#ffffa5","#a4ffff","#ff6e6e","#caa9fa","#5af78e"];function T(Z0){let y=R.get(Z0);if(!y){let e=0;for(let a=0;a<Z0.length;a++)e=(e<<5)-e+Z0.charCodeAt(a)|0;y=v[Math.abs(e)%v.length],R.set(Z0,y)}return y}let i="",m=!1;return F.onmessage=(Z0)=>{try{let y=JSON.parse(Z0.data),e=y.processImagePath?.split("/").pop()??y.senderImagePath?.split("/").pop()??"",a=y.subsystem??"",V0=y.category??"",J0=y.eventMessage??"";if(!J0)return;if(e!==i){if(m)console.groupEnd();let M0=T(e);console.groupCollapsed(`%c${e}${a?` %c${a}${V0?":"+V0:""}`:""}`,`color:${M0};font-weight:bold`,...a?["color:#888;font-weight:normal"]:[]),m=!0,i=e}let l=(y.messageType??"").toLowerCase(),u=a&&e===i?`%c${V0||a}%c `:"",U0=u?["color:#888;font-style:italic","color:inherit"]:[];if(l==="fault"||l==="error")console.log(`${u}%c${J0}`,...U0,"color:#ff5555");else if(l==="debug")console.log(`${u}%c${J0}`,...U0,"color:#6272a4");else console.log(`${u}%c${J0}`,...U0,"color:inherit")}catch{}},()=>{if(m)console.groupEnd();F.close()}},[X?.logsEndpoint]),!X)return N("div",{style:N0.page,children:N("div",{style:N0.empty,children:[N("h1",{style:N0.emptyTitle,children:"No serve-sim stream running"}),N("p",{style:N0.emptyHint,children:["Boot an iOS simulator and start a Hatch stream with"," ",N("code",{style:N0.code,children:"bunx serve-sim --detach"}),", then reload."]})]})});let C=Y.find((F)=>F.udid===X.device)??null,A=k0(C?.name),k=$0[A],I=k.width-2*k.bezelX,M=k.height-2*k.bezelY,h=e0(A),E=A==="vision"?580:A==="ipad"?400:A==="watch"?200:320,n=m6(X.streamUrl),Q0=w(null);x(()=>{let F=new WebSocket(X.wsUrl);return F.binaryType="arraybuffer",Q0.current=F,()=>{F.close(),Q0.current=null}},[X.wsUrl]);let g=j((F,R)=>{let v=Q0.current;if(!v||v.readyState!==WebSocket.OPEN)return;let T=new TextEncoder().encode(JSON.stringify(R)),i=new Uint8Array(1+T.length);i[0]=F,i.set(T,1),v.send(i)},[]),K0=j((F)=>g(3,F),[g]),s=j((F)=>g(5,F),[g]),r=j((F)=>g(4,{button:F}),[g]),O0=j((F,R)=>{g(6,{type:F,usage:R})},[g]),[j0,v0]=S(null);x(()=>{let F=new EventSource("/appstate"),R=null;return F.onmessage=(v)=>{try{let T=JSON.parse(v.data);if(R)clearTimeout(R);let i=T?.isReactNative?0:600;R=setTimeout(()=>v0(T),i)}catch{}},()=>{if(R)clearTimeout(R);F.close()}},[]);let G0=j(async()=>{O0("down",227),await new Promise((v)=>setTimeout(v,30)),O0("down",21),await new Promise((v)=>setTimeout(v,30)),O0("up",21),await new Promise((v)=>setTimeout(v,30)),O0("up",227)},[O0]);x(()=>{let F=(T,i)=>{if(T.code==="KeyH"&&T.metaKey&&T.shiftKey){if(T.preventDefault(),i==="down"&&!T.repeat)g(4,{button:"home"});return}if(T.code==="KeyA"&&T.metaKey&&T.shiftKey){if(T.preventDefault(),i==="down"&&!T.repeat)A0(`xcrun simctl ui ${X.device} appearance`).then((Z0)=>{let y=Z0.stdout.trim()==="dark"?"light":"dark";return A0(`xcrun simctl ui ${X.device} appearance ${y}`)}).catch(()=>{});return}let m=f6(T.code);if(m==null)return;T.preventDefault(),g(6,{type:i,usage:m})},R=(T)=>F(T,"down"),v=(T)=>F(T,"up");return window.addEventListener("keydown",R),window.addEventListener("keyup",v),()=>{window.removeEventListener("keydown",R),window.removeEventListener("keyup",v)}},[g,X.device]);let J4=j(async(F)=>{if($||F.udid===X.device)return;_(!0);try{if(F.state!=="Booted")await A0(`xcrun simctl boot ${F.udid}`);await A0(`bunx serve-sim --kill ${X.device}`),await A0(`bunx serve-sim --detach ${F.udid}`),window.location.reload()}catch{_(!1)}},[$,X.device]),I0=j(async(F)=>{P((R)=>new Set(R).add(F));try{await A0(`xcrun simctl shutdown ${F}`),await O()}finally{P((R)=>{let v=new Set(R);return v.delete(F),v})}},[O]);return N("div",{style:N0.page,children:[N(t,{exec:A0,deviceUdid:X.device,deviceName:C?.name??null,deviceRuntime:C?.runtime??null,streaming:Z,style:{maxWidth:E},children:[N(l6,{devices:Y,selectedUdid:X.device,loading:Q,error:W,stoppingUdids:z,onRefresh:O,onSelect:J4,onStop:I0,trigger:N(t.Title,{})}),N(t.Actions,{children:[j0?.isReactNative&&N(t.Button,{"aria-label":"Reload React Native bundle",title:"Reload (Cmd+R)",onClick:()=>void G0(),children:N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[N("path",{d:"M3 12a9 9 0 1 0 3.5-7.1"}),N("polyline",{points:"3 3 3 9 9 9"})]})}),N(t.HomeButton,{onClick:(F)=>{F.preventDefault(),r("home")}}),N(t.ScreenshotButton,{}),N(t.RotateButton,{})]})]}),N("div",{style:{maxWidth:E,width:"100%",aspectRatio:`${I} / ${M}`},children:N(n0,{url:X.url,style:{width:"100%",height:"100%",border:"none"},imageStyle:{borderRadius:h,cornerShape:"superellipse(1.3)"},hideControls:!0,onStreamingChange:J,onStreamTouch:K0,onStreamMultiTouch:s,onStreamButton:r,subscribeFrame:n.subscribeFrame,streamFrame:n.frame,streamConfig:n.config})}),N("div",{style:N0.bar,children:N("span",{style:{...N0.live,color:Z?"#4ade80":"#666"},children:[N("span",{style:{...N0.dot,background:Z?"#4ade80":"#666"}}),Z?"live":"connecting"]})})]})}var N0={page:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",background:"#0a0a0a",padding:24,gap:12,fontFamily:"-apple-system, system-ui, sans-serif"},bar:{display:"flex",alignItems:"center",gap:10,fontSize:12,fontFamily:"ui-monospace, monospace",color:"#666"},live:{display:"flex",alignItems:"center",gap:5,transition:"color 0.3s"},dot:{width:6,height:6,borderRadius:"50%",transition:"background 0.3s"},empty:{display:"flex",flexDirection:"column",alignItems:"center",gap:12,textAlign:"center"},emptyTitle:{fontSize:18,margin:0,color:"#eee"},emptyHint:{color:"#888",fontSize:14,maxWidth:480},code:{background:"#222",padding:"2px 6px",borderRadius:4,fontSize:13}},i6={position:"absolute",top:"calc(100% + 6px)",left:0,minWidth:260,maxHeight:360,overflowY:"auto",background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.12)",borderRadius:10,padding:4,boxShadow:"0 8px 24px rgba(0,0,0,0.5)",fontFamily:"ui-monospace, monospace",fontSize:13,color:"#eee",zIndex:20},u6={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"6px 10px",fontSize:11,color:"#aaa"},o6={background:"transparent",border:"none",color:"#a5b4fc",fontSize:11,cursor:"pointer",padding:0},s6={padding:"6px 10px",color:"#f87171",fontSize:11},p5={display:"flex",alignItems:"center",gap:8,padding:"6px 10px",borderRadius:6,cursor:"pointer",transition:"background 0.15s"},r6={height:1,background:"rgba(255,255,255,0.08)",margin:"4px 0"},t6={padding:12,color:"rgba(255,255,255,0.4)",fontSize:11,textAlign:"center"},n6={padding:"6px 10px 2px",fontSize:10,fontWeight:600,color:"rgba(255,255,255,0.4)",textTransform:"uppercase",letterSpacing:"0.08em"};P5(document.getElementById("root")).render(N(c6,{}));
</script>
</body></html>","base64").toString("utf-8");return P}function b($){let C=($?.basePath??"/.sim").replace(/\/+$/,"");return(J,z,K)=>{let X=J.url??"";if(X===C||X===C+"/"){let Q=O()[0]??null,V=p();if(Q){let G=`<script>window.__SIM_PREVIEW__=${JSON.stringify({...Q,logsEndpoint:C+"/logs"})}</script>`;V=V.replace("<!--__SIM_PREVIEW_CONFIG__-->",G)}z.writeHead(200,{"Content-Type":"text/html; charset=utf-8","Cache-Control":"no-store"}),z.end(V);return}if(X===C+"/api"){let W=O();z.writeHead(200,{"Content-Type":"application/json","Cache-Control":"no-store"}),z.end(JSON.stringify(W[0]||null));return}if((X===C+"/exec"||X===C+"/exec/")&&J.method==="POST"){let W="";J.on("data",(Q)=>{W+=typeof Q==="string"?Q:Q.toString()}),J.on("end",()=>{let Q="";try{Q=JSON.parse(W).command??""}catch{}if(!Q){z.writeHead(400,{"Content-Type":"application/json"}),z.end(JSON.stringify({stdout:"",stderr:"Missing command",exitCode:1}));return}g(Q,{maxBuffer:16777216},(V,Y,G)=>{z.writeHead(200,{"Content-Type":"application/json"}),z.end(JSON.stringify({stdout:Y.toString(),stderr:G.toString(),exitCode:V?V.code??1:0}))})});return}if(X===C+"/logs"||X.startsWith(C+"/logs?")){let W=O();if(W.length===0){z.writeHead(404),z.end("No serve-sim device");return}let Q=W[0].device;z.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),z.write(`:
|
|
3
3
|
|
|
4
|
-
`);let
|
|
5
|
-
`))!==-1){let
|
|
4
|
+
`);let V=U("xcrun",["simctl","spawn",Q,"log","stream","--style","ndjson","--level","info"],{stdio:["ignore","pipe","ignore"]}),Y="";V.stdout.on("data",(G)=>{Y+=G.toString();let Z;while((Z=Y.indexOf(`
|
|
5
|
+
`))!==-1){let M=Y.slice(0,Z).trim();if(Y=Y.slice(Z+1),M)z.write("data: "+M+`
|
|
6
6
|
|
|
7
|
-
`)}}),
|
|
7
|
+
`)}}),V.on("close",()=>z.end()),J.on("close",()=>V.kill());return}if(X===C+"/appstate"||X.startsWith(C+"/appstate?")){let W=O();if(W.length===0){z.writeHead(404),z.end("No serve-sim device");return}let Q=W[0].device;z.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),z.write(`:
|
|
8
|
+
|
|
9
|
+
`);let V=U("xcrun",["simctl","spawn",Q,"log","stream","--style","ndjson","--level","info","--predicate",'process == "SpringBoard" AND eventMessage CONTAINS "Setting process visibility to: Foreground"'],{stdio:["ignore","pipe","ignore"]}),Y=/\[app<([^>]+)>:(\d+)\] Setting process visibility to: Foreground/,G="",Z="";V.stdout.on("data",(M)=>{Z+=M.toString();let w;while((w=Z.indexOf(`
|
|
10
|
+
`))!==-1){let A=Z.slice(0,w).trim();if(Z=Z.slice(w+1),!A)continue;let T;try{T=JSON.parse(A).eventMessage??""}catch{continue}let L=Y.exec(T);if(!L)continue;let H=L[1],D=parseInt(L[2],10);if(!I(H))continue;if(H===G)continue;G=H,v(Q,H).then((F)=>{z.write("data: "+JSON.stringify({bundleId:H,pid:D,isReactNative:F})+`
|
|
11
|
+
|
|
12
|
+
`)})}}),V.on("close",()=>z.end()),J.on("close",()=>V.kill());return}if(K)K()}}export{b as simMiddleware};
|
package/dist/serve-sim.js
CHANGED
|
@@ -1,17 +1,22 @@
|
|
|
1
1
|
#!/usr/bin/env bun
|
|
2
2
|
// @bun
|
|
3
|
-
var $e=Object.defineProperty;var ye=(e,_)=>{for(var t in _)$e(e,t,{get:_[t],enumerable:!0,configurable:!0,set:(C)=>_[t]=()=>C})};var ce=(e,_)=>()=>(e&&(_=e(e=0)),_);var U={};ye(U,{simMiddleware:()=>ge});import{readdirSync as pe,readFileSync as He}from"fs";import{spawn as Te}from"child_process";import{tmpdir as ue}from"os";import{join as P}from"path";function N(){let e;try{e=pe(k).filter((t)=>t.startsWith("server-")&&t.endsWith(".json"))}catch{return[]}let _=[];for(let t of e)try{let C=JSON.parse(He(P(k,t),"utf-8"));try{process.kill(C.pid,0),_.push(C)}catch{}}catch{}return _}function le(){if(!V)V=Buffer.from("<!doctype html>
<html><head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Simulator Preview</title>
<style>*,*::before,*::after{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}</style>
</head><body>
<div id="root"></div>
<!--__SIM_PREVIEW_CONFIG__-->
<script type="module">var b0,P,b4,j5,K0,w4,p4,v4,X4,C0,U0,j4,K4,Y4,Z4,R4,w0={},S0=[],R5=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,A0=Array.isArray;function X0(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function Q4(X){X&&X.parentNode&&X.parentNode.removeChild(X)}function Y0(X,Y,Z){var J,q,K,Q={};for(K in Y)K=="key"?J=Y[K]:K=="ref"?q=Y[K]:Q[K]=Y[K];if(arguments.length>2&&(Q.children=arguments.length>3?b0.call(arguments,2):Z),typeof X=="function"&&X.defaultProps!=null)for(K in X.defaultProps)Q[K]===void 0&&(Q[K]=X.defaultProps[K]);return E0(X,Q,J,q,null)}function E0(X,Y,Z,J,q){var K={type:X,props:Y,key:Z,ref:J,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:q==null?++b4:q,__i:-1,__u:0};return q==null&&P.vnode!=null&&P.vnode(K),K}function x(X){return X.children}function g(X,Y){this.props=X,this.context=Y}function L0(X,Y){if(Y==null)return X.__?L0(X.__,X.__i+1):null;for(var Z;Y<X.__k.length;Y++)if((Z=X.__k[Y])!=null&&Z.__e!=null)return Z.__e;return typeof X.type=="function"?L0(X):null}function y5(X){if(X.__P&&X.__d){var Y=X.__v,Z=Y.__e,J=[],q=[],K=X0({},Y);K.__v=Y.__v+1,P.vnode&&P.vnode(K),$4(X.__P,K,Y,X.__n,X.__P.namespaceURI,32&Y.__u?[Z]:null,J,Z==null?L0(Y):Z,!!(32&Y.__u),q),K.__v=Y.__v,K.__.__k[K.__i]=K,d4(J,K,q),Y.__e=Y.__=null,K.__e!=Z&&y4(K)}}function y4(X){if((X=X.__)!=null&&X.__c!=null)return X.__e=X.__c.base=null,X.__k.some(function(Y){if(Y!=null&&Y.__e!=null)return X.__e=X.__c.base=Y.__e}),y4(X)}function J4(X){(!X.__d&&(X.__d=!0)&&K0.push(X)&&!T0.__r++||w4!=P.debounceRendering)&&((w4=P.debounceRendering)||p4)(T0)}function T0(){try{for(var X,Y=1;K0.length;)K0.length>Y&&K0.sort(v4),X=K0.shift(),Y=K0.length,y5(X)}finally{K0.length=T0.__r=0}}function g4(X,Y,Z,J,q,K,Q,z,G,L,D){var W,O,U,k,_,C,M,F=J&&J.__k||S0,E=Y.length;for(G=g5(Z,Y,F,G,E),W=0;W<E;W++)(U=Z.__k[W])!=null&&(O=U.__i!=-1&&F[U.__i]||w0,U.__i=W,C=$4(X,U,O,q,K,Q,z,G,L,D),k=U.__e,U.ref&&O.ref!=U.ref&&(O.ref&&W4(O.ref,null,U),D.push(U.ref,U.__c||k,U)),_==null&&k!=null&&(_=k),(M=!!(4&U.__u))||O.__k===U.__k?(G=x4(U,G,X,M),M&&O.__e&&(O.__e=null)):typeof U.type=="function"&&C!==void 0?G=C:k&&(G=k.nextSibling),U.__u&=-7);return Z.__e=_,G}function g5(X,Y,Z,J,q){var K,Q,z,G,L,D=Z.length,W=D,O=0;for(X.__k=Array(q),K=0;K<q;K++)(Q=Y[K])!=null&&typeof Q!="boolean"&&typeof Q!="function"?(typeof Q=="string"||typeof Q=="number"||typeof Q=="bigint"||Q.constructor==String?Q=X.__k[K]=E0(null,Q,null,null,null):A0(Q)?Q=X.__k[K]=E0(x,{children:Q},null,null,null):Q.constructor===void 0&&Q.__b>0?Q=X.__k[K]=E0(Q.type,Q.props,Q.key,Q.ref?Q.ref:null,Q.__v):X.__k[K]=Q,G=K+O,Q.__=X,Q.__b=X.__b+1,z=null,(L=Q.__i=x5(Q,Z,G,W))!=-1&&(W--,(z=Z[L])&&(z.__u|=2)),z==null||z.__v==null?(L==-1&&(q>D?O--:q<D&&O++),typeof Q.type!="function"&&(Q.__u|=4)):L!=G&&(L==G-1?O--:L==G+1?O++:(L>G?O--:O++,Q.__u|=4))):X.__k[K]=null;if(W)for(K=0;K<D;K++)(z=Z[K])!=null&&(2&z.__u)==0&&(z.__e==J&&(J=L0(z)),h4(z,z));return J}function x4(X,Y,Z,J){var q,K;if(typeof X.type=="function"){for(q=X.__k,K=0;q&&K<q.length;K++)q[K]&&(q[K].__=X,Y=x4(q[K],Y,Z,J));return Y}X.__e!=Y&&(J&&(Y&&X.type&&!Y.parentNode&&(Y=L0(X)),Z.insertBefore(X.__e,Y||null)),Y=X.__e);do Y=Y&&Y.nextSibling;while(Y!=null&&Y.nodeType==8);return Y}function Z0(X,Y){return Y=Y||[],X==null||typeof X=="boolean"||(A0(X)?X.some(function(Z){Z0(Z,Y)}):Y.push(X)),Y}function x5(X,Y,Z,J){var q,K,Q,z=X.key,G=X.type,L=Y[Z],D=L!=null&&(2&L.__u)==0;if(L===null&&z==null||D&&z==L.key&&G==L.type)return Z;if(J>(D?1:0)){for(q=Z-1,K=Z+1;q>=0||K<Y.length;)if((L=Y[Q=q>=0?q--:K++])!=null&&(2&L.__u)==0&&z==L.key&&G==L.type)return Q}return-1}function S4(X,Y,Z){Y[0]=="-"?X.setProperty(Y,Z==null?"":Z):X[Y]=Z==null?"":typeof Z!="number"||R5.test(Y)?Z:Z+"px"}function M0(X,Y,Z,J,q){var K,Q;X:if(Y=="style")if(typeof Z=="string")X.style.cssText=Z;else{if(typeof J=="string"&&(X.style.cssText=J=""),J)for(Y in J)Z&&Y in Z||S4(X.style,Y,"");if(Z)for(Y in Z)J&&Z[Y]==J[Y]||S4(X.style,Y,Z[Y])}else if(Y[0]=="o"&&Y[1]=="n")K=Y!=(Y=Y.replace(j4,"$1")),Q=Y.toLowerCase(),Y=Q in X||Y=="onFocusOut"||Y=="onFocusIn"?Q.slice(2):Y.slice(2),X.l||(X.l={}),X.l[Y+K]=Z,Z?J?Z[U0]=J[U0]:(Z[U0]=K4,X.addEventListener(Y,K?Z4:Y4,K)):X.removeEventListener(Y,K?Z4:Y4,K);else{if(q=="http://www.w3.org/2000/svg")Y=Y.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if(Y!="width"&&Y!="height"&&Y!="href"&&Y!="list"&&Y!="form"&&Y!="tabIndex"&&Y!="download"&&Y!="rowSpan"&&Y!="colSpan"&&Y!="role"&&Y!="popover"&&Y in X)try{X[Y]=Z==null?"":Z;break X}catch(z){}typeof Z=="function"||(Z==null||Z===!1&&Y[4]!="-"?X.removeAttribute(Y):X.setAttribute(Y,Y=="popover"&&Z==1?"":Z))}}function T4(X){return function(Y){if(this.l){var Z=this.l[Y.type+X];if(Y[C0]==null)Y[C0]=K4++;else if(Y[C0]<Z[U0])return;return Z(P.event?P.event(Y):Y)}}}function $4(X,Y,Z,J,q,K,Q,z,G,L){var D,W,O,U,k,_,C,M,F,E,I,v,r,f,i,y=Y.type;if(Y.constructor!==void 0)return null;128&Z.__u&&(G=!!(32&Z.__u),K=[z=Y.__e=Z.__e]),(D=P.__b)&&D(Y);X:if(typeof y=="function")try{if(M=Y.props,F=y.prototype&&y.prototype.render,E=(D=y.contextType)&&J[D.__c],I=D?E?E.props.value:D.__:J,Z.__c?C=(W=Y.__c=Z.__c).__=W.__E:(F?Y.__c=W=new y(M,I):(Y.__c=W=new g(M,I),W.constructor=y,W.render=m5),E&&E.sub(W),W.state||(W.state={}),W.__n=J,O=W.__d=!0,W.__h=[],W._sb=[]),F&&W.__s==null&&(W.__s=W.state),F&&y.getDerivedStateFromProps!=null&&(W.__s==W.state&&(W.__s=X0({},W.__s)),X0(W.__s,y.getDerivedStateFromProps(M,W.__s))),U=W.props,k=W.state,W.__v=Y,O)F&&y.getDerivedStateFromProps==null&&W.componentWillMount!=null&&W.componentWillMount(),F&&W.componentDidMount!=null&&W.__h.push(W.componentDidMount);else{if(F&&y.getDerivedStateFromProps==null&&M!==U&&W.componentWillReceiveProps!=null&&W.componentWillReceiveProps(M,I),Y.__v==Z.__v||!W.__e&&W.shouldComponentUpdate!=null&&W.shouldComponentUpdate(M,W.__s,I)===!1){Y.__v!=Z.__v&&(W.props=M,W.state=W.__s,W.__d=!1),Y.__e=Z.__e,Y.__k=Z.__k,Y.__k.some(function(m){m&&(m.__=Y)}),S0.push.apply(W.__h,W._sb),W._sb=[],W.__h.length&&Q.push(W);break X}W.componentWillUpdate!=null&&W.componentWillUpdate(M,W.__s,I),F&&W.componentDidUpdate!=null&&W.__h.push(function(){W.componentDidUpdate(U,k,_)})}if(W.context=I,W.props=M,W.__P=X,W.__e=!1,v=P.__r,r=0,F)W.state=W.__s,W.__d=!1,v&&v(Y),D=W.render(W.props,W.state,W.context),S0.push.apply(W.__h,W._sb),W._sb=[];else do W.__d=!1,v&&v(Y),D=W.render(W.props,W.state,W.context),W.state=W.__s;while(W.__d&&++r<25);W.state=W.__s,W.getChildContext!=null&&(J=X0(X0({},J),W.getChildContext())),F&&!O&&W.getSnapshotBeforeUpdate!=null&&(_=W.getSnapshotBeforeUpdate(U,k)),f=D!=null&&D.type===x&&D.key==null?m4(D.props.children):D,z=g4(X,A0(f)?f:[f],Y,Z,J,q,K,Q,z,G,L),W.base=Y.__e,Y.__u&=-161,W.__h.length&&Q.push(W),C&&(W.__E=W.__=null)}catch(m){if(Y.__v=null,G||K!=null)if(m.then){for(Y.__u|=G?160:128;z&&z.nodeType==8&&z.nextSibling;)z=z.nextSibling;K[K.indexOf(z)]=null,Y.__e=z}else{for(i=K.length;i--;)Q4(K[i]);q4(Y)}else Y.__e=Z.__e,Y.__k=Z.__k,m.then||q4(Y);P.__e(m,Y,Z)}else K==null&&Y.__v==Z.__v?(Y.__k=Z.__k,Y.__e=Z.__e):z=Y.__e=d5(Z.__e,Y,Z,J,q,K,Q,G,L);return(D=P.diffed)&&D(Y),128&Y.__u?void 0:z}function q4(X){X&&(X.__c&&(X.__c.__e=!0),X.__k&&X.__k.some(q4))}function d4(X,Y,Z){for(var J=0;J<Z.length;J++)W4(Z[J],Z[++J],Z[++J]);P.__c&&P.__c(Y,X),X.some(function(q){try{X=q.__h,q.__h=[],X.some(function(K){K.call(q)})}catch(K){P.__e(K,q.__v)}})}function m4(X){return typeof X!="object"||X==null||X.__b>0?X:A0(X)?X.map(m4):X0({},X)}function d5(X,Y,Z,J,q,K,Q,z,G){var L,D,W,O,U,k,_,C=Z.props||w0,M=Y.props,F=Y.type;if(F=="svg"?q="http://www.w3.org/2000/svg":F=="math"?q="http://www.w3.org/1998/Math/MathML":q||(q="http://www.w3.org/1999/xhtml"),K!=null){for(L=0;L<K.length;L++)if((U=K[L])&&"setAttribute"in U==!!F&&(F?U.localName==F:U.nodeType==3)){X=U,K[L]=null;break}}if(X==null){if(F==null)return document.createTextNode(M);X=document.createElementNS(q,F,M.is&&M),z&&(P.__m&&P.__m(Y,K),z=!1),K=null}if(F==null)C===M||z&&X.data==M||(X.data=M);else{if(K=K&&b0.call(X.childNodes),!z&&K!=null)for(C={},L=0;L<X.attributes.length;L++)C[(U=X.attributes[L]).name]=U.value;for(L in C)U=C[L],L=="dangerouslySetInnerHTML"?W=U:L=="children"||(L in M)||L=="value"&&("defaultValue"in M)||L=="checked"&&("defaultChecked"in M)||M0(X,L,null,U,q);for(L in M)U=M[L],L=="children"?O=U:L=="dangerouslySetInnerHTML"?D=U:L=="value"?k=U:L=="checked"?_=U:z&&typeof U!="function"||C[L]===U||M0(X,L,U,C[L],q);if(D)z||W&&(D.__html==W.__html||D.__html==X.innerHTML)||(X.innerHTML=D.__html),Y.__k=[];else if(W&&(X.innerHTML=""),g4(Y.type=="template"?X.content:X,A0(O)?O:[O],Y,Z,J,F=="foreignObject"?"http://www.w3.org/1999/xhtml":q,K,Q,K?K[0]:Z.__k&&L0(Z,0),z,G),K!=null)for(L=K.length;L--;)Q4(K[L]);z||(L="value",F=="progress"&&k==null?X.removeAttribute("value"):k!=null&&(k!==X[L]||F=="progress"&&!k||F=="option"&&k!=C[L])&&M0(X,L,k,C[L],q),L="checked",_!=null&&_!=X[L]&&M0(X,L,_,C[L],q))}return X}function W4(X,Y,Z){try{if(typeof X=="function"){var J=typeof X.__u=="function";J&&X.__u(),J&&Y==null||(X.__u=X(Y))}else X.current=Y}catch(q){P.__e(q,Z)}}function h4(X,Y,Z){var J,q;if(P.unmount&&P.unmount(X),(J=X.ref)&&(J.current&&J.current!=X.__e||W4(J,null,Y)),(J=X.__c)!=null){if(J.componentWillUnmount)try{J.componentWillUnmount()}catch(K){P.__e(K,Y)}J.base=J.__P=null}if(J=X.__k)for(q=0;q<J.length;q++)J[q]&&h4(J[q],Y,Z||typeof X.type!="function");Z||Q4(X.__e),X.__c=X.__=X.__e=void 0}function m5(X,Y,Z){return this.constructor(X,Z)}function p0(X,Y,Z){var J,q,K,Q;Y==document&&(Y=document.documentElement),P.__&&P.__(X,Y),q=(J=typeof Z=="function")?null:Z&&Z.__k||Y.__k,K=[],Q=[],$4(Y,X=(!J&&Z||Y).__k=Y0(x,null,[X]),q||w0,w0,Y.namespaceURI,!J&&Z?[Z]:q?null:Y.firstChild?b0.call(Y.childNodes):null,K,!J&&Z?Z:q?q.__e:Y.firstChild,J,Q),d4(K,X,Q)}function z0(X){function Y(Z){var J,q;return this.getChildContext||(J=new Set,(q={})[Y.__c]=this,this.getChildContext=function(){return q},this.componentWillUnmount=function(){J=null},this.shouldComponentUpdate=function(K){this.props.value!=K.value&&J.forEach(function(Q){Q.__e=!0,J4(Q)})},this.sub=function(K){J.add(K);var Q=K.componentWillUnmount;K.componentWillUnmount=function(){J&&J.delete(K),Q&&Q.call(K)}}),Z.children}return Y.__c="__cC"+R4++,Y.__=X,Y.Provider=Y.__l=(Y.Consumer=function(Z,J){return Z.children(J)}).contextType=Y,Y}b0=S0.slice,P={__e:function(X,Y,Z,J){for(var q,K,Q;Y=Y.__;)if((q=Y.__c)&&!q.__)try{if((K=q.constructor)&&K.getDerivedStateFromError!=null&&(q.setState(K.getDerivedStateFromError(X)),Q=q.__d),q.componentDidCatch!=null&&(q.componentDidCatch(X,J||{}),Q=q.__d),Q)return q.__E=q}catch(z){X=z}throw X}},b4=0,j5=function(X){return X!=null&&X.constructor===void 0},g.prototype.setState=function(X,Y){var Z;Z=this.__s!=null&&this.__s!=this.state?this.__s:this.__s=X0({},this.state),typeof X=="function"&&(X=X(X0({},Z),this.props)),X&&X0(Z,X),X!=null&&this.__v&&(Y&&this._sb.push(Y),J4(this))},g.prototype.forceUpdate=function(X){this.__v&&(this.__e=!0,X&&this.__h.push(X),J4(this))},g.prototype.render=x,K0=[],p4=typeof Promise=="function"?Promise.prototype.then.bind(Promise.resolve()):setTimeout,v4=function(X,Y){return X.__v.__b-Y.__v.__b},T0.__r=0,X4=Math.random().toString(8),C0="__d"+X4,U0="__a"+X4,j4=/(PointerCapture)$|Capture$/i,K4=0,Y4=T4(!1),Z4=T4(!0),R4=0;var N0,T,L4,f4,D0=0,r4=[],b=P,a4=b.__b,c4=b.__r,l4=b.diffed,i4=b.__c,s4=b.unmount,o4=b.__;function j0(X,Y){b.__h&&b.__h(T,X,D0||Y),D0=0;var Z=T.__H||(T.__H={__:[],__h:[]});return X>=Z.__.length&&Z.__.push({}),Z.__[X]}function p(X){return D0=1,N4(n4,X)}function N4(X,Y,Z){var J=j0(N0++,2);if(J.t=X,!J.__c&&(J.__=[Z?Z(Y):n4(void 0,Y),function(z){var G=J.__N?J.__N[0]:J.__[0],L=J.t(G,z);G!==L&&(J.__N=[L,J.__[1]],J.__c.setState({}))}],J.__c=T,!T.__f)){var q=function(z,G,L){if(!J.__c.__H)return!0;var D=J.__c.__H.__.filter(function(O){return O.__c});if(D.every(function(O){return!O.__N}))return!K||K.call(this,z,G,L);var W=J.__c.props!==z;return D.some(function(O){if(O.__N){var U=O.__[0];O.__=O.__N,O.__N=void 0,U!==O.__[0]&&(W=!0)}}),K&&K.call(this,z,G,L)||W};T.__f=!0;var{shouldComponentUpdate:K,componentWillUpdate:Q}=T;T.componentWillUpdate=function(z,G,L){if(this.__e){var D=K;K=void 0,q(z,G,L),K=D}Q&&Q.call(this,z,G,L)},T.shouldComponentUpdate=q}return J.__N||J.__}function d(X,Y){var Z=j0(N0++,3);!b.__s&&t4(Z.__H,Y)&&(Z.__=X,Z.u=Y,T.__H.__h.push(Z))}function w(X){return D0=5,R0(function(){return{current:X}},[])}function R0(X,Y){var Z=j0(N0++,7);return t4(Z.__H,Y)&&(Z.__=X(),Z.__H=Y,Z.__h=X),Z.__}function j(X,Y){return D0=8,R0(function(){return X},Y)}function P0(X){var Y=T.context[X.__c],Z=j0(N0++,9);return Z.c=X,Y?(Z.__==null&&(Z.__=!0,Y.sub(T)),Y.props.value):X.__}function h5(){for(var X;X=r4.shift();){var Y=X.__H;if(X.__P&&Y)try{Y.__h.some(v0),Y.__h.some(z4),Y.__h=[]}catch(Z){Y.__h=[],b.__e(Z,X.__v)}}}b.__b=function(X){T=null,a4&&a4(X)},b.__=function(X,Y){X&&Y.__k&&Y.__k.__m&&(X.__m=Y.__k.__m),o4&&o4(X,Y)},b.__r=function(X){c4&&c4(X),N0=0;var Y=(T=X.__c).__H;Y&&(L4===T?(Y.__h=[],T.__h=[],Y.__.some(function(Z){Z.__N&&(Z.__=Z.__N),Z.u=Z.__N=void 0})):(Y.__h.some(v0),Y.__h.some(z4),Y.__h=[],N0=0)),L4=T},b.diffed=function(X){l4&&l4(X);var Y=X.__c;Y&&Y.__H&&(Y.__H.__h.length&&(r4.push(Y)!==1&&f4===b.requestAnimationFrame||((f4=b.requestAnimationFrame)||f5)(h5)),Y.__H.__.some(function(Z){Z.u&&(Z.__H=Z.u),Z.u=void 0})),L4=T=null},b.__c=function(X,Y){Y.some(function(Z){try{Z.__h.some(v0),Z.__h=Z.__h.filter(function(J){return!J.__||z4(J)})}catch(J){Y.some(function(q){q.__h&&(q.__h=[])}),Y=[],b.__e(J,Z.__v)}}),i4&&i4(X,Y)},b.unmount=function(X){s4&&s4(X);var Y,Z=X.__c;Z&&Z.__H&&(Z.__H.__.some(function(J){try{v0(J)}catch(q){Y=q}}),Z.__H=void 0,Y&&b.__e(Y,Z.__v))};var u4=typeof requestAnimationFrame=="function";function f5(X){var Y,Z=function(){clearTimeout(J),u4&&cancelAnimationFrame(Y),setTimeout(X)},J=setTimeout(Z,35);u4&&(Y=requestAnimationFrame(Z))}function v0(X){var Y=T,Z=X.__c;typeof Z=="function"&&(X.__c=void 0,Z()),T=Y}function z4(X){var Y=T;X.__c=X.__(),T=Y}function t4(X,Y){return!X||X.length!==Y.length||Y.some(function(Z,J){return Z!==X[J]})}function n4(X,Y){return typeof Y=="function"?Y(X):Y}function u5(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function e4(X,Y){for(var Z in X)if(Z!=="__source"&&!(Z in Y))return!0;for(var J in Y)if(J!=="__source"&&X[J]!==Y[J])return!0;return!1}function X5(X,Y){this.props=X,this.context=Y}(X5.prototype=new g).isPureReactComponent=!0,X5.prototype.shouldComponentUpdate=function(X,Y){return e4(this.props,X)||e4(this.state,Y)};var Y5=P.__b;P.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),Y5&&Y5(X)};var r5=P.__e;P.__e=function(X,Y,Z,J){if(X.then){for(var q,K=Y;K=K.__;)if((q=K.__c)&&q.__c)return Y.__e==null&&(Y.__e=Z.__e,Y.__k=Z.__k),q.__c(X,Y)}r5(X,Y,Z,J)};var Z5=P.unmount;function W5(X,Y,Z){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(J){typeof J.__c=="function"&&J.__c()}),X.__c.__H=null),(X=u5({},X)).__c!=null&&(X.__c.__P===Z&&(X.__c.__P=Y),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(J){return W5(J,Y,Z)})),X}function L5(X,Y,Z){return X&&Z&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(J){return L5(J,Y,Z)}),X.__c&&X.__c.__P===Y&&(X.__e&&Z.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=Z)),X}function G4(){this.__u=0,this.o=null,this.__b=null}function z5(X){var Y=X.__&&X.__.__c;return Y&&Y.__a&&Y.__a(X)}function y0(){this.i=null,this.l=null}P.unmount=function(X){var Y=X.__c;Y&&(Y.__z=!0),Y&&Y.__R&&Y.__R(),Y&&32&X.__u&&(X.type=null),Z5&&Z5(X)},(G4.prototype=new g).__c=function(X,Y){var Z=Y.__c,J=this;J.o==null&&(J.o=[]),J.o.push(Z);var q=z5(J.__v),K=!1,Q=function(){K||J.__z||(K=!0,Z.__R=null,q?q(G):G())};Z.__R=Q;var z=Z.__P;Z.__P=null;var G=function(){if(!--J.__u){if(J.state.__a){var L=J.state.__a;J.__v.__k[0]=L5(L,L.__c.__P,L.__c.__O)}var D;for(J.setState({__a:J.__b=null});D=J.o.pop();)D.__P=z,D.forceUpdate()}};J.__u++||32&Y.__u||J.setState({__a:J.__b=J.__v.__k[0]}),X.then(Q,Q)},G4.prototype.componentWillUnmount=function(){this.o=[]},G4.prototype.render=function(X,Y){if(this.__b){if(this.__v.__k){var Z=document.createElement("div"),J=this.__v.__k[0].__c;this.__v.__k[0]=W5(this.__b,Z,J.__O=J.__P)}this.__b=null}var q=Y.__a&&Y0(x,null,X.fallback);return q&&(q.__u&=-33),[Y0(x,null,Y.__a?null:X.children),q]};var J5=function(X,Y,Z){if(++Z[1]===Z[0]&&X.l.delete(Y),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(Z=X.i;Z;){for(;Z.length>3;)Z.pop()();if(Z[1]<Z[0])break;X.i=Z=Z[2]}};(y0.prototype=new g).__a=function(X){var Y=this,Z=z5(Y.__v),J=Y.l.get(X);return J[0]++,function(q){var K=function(){Y.props.revealOrder?(J.push(q),J5(Y,X,J)):q()};Z?Z(K):K()}},y0.prototype.render=function(X){this.i=null,this.l=new Map;var Y=Z0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Y.reverse();for(var Z=Y.length;Z--;)this.l.set(Y[Z],this.i=[1,0,this.i]);return X.children},y0.prototype.componentDidUpdate=y0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Y,Z){J5(X,Z,Y)})};var t5=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,n5=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,e5=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,X6=/[A-Z0-9]/g,Y6=typeof document<"u",Z6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};function N5(X,Y,Z){return Y.__k==null&&(Y.textContent=""),p0(X,Y),typeof Z=="function"&&Z(),X?X.__c:null}g.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(g.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Y){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Y})}})});var q5=P.event;P.event=function(X){return q5&&(X=q5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var G5,J6={configurable:!0,get:function(){return this.class}},K5=P.vnode;P.vnode=function(X){typeof X.type=="string"&&function(Y){var{props:Z,type:J}=Y,q={},K=J.indexOf("-")==-1;for(var Q in Z){var z=Z[Q];if(!(Q==="value"&&("defaultValue"in Z)&&z==null||Y6&&Q==="children"&&J==="noscript"||Q==="class"||Q==="className")){var G=Q.toLowerCase();Q==="defaultValue"&&"value"in Z&&Z.value==null?Q="value":Q==="download"&&z===!0?z="":G==="translate"&&z==="no"?z=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?Q="ondblclick":G!=="onchange"||J!=="input"&&J!=="textarea"||Z6(Z.type)?G==="onfocus"?Q="onfocusin":G==="onblur"?Q="onfocusout":e5.test(Q)&&(Q=G):G=Q="oninput":K&&n5.test(Q)?Q=Q.replace(X6,"-$&").toLowerCase():z===null&&(z=void 0),G==="oninput"&&q[Q=G]&&(Q="oninputCapture"),q[Q]=z}}J=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.value.indexOf(L.props.value)!=-1})),q.defaultValue!=null&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.multiple?q.defaultValue.indexOf(L.props.value)!=-1:q.defaultValue==L.props.value}))),Z.class&&!Z.className?(q.class=Z.class,Object.defineProperty(q,"className",J6)):Z.className&&(q.class=q.className=Z.className),Y.props=q}(X),X.$$typeof=t5,K5&&K5(X)};var Q5=P.__r;P.__r=function(X){Q5&&Q5(X),G5=X.__c};var $5=P.diffed;P.diffed=function(X){$5&&$5(X);var{props:Y,__e:Z}=X;Z!=null&&X.type==="textarea"&&"value"in Y&&Y.value!==Z.value&&(Z.value=Y.value==null?"":Y.value),G5=null};function V5(X){return!!X.__k&&(p0(null,X),!0)}function H5(X){return{render:function(Y){N5(Y,X)},unmount:function(){V5(X)}}}function I5(X,Y){for(var Z in Y)X[Z]=Y[Z];return X}function O5(X,Y){for(var Z in X)if(Z!=="__source"&&!(Z in Y))return!0;for(var J in Y)if(J!=="__source"&&X[J]!==Y[J])return!0;return!1}function U5(X,Y){this.props=X,this.context=Y}(U5.prototype=new g).isPureReactComponent=!0,U5.prototype.shouldComponentUpdate=function(X,Y){return O5(this.props,X)||O5(this.state,Y)};var A5=P.__b;P.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),A5&&A5(X)};var q6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.forward_ref")||3911;function G0(X){function Y(Z){var J=I5({},Z);return delete J.ref,X(J,Z.ref||null)}return Y.$$typeof=q6,Y.render=X,Y.prototype.isReactComponent=Y.__f=!0,Y.displayName="ForwardRef("+(X.displayName||X.name)+")",Y}var K6=P.__e;P.__e=function(X,Y,Z,J){if(X.then){for(var q,K=Y;K=K.__;)if((q=K.__c)&&q.__c)return Y.__e==null&&(Y.__e=Z.__e,Y.__k=Z.__k),q.__c(X,Y)}K6(X,Y,Z,J)};var D5=P.unmount;function M5(X,Y,Z){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(J){typeof J.__c=="function"&&J.__c()}),X.__c.__H=null),(X=I5({},X)).__c!=null&&(X.__c.__P===Z&&(X.__c.__P=Y),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(J){return M5(J,Y,Z)})),X}function C5(X,Y,Z){return X&&Z&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(J){return C5(J,Y,Z)}),X.__c&&X.__c.__P===Y&&(X.__e&&Z.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=Z)),X}function H4(){this.__u=0,this.o=null,this.__b=null}function E5(X){var Y=X.__&&X.__.__c;return Y&&Y.__a&&Y.__a(X)}function g0(){this.i=null,this.l=null}P.unmount=function(X){var Y=X.__c;Y&&(Y.__z=!0),Y&&Y.__R&&Y.__R(),Y&&32&X.__u&&(X.type=null),D5&&D5(X)},(H4.prototype=new g).__c=function(X,Y){var Z=Y.__c,J=this;J.o==null&&(J.o=[]),J.o.push(Z);var q=E5(J.__v),K=!1,Q=function(){K||J.__z||(K=!0,Z.__R=null,q?q(G):G())};Z.__R=Q;var z=Z.__P;Z.__P=null;var G=function(){if(!--J.__u){if(J.state.__a){var L=J.state.__a;J.__v.__k[0]=C5(L,L.__c.__P,L.__c.__O)}var D;for(J.setState({__a:J.__b=null});D=J.o.pop();)D.__P=z,D.forceUpdate()}};J.__u++||32&Y.__u||J.setState({__a:J.__b=J.__v.__k[0]}),X.then(Q,Q)},H4.prototype.componentWillUnmount=function(){this.o=[]},H4.prototype.render=function(X,Y){if(this.__b){if(this.__v.__k){var Z=document.createElement("div"),J=this.__v.__k[0].__c;this.__v.__k[0]=M5(this.__b,Z,J.__O=J.__P)}this.__b=null}var q=Y.__a&&Y0(x,null,X.fallback);return q&&(q.__u&=-33),[Y0(x,null,Y.__a?null:X.children),q]};var P5=function(X,Y,Z){if(++Z[1]===Z[0]&&X.l.delete(Y),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(Z=X.i;Z;){for(;Z.length>3;)Z.pop()();if(Z[1]<Z[0])break;X.i=Z=Z[2]}};(g0.prototype=new g).__a=function(X){var Y=this,Z=E5(Y.__v),J=Y.l.get(X);return J[0]++,function(q){var K=function(){Y.props.revealOrder?(J.push(q),P5(Y,X,J)):q()};Z?Z(K):K()}},g0.prototype.render=function(X){this.i=null,this.l=new Map;var Y=Z0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Y.reverse();for(var Z=Y.length;Z--;)this.l.set(Y[Z],this.i=[1,0,this.i]);return X.children},g0.prototype.componentDidUpdate=g0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Y,Z){P5(X,Z,Y)})};var Q6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,$6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,W6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,L6=/[A-Z0-9]/g,z6=typeof document<"u",N6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};g.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(g.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Y){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Y})}})});var B5=P.event;P.event=function(X){return B5&&(X=B5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var w5,G6={configurable:!0,get:function(){return this.class}},_5=P.vnode;P.vnode=function(X){typeof X.type=="string"&&function(Y){var{props:Z,type:J}=Y,q={},K=J.indexOf("-")==-1;for(var Q in Z){var z=Z[Q];if(!(Q==="value"&&("defaultValue"in Z)&&z==null||z6&&Q==="children"&&J==="noscript"||Q==="class"||Q==="className")){var G=Q.toLowerCase();Q==="defaultValue"&&"value"in Z&&Z.value==null?Q="value":Q==="download"&&z===!0?z="":G==="translate"&&z==="no"?z=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?Q="ondblclick":G!=="onchange"||J!=="input"&&J!=="textarea"||N6(Z.type)?G==="onfocus"?Q="onfocusin":G==="onblur"?Q="onfocusout":W6.test(Q)&&(Q=G):G=Q="oninput":K&&$6.test(Q)?Q=Q.replace(L6,"-$&").toLowerCase():z===null&&(z=void 0),G==="oninput"&&q[Q=G]&&(Q="oninputCapture"),q[Q]=z}}J=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.value.indexOf(L.props.value)!=-1})),q.defaultValue!=null&&(q.value=Z0(Z.children).forEach(function(L){L.props.selected=q.multiple?q.defaultValue.indexOf(L.props.value)!=-1:q.defaultValue==L.props.value}))),Z.class&&!Z.className?(q.class=Z.class,Object.defineProperty(q,"className",G6)):Z.className&&(q.class=q.className=Z.className),Y.props=q}(X),X.$$typeof=Q6,_5&&_5(X)};var F5=P.__r;P.__r=function(X){F5&&F5(X),w5=X.__c};var k5=P.diffed;P.diffed=function(X){k5&&k5(X);var{props:Y,__e:Z}=X;Z!=null&&X.type==="textarea"&&"value"in Y&&Y.value!==Z.value&&(Z.value=Y.value==null?"":Y.value),w5=null};var V6=0;function $(X,Y,Z,J,q,K){Y||(Y={});var Q,z,G=Y;if("ref"in G)for(z in G={},Y)z=="ref"?Q=Y[z]:G[z]=Y[z];var L={type:X,props:G,key:Z,ref:Q,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--V6,__i:-1,__u:0,__source:q,__self:K};if(typeof X=="function"&&(Q=X.defaultProps))for(z in Q)G[z]===void 0&&(G[z]=Q[z]);return P.vnode&&P.vnode(L),L}var O4=`url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle cx='10' cy='10' r='9' fill='rgba(255,255,255,0.4)' stroke='rgba(255,255,255,0.7)' stroke-width='1'/%3E%3C/svg%3E") 10 10, pointer`,H6=3,O6=4,U6=5;function x0({url:X,wsUrl:Y,style:Z,imageStyle:J,className:q,onHomePress:K,onStreamTouch:Q,onStreamMultiTouch:z,onStreamButton:G,subscribeFrame:L,streamFrame:D,streamConfig:W,hideControls:O,onStreamingChange:U,connectionQuality:k}){let _=!!Q,C=w(null),M=w(null),F=w(null),[E,I]=p(!1),[v,r]=p(null),[f,i]=p(null),y=w(null),[m,c0]=p(null);d(()=>{let V=y.current;if(!V||typeof ResizeObserver>"u")return;let H=new ResizeObserver((N)=>{let A=N[0]?.contentRect;if(A)c0({width:A.width,height:A.height})});return H.observe(V),()=>H.disconnect()},[]);let[D4,P4]=p(0),W0=w(0),[p5,l0]=p(!1),t=w(null);d(()=>{if(k==="poor"){if(l0(!0),t.current)clearTimeout(t.current);t.current=setTimeout(()=>{l0(!1),t.current=null},3000)}else if(l0(!1),t.current)clearTimeout(t.current),t.current=null;return()=>{if(t.current)clearTimeout(t.current)}},[k]);let i0=`${X}/stream.mjpeg`,B4=w(U);B4.current=U,d(()=>{B4.current?.(E)},[E]),d(()=>{if(_&&W)i(W)},[_,W]);let _4=w(!1);_4.current=E;let s0=w(null);d(()=>{if(!_||!L)return;return L((V)=>{W0.current++;let H=M.current;if(H){if(s0.current)URL.revokeObjectURL(s0.current);s0.current=V,H.src=V}if(!_4.current)console.log("[serve-sim] first frame received, rendering"),I(!0),r(null)})},[_,L]);let c=j((V)=>{if(_){Q?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify(V)),A=new Uint8Array(1+N.length);A[0]=H6,A.set(N,1),H.send(A)},[_,Q]),o0=j((V)=>{if(_){G?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify({button:V})),A=new Uint8Array(1+N.length);A[0]=O6,A.set(N,1),H.send(A)},[_,G]),n=j((V)=>{if(_){z?.(V);return}let H=F.current;if(!H||H.readyState!==WebSocket.OPEN)return;let N=new TextEncoder().encode(JSON.stringify(V)),A=new Uint8Array(1+N.length);A[0]=U6,A.set(N,1),H.send(A)},[_,z]);d(()=>{if(_)return;fetch(`${X}/config`).then((B)=>B.json()).then((B)=>{if(B.width>0&&B.height>0)i(B)}).catch(()=>{});let V=Y??X.replace(/^http/,"ws")+"/ws",H=new WebSocket(V);H.binaryType="arraybuffer",F.current=H,H.onopen=()=>{I(!0),r(null)},H.onclose=()=>{I(!1)},H.onerror=()=>{r("WebSocket connection failed"),I(!1)};let N=new AbortController,A=setInterval(()=>{P4(W0.current),W0.current=0},1000);return(async()=>{try{let S=(await fetch(i0,{signal:N.signal})).body?.getReader();if(!S)return;let h=new TextEncoder().encode("--frame");while(!0){let{done:l,value:u}=await S.read();if(l)break;if(u)for(let e0=0;e0<=u.length-h.length;e0++){let E4=!0;for(let I0=0;I0<h.length;I0++)if(u[e0+I0]!==h[I0]){E4=!1;break}if(E4)W0.current++}}}catch{}})(),()=>{N.abort(),clearInterval(A),H.close(),F.current=null}},[X,i0,_]),d(()=>{if(!_)return;let V=setInterval(()=>{P4(W0.current),W0.current=0},1000);return()=>clearInterval(V)},[_]);let e=j(()=>{return _?M.current:C.current},[_]),B0=j((V,H)=>{let N=e();if(!N)return;let A=N.getBoundingClientRect(),B=(H.clientX-A.left)/A.width,S=(H.clientY-A.top)/A.height;c({type:V,x:B,y:S})},[c]),Q0=3,a=w(!1),o=w(!1),u0=w(!1),r0=w({dx:0,dy:0}),V0=w(!1),[t0,F4]=p(!1),k4=w({x:0.5,y:0.5}),[q0,s]=p(null);d(()=>{let V=(N)=>{if(N.key==="Alt")F4(!0)},H=(N)=>{if(N.key==="Alt"){if(F4(!1),!o.current)s(null)}};return window.addEventListener("keydown",V),window.addEventListener("keyup",H),()=>{window.removeEventListener("keydown",V),window.removeEventListener("keyup",H)}},[]),d(()=>{if(t0&&!o.current){let V=k4.current;s({x1:V.x,y1:V.y,x2:1-V.x,y2:1-V.y})}else if(!t0&&!o.current)s(null)},[t0]);let _0=w(null),n0=w(!1),H0=w(0),I4=j((V,H)=>{n0.current=!0;let N=_0.current;if(N)cancelAnimationFrame(H0.current),H0.current=requestAnimationFrame(()=>{N.style.left=`${V*100}%`,N.style.top=`${H*100}%`,N.style.display="block"})},[]),M4=j((V,H)=>{if(!n0.current)return;let N=_0.current;if(N)cancelAnimationFrame(H0.current),H0.current=requestAnimationFrame(()=>{N.style.left=`${V*100}%`,N.style.top=`${H*100}%`})},[]),F0=j(()=>{n0.current=!1;let V=_0.current;if(V)cancelAnimationFrame(H0.current),V.style.display="none"},[]),C4=w(0),O0=w(null),v5=j(()=>{let V=Date.now(),H=V-C4.current;if(C4.current=V,H<300){if(O0.current)clearTimeout(O0.current),O0.current=null;if(K)K();else o0("app_switcher")}else O0.current=setTimeout(()=>{if(K)K();else o0("home");O0.current=null},300)},[o0,K]),k0=(()=>{if(!f||!m)return null;if(m.width===0||m.height===0)return null;let V=Math.min(m.width/f.width,m.height/f.height);return{width:f.width*V,height:f.height*V}})();return $("div",{style:{display:"flex",flexDirection:"column",flex:1,...O?{}:{border:"1px solid rgba(255,255,255,0.12)"},overflow:"hidden",minWidth:0,minHeight:0,...Z},className:q,children:[$("div",{ref:y,style:{position:"relative",flex:1,minHeight:0,minWidth:0,display:"flex",alignItems:"center",justifyContent:"center"},children:$("div",{style:{position:"relative",width:k0?`${k0.width}px`:"100%",height:k0?`${k0.height}px`:"100%"},children:[$("img",{ref:C,src:_?void 0:i0,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)i((N)=>N&&N.width===H.naturalWidth&&N.height===H.naturalHeight?N:{width:H.naturalWidth,height:H.naturalHeight})},style:_?{display:"none"}:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:O4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...J}}),_&&$("img",{ref:M,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)i((N)=>N&&N.width===H.naturalWidth&&N.height===H.naturalHeight?N:{width:H.naturalWidth,height:H.naturalHeight})},style:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:O4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...J}}),$("div",{style:{position:"absolute",inset:0,cursor:O4,touchAction:"none"},onMouseDown:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(V.altKey){o.current=!0,u0.current=V.shiftKey;let S={x1:A,y1:B,x2:1-A,y2:1-B};r0.current={dx:1-A-A,dy:1-B-B},s(S),n({type:"begin",...S});return}if(I4(A,B),B>0.88)a.current=!0,c({type:"begin",x:A,y:B,edge:Q0});else a.current=!1,B0("begin",V)},onMouseMove:(V)=>{let H=e();if(!H)return;let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(k4.current={x:A,y:B},V.buttons===0){if(V.altKey)s({x1:A,y1:B,x2:1-A,y2:1-B});return}if(o.current){let S;if(u0.current){let h=r0.current;S={x1:A,y1:B,x2:A+h.dx,y2:B+h.dy}}else S={x1:A,y1:B,x2:1-A,y2:1-B};s(S),n({type:"move",...S});return}if(M4(A,B),a.current)c({type:"move",x:A,y:B,edge:Q0});else B0("move",V)},onMouseUp:(V)=>{if(o.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;if(u0.current){let S=r0.current;n({type:"end",x1:A,y1:B,x2:A+S.dx,y2:B+S.dy})}else n({type:"end",x1:A,y1:B,x2:1-A,y2:1-B})}if(o.current=!1,!V.altKey)s(null);return}if(F0(),a.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;c({type:"end",x:A,y:B,edge:Q0})}a.current=!1;return}B0("end",V)},onMouseLeave:(V)=>{if(o.current){if(q0)n({type:"end",...q0});o.current=!1,s(null);return}if(F0(),a.current){let H=e();if(H){let N=H.getBoundingClientRect(),A=(V.clientX-N.left)/N.width,B=(V.clientY-N.top)/N.height;c({type:"end",x:A,y:B,edge:Q0})}a.current=!1;return}if(V.buttons>0)B0("end",V);s(null)},onTouchStart:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V.touches.length>=2){F0();let h=V.touches[0],l=V.touches[1],u={x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:(l.clientX-N.left)/N.width,y2:(l.clientY-N.top)/N.height};if(!V0.current&&!a.current)c({type:"end",x:u.x1,y:u.y1});V0.current=!0,o.current=!0,a.current=!1,s(u),n({type:"begin",...u});return}let A=V.touches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(I4(B,S),S>0.88)a.current=!0,c({type:"begin",x:B,y:S,edge:Q0});else a.current=!1,c({type:"begin",x:B,y:S})},onTouchMove:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V0.current&&V.touches.length>=2){let h=V.touches[0],l=V.touches[1],u={x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:(l.clientX-N.left)/N.width,y2:(l.clientY-N.top)/N.height};s(u),n({type:"move",...u});return}let A=V.touches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(M4(B,S),a.current)c({type:"move",x:B,y:S,edge:Q0});else c({type:"move",x:B,y:S})},onTouchEnd:(V)=>{V.preventDefault();let H=e();if(!H)return;let N=H.getBoundingClientRect();if(V0.current){if(V.touches.length<2){let h=V.changedTouches[0],l=q0;if(h&&l)n({type:"end",x1:(h.clientX-N.left)/N.width,y1:(h.clientY-N.top)/N.height,x2:l.x2,y2:l.y2});else if(l)n({type:"end",...l});V0.current=!1,o.current=!1,s(null)}return}let A=V.changedTouches[0];if(!A)return;let B=(A.clientX-N.left)/N.width,S=(A.clientY-N.top)/N.height;if(F0(),a.current)c({type:"end",x:B,y:S,edge:Q0}),a.current=!1;else c({type:"end",x:B,y:S})}}),$("div",{ref:_0,"data-testid":"touch-indicator",style:{position:"absolute",display:"none",width:24,height:24,borderRadius:"50%",background:"rgba(59,130,246,0.5)",boxShadow:"0 0 8px rgba(59,130,246,0.3)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}),q0&&$(x,{children:[$("div",{"data-testid":"finger-dot",style:b5(q0.x1,q0.y1)}),$("div",{"data-testid":"finger-dot",style:b5(q0.x2,q0.y2)})]}),!E&&!v&&$("div",{style:S5,children:$("span",{style:{color:"#888",fontSize:14},children:"Connecting..."})}),v&&$("div",{style:S5,children:$("span",{style:{color:"#f44",fontSize:14,padding:20,textAlign:"center"},children:v})}),p5&&$("div",{style:A6,children:$("span",{style:{color:"#fbbf24",fontSize:13,fontFamily:"monospace"},children:"Slow connection"})})]})}),!O&&$("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 8px",borderTop:"1px solid rgba(255,255,255,0.12)"},children:[$("button",{onClick:v5,style:{background:"none",border:"1px solid rgba(255,255,255,0.2)",color:"#aaa",fontSize:11,fontFamily:"monospace",padding:"2px 10px",cursor:"pointer",borderRadius:4},children:"Home"}),$("span",{style:{color:D4>0?"#4f4":"#888",fontSize:12,fontFamily:"monospace",display:"flex",alignItems:"center",gap:6},children:[k&&$("span",{"data-testid":"quality-dot",style:{width:8,height:8,borderRadius:"50%",display:"inline-block",background:k==="good"?"#4ade80":k==="degraded"?"#facc15":"#ef4444"}}),D4," fps"]})]})]})}var A6={position:"absolute",top:8,left:"50%",transform:"translateX(-50%)",background:"rgba(0,0,0,0.7)",borderRadius:6,padding:"4px 12px",pointerEvents:"none"},S5={position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.8)"},T5=20;function b5(X,Y){return{position:"absolute",left:`${X*100}%`,top:`${Y*100}%`,width:T5,height:T5,borderRadius:"50%",background:"rgba(255,255,255,0.4)",border:"1px solid rgba(255,255,255,0.7)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}function d0(X){if(!X)return"iphone";let Y=X.toLowerCase();if(Y.includes("ipad"))return"ipad";if(Y.includes("watch"))return"watch";if(Y.includes("vision"))return"vision";return"iphone"}var R={iphone:{width:427,height:881,bezelX:18,bezelY:18,innerRadius:55},ipad:{width:430,height:605,bezelX:16,bezelY:16,innerRadius:12},watch:{width:274,height:322,bezelX:12,bezelY:12,innerRadius:79},vision:{width:640,height:400,bezelX:12,bezelY:12,innerRadius:32}},U7=R.iphone.width,A7=R.iphone.height,D7=R.iphone.bezelX,P7=R.iphone.bezelY,B7=R.iphone.innerRadius;function U4(X="iphone"){let Y=R[X];return{top:`${Y.bezelY/Y.height*100}%`,left:`${Y.bezelX/Y.width*100}%`,right:`${Y.bezelX/Y.width*100}%`,bottom:`${Y.bezelY/Y.height*100}%`}}function m0(X="iphone"){let Y=R[X],Z=Y.width-2*Y.bezelX,J=Y.height-2*Y.bezelY;return`${Y.innerRadius/Z*100}% / ${Y.innerRadius/J*100}%`}function h0({type:X="iphone",streaming:Y=!1}){switch(X){case"ipad":return $(B6,{streaming:Y});case"watch":return $(_6,{streaming:Y});case"vision":return $(F6,{streaming:Y});default:return $(P6,{streaming:Y})}}function P6({streaming:X=!1}){return $("svg",{viewBox:"0 0 427 881",style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"chrome-filter0",x:"-0.166992",y:"0.166504",width:"427",height:"880.667",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"effect1_foregroundBlur"})]}),$("filter",{id:"chrome-filter1",x:"6.33236",y:"6.33382",width:"414",height:"868",filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333333",result:"effect1_foregroundBlur"})]})]}),$("rect",{x:"3.83268",y:"3.83366",width:"419",height:"873",rx:"66.1667",stroke:"#454548",strokeWidth:"4.33333"}),$("rect",{x:"0.833333",y:"0.833333",width:"425",height:"879",rx:"69.1667",stroke:"#37373a",strokeWidth:"1.66667"}),$("g",{opacity:"0.9",filter:"url(#chrome-filter0)",children:$("rect",{x:"1.66602",y:"2",width:"423.333",height:"877",rx:"68.6667",stroke:"#454548",strokeWidth:"1.66667"})}),$("g",{opacity:"0.8",filter:"url(#chrome-filter1)",children:$("rect",{x:"7.33268",y:"7.33366",width:"412",height:"866",rx:"62.6667",stroke:"#646464",strokeWidth:"0.666667"})}),$("rect",{x:"151.666",y:"31.667",width:"123.333",height:"36",rx:"18",fill:"black",style:{opacity:X?0:1,transition:"opacity 0.3s ease"}})]})}function B6({streaming:X=!1}){let Y=R.ipad.width,Z=R.ipad.height,J=30,q=26;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"ipad-glow0",x:"0",y:"0",width:Y,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]}),$("filter",{id:"ipad-glow1",x:"5",y:"5",width:Y-10,height:Z-10,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333333",result:"blur"})]})]}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:26,stroke:"#454548",strokeWidth:"4"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:30,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#ipad-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:29,stroke:"#454548",strokeWidth:"1.666"})}),$("g",{opacity:"0.8",filter:"url(#ipad-glow1)",children:$("rect",{x:"6",y:"6",width:Y-12,height:Z-12,rx:24,stroke:"#646464",strokeWidth:"0.666"})}),$("circle",{cx:Y/2,cy:R.ipad.bezelY/2+1,r:"3",fill:"#1a1a1a",style:{opacity:X?0:0.8,transition:"opacity 0.3s ease"}}),$("rect",{x:(Y-120)/2,y:Z-R.ipad.bezelY/2-2.5,width:"120",height:"5",rx:"2.5",fill:"white",style:{opacity:X?0:0.35,mixBlendMode:"difference",transition:"opacity 0.3s ease"}})]})}function _6({streaming:X=!1}){let Y=R.watch.width,Z=R.watch.height,J=88,q=82,K=8,Q=36,z=Z/2-18-16,G=22,L=Z/2-11+16;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%",overflow:"visible"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:$("filter",{id:"watch-glow0",x:"0",y:"0",width:Y+12,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]})}),$("rect",{x:Y-2,y:z,width:8,height:36,rx:"3",fill:"#2a2a2c",stroke:"#454548",strokeWidth:"1"}),$("rect",{x:Y-1,y:L,width:6,height:22,rx:"2.5",fill:"#2a2a2c",stroke:"#454548",strokeWidth:"0.8"}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:82,stroke:"#454548",strokeWidth:"3.5"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:88,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#watch-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:87,stroke:"#454548",strokeWidth:"1.666"})})]})}function F6({streaming:X=!1}){let Y=R.vision.width,Z=R.vision.height,J=40,q=34;return $("svg",{viewBox:`0 0 ${Y} ${Z}`,style:{width:"100%",height:"100%"},fill:"none",xmlns:"http://www.w3.org/2000/svg",children:[$("defs",{children:[$("filter",{id:"vision-glow0",x:"0",y:"0",width:Y,height:Z,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.5",result:"blur"})]}),$("filter",{id:"vision-glow1",x:"5",y:"5",width:Y-10,height:Z-10,filterUnits:"userSpaceOnUse",colorInterpolationFilters:"sRGB",children:[$("feFlood",{floodOpacity:"0",result:"BackgroundImageFix"}),$("feBlend",{mode:"normal",in:"SourceGraphic",in2:"BackgroundImageFix",result:"shape"}),$("feGaussianBlur",{stdDeviation:"0.333",result:"blur"})]}),$("linearGradient",{id:"vision-glass",x1:"0",y1:"0",x2:"0",y2:"1",children:[$("stop",{offset:"0%",stopColor:"#555558",stopOpacity:"0.3"}),$("stop",{offset:"100%",stopColor:"#3a3a3d",stopOpacity:"0.1"})]})]}),$("rect",{x:"0",y:"0",width:Y,height:Z,rx:40,fill:"url(#vision-glass)"}),$("rect",{x:"3.5",y:"3.5",width:Y-7,height:Z-7,rx:34,stroke:"#454548",strokeWidth:"3"}),$("rect",{x:"0.833",y:"0.833",width:Y-1.666,height:Z-1.666,rx:40,stroke:"#37373a",strokeWidth:"1.666"}),$("g",{opacity:"0.9",filter:"url(#vision-glow0)",children:$("rect",{x:"1.5",y:"1.5",width:Y-3,height:Z-3,rx:39,stroke:"#454548",strokeWidth:"1.666"})}),$("g",{opacity:"0.8",filter:"url(#vision-glow1)",children:$("rect",{x:"6",y:"6",width:Y-12,height:Z-12,rx:32,stroke:"#646464",strokeWidth:"0.666"})}),$("ellipse",{cx:Y/2,cy:Z/2,rx:Y/2-30,ry:Z/2-24,stroke:"#4a4a4d",strokeWidth:"0.5",opacity:"0.3",style:{opacity:X?0:0.3,transition:"opacity 0.3s ease"}})]})}var A4=z0(null);function f0(X){let Y=P0(A4);if(!Y)throw Error(`<SimulatorToolbar.${X}> must be rendered inside <SimulatorToolbar>`);return Y}var M6={display:"flex",flexWrap:"wrap",alignItems:"center",justifyContent:"space-between",gap:"4px 12px",padding:"8px 12px",borderRadius:24,background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.1)",boxShadow:"0 1px 2px rgba(0,0,0,0.2)",minWidth:240,width:"100%"};function C6({exec:X,deviceUdid:Y,deviceName:Z,deviceRuntime:J,streaming:q=!1,disabled:K=!1,children:Q,style:z,...G}){let L=d0(Z),W={exec:X,deviceUdid:Y,deviceName:Z,deviceRuntime:J,deviceType:L,streaming:q,disabled:K||!Y||!q};return $(A4.Provider,{value:W,children:$("div",{"data-simulator-toolbar":!0,style:{...M6,...z},...G,children:Q})})}var E6={display:"flex",flexDirection:"column",alignItems:"flex-start",textAlign:"left",background:"transparent",border:"none",color:"#fff",padding:"2px 4px",margin:"-2px -4px",borderRadius:6,cursor:"pointer",minWidth:0,maxWidth:"100%",lineHeight:1.2,fontFamily:"inherit"},w6=G0(function({name:Y,subtitle:Z,hideChevron:J,style:q,onMouseEnter:K,onMouseLeave:Q,...z},G){let L=f0("Title"),[D,W]=p(!1),O=Y??L.deviceName??"No simulator",U=Z??(L.deviceRuntime?L.deviceRuntime.replace(/\./," "):"—");return $("button",{ref:G,type:"button","data-simulator-toolbar-title":!0,onMouseEnter:(k)=>{W(!0),K?.(k)},onMouseLeave:(k)=>{W(!1),Q?.(k)},style:{...E6,background:D?"rgba(255,255,255,0.1)":"transparent",...q},...z,children:[$("span",{style:{display:"inline-flex",alignItems:"center",gap:4,fontSize:12,fontWeight:600,color:"#fff",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:[O,!J&&$("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"rgba(255,255,255,0.6)",flexShrink:0},children:$("polyline",{points:"6 9 12 15 18 9"})})]}),$("span",{style:{fontSize:10,color:"rgba(255,255,255,0.5)",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:U})]})}),S6={display:"flex",alignItems:"center",gap:4,flexShrink:0};function T6({style:X,...Y}){return $("div",{style:{...S6,...X},...Y})}var b6={background:"transparent",border:"none",padding:6,borderRadius:6,cursor:"pointer",display:"inline-flex",alignItems:"center",justifyContent:"center",color:"rgba(255,255,255,0.8)",transition:"background-color 0.15s, color 0.15s"},a0=G0(function({forceDisabled:Y,style:Z,disabled:J,onMouseEnter:q,onMouseLeave:K,children:Q,...z},G){let L=P0(A4),D=J||Y||L?.disabled,[W,O]=p(!1);return $("button",{ref:G,type:"button",disabled:D,onMouseEnter:(U)=>{O(!0),q?.(U)},onMouseLeave:(U)=>{O(!1),K?.(U)},style:{...b6,color:D?"rgba(255,255,255,0.25)":"rgba(255,255,255,0.8)",background:W&&!D?"rgba(255,255,255,0.1)":"transparent",cursor:D?"not-allowed":"pointer",...Z},...z,children:Q})});function p6(){return['tell application "System Events" to tell process "Simulator" to set frontmost to true','tell application "System Events" to tell process "Simulator" to perform action "AXRaise" of (first window whose name contains "watchOS")','tell application "System Events" to tell process "Simulator" to click menu item "Home" of menu "Device" of menu bar item "Device" of menu bar 1'].map((Y)=>`-e '${Y}'`).reduce((Y,Z)=>`${Y} ${Z}`,"osascript")}var v6=$("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:$("path",{d:"M3 10.5 12 3l9 7.5V20a1 1 0 0 1-1 1h-5v-7h-6v7H4a1 1 0 0 1-1-1z"})}),j6=$("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[$("path",{d:"M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3z"}),$("circle",{cx:"12",cy:"13",r:"4"})]}),R6=$("svg",{width:"18",height:"18",viewBox:"0 0 12 13",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",children:$("path",{d:"M10.2305 12.8077H4.42383C3.92383 12.8077 3.54688 12.6846 3.29297 12.4385C3.04297 12.1963 2.91797 11.8194 2.91797 11.3077V5.51274C2.91797 4.99711 3.04297 4.61821 3.29297 4.37602C3.54688 4.12993 3.92383 4.00688 4.42383 4.00688H10.2305C10.7344 4.00688 11.1113 4.12993 11.3613 4.37602C11.6113 4.61821 11.7363 4.99711 11.7363 5.51274V11.3077C11.7363 11.8194 11.6113 12.1963 11.3613 12.4385C11.1113 12.6846 10.7344 12.8077 10.2305 12.8077ZM10.2129 11.8643C10.416 11.8643 10.5625 11.8194 10.6523 11.7295C10.7461 11.6436 10.793 11.4971 10.793 11.2901V5.52446C10.793 5.31743 10.7461 5.17094 10.6523 5.08501C10.5625 4.99516 10.416 4.95024 10.2129 4.95024H4.44141C4.24219 4.95024 4.0957 4.99516 4.00195 5.08501C3.9082 5.17094 3.86133 5.31743 3.86133 5.52446V11.2901C3.86133 11.4971 3.9082 11.6436 4.00195 11.7295C4.0957 11.8194 4.24219 11.8643 4.44141 11.8643H10.2129ZM2.91797 2.58305V0.415083C2.91797 0.20024 2.98633 0.0693803 3.12305 0.0225053C3.25977 -0.0282759 3.41016 0.00688033 3.57422 0.127974L5.05078 1.21196C5.17578 1.30571 5.23828 1.40141 5.23828 1.49907C5.23828 1.59672 5.17578 1.69243 5.05078 1.78618L3.57422 2.8643C3.41016 2.9854 3.25977 3.02251 3.12305 2.97563C2.98633 2.92485 2.91797 2.79399 2.91797 2.58305ZM3.5332 1.15336C3.62695 1.15336 3.70703 1.18657 3.77344 1.25297C3.84375 1.31938 3.87891 1.39751 3.87891 1.48735C3.87891 1.5811 3.84375 1.66313 3.77344 1.73344C3.70703 1.79985 3.62695 1.83305 3.5332 1.83305H2.80664C2.38086 1.83305 2.01172 1.92485 1.69922 2.10844C1.39062 2.28813 1.15234 2.53813 0.984375 2.85844C0.816406 3.17876 0.732422 3.54594 0.732422 3.96001V4.83891C0.732422 4.93657 0.697266 5.02251 0.626953 5.09672C0.552734 5.16704 0.464844 5.20219 0.363281 5.20219C0.265625 5.20219 0.181641 5.16704 0.111328 5.09672C0.0371094 5.02251 0 4.93657 0 4.83891V3.96001C0 3.40141 0.117188 2.91118 0.351562 2.4893C0.582031 2.06743 0.908203 1.7393 1.33008 1.50493C1.74805 1.27055 2.23828 1.15336 2.80078 1.15336H3.5332Z"})}),y6=G0(function({onClick:Y,...Z},J){let q=f0("HomeButton");return $(a0,{ref:J,"aria-label":"Home",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceType==="watch")q.exec(p6());else q.exec("serve-sim button home")},...Z,children:v6})}),g6=G0(function({onClick:Y,...Z},J){let q=f0("ScreenshotButton");return $(a0,{ref:J,"aria-label":"Screenshot",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceUdid)q.exec(`xcrun simctl io ${q.deviceUdid} screenshot ~/Desktop/hatch-screenshot-$(date +%s).png`)},...Z,children:j6})}),x6=G0(function({onClick:Y,...Z},J){let q=f0("RotateButton");return $(a0,{ref:J,"aria-label":"Rotate device",onClick:(K)=>{if(Y?.(K),K.defaultPrevented)return;if(q.deviceUdid)q.exec(`osascript -e 'tell application "Simulator" to activate' -e 'tell application "System Events" to key code 124 using {command down}'`)},...Z,children:R6})}),$0=C6;$0.Title=w6;$0.Actions=T6;$0.Button=a0;$0.HomeButton=y6;$0.ScreenshotButton=g6;$0.RotateButton=x6;function d6(X){let[Y,Z]=p(null),J=w(new Set),[q,K]=p(null),Q=j((z)=>{return J.current.add(z),()=>{J.current.delete(z)}},[]);return d(()=>{if(!X)return;let z=new AbortController,G=X.replace(/\/stream\.mjpeg$/,"");return fetch(`${G}/config`,{signal:z.signal}).then((L)=>L.json()).then((L)=>{if(L.width>0&&L.height>0)Z(L)}).catch(()=>{}),(async()=>{try{let D=(await fetch(X,{signal:z.signal})).body?.getReader();if(!D)return;let W=new Uint8Array(0);while(!0){let{done:O,value:U}=await D.read();if(O)break;let k=new Uint8Array(W.length+U.length);k.set(W),k.set(U,W.length),W=k;while(!0){let _=-1;for(let I=0;I<W.length-1;I++)if(W[I]===255&&W[I+1]===216){_=I;break}if(_===-1)break;let C=-1;for(let I=_+2;I<W.length-1;I++)if(W[I]===255&&W[I+1]===217){C=I+2;break}if(C===-1)break;let M=W.slice(_,C);W=W.slice(C);let F=new Blob([M],{type:"image/jpeg"}),E=URL.createObjectURL(F);K(E);for(let I of J.current)I(E)}}}catch{}})(),()=>z.abort()},[X]),{subscribeFrame:Q,frame:q,config:Y}}function m6(){let X=window.__SIM_PREVIEW__,[Y,Z]=p(!1);if(d(()=>{if(!X?.logsEndpoint)return;let O=new EventSource(X.logsEndpoint),U=new Map,k=["#8be9fd","#50fa7b","#ffb86c","#ff79c6","#bd93f9","#f1fa8c","#6272a4","#ff5555","#69ff94","#d6acff","#ffffa5","#a4ffff","#ff6e6e","#caa9fa","#5af78e"];function _(F){let E=U.get(F);if(!E){let I=0;for(let v=0;v<F.length;v++)I=(I<<5)-I+F.charCodeAt(v)|0;E=k[Math.abs(I)%k.length],U.set(F,E)}return E}let C="",M=!1;return O.onmessage=(F)=>{try{let E=JSON.parse(F.data),I=E.processImagePath?.split("/").pop()??E.senderImagePath?.split("/").pop()??"",v=E.subsystem??"",r=E.category??"",f=E.eventMessage??"";if(!f)return;if(I!==C){if(M)console.groupEnd();let c0=_(I);console.groupCollapsed(`%c${I}${v?` %c${v}${r?":"+r:""}`:""}`,`color:${c0};font-weight:bold`,...v?["color:#888;font-weight:normal"]:[]),M=!0,C=I}let i=(E.messageType??"").toLowerCase(),y=v&&I===C?`%c${r||v}%c `:"",m=y?["color:#888;font-style:italic","color:inherit"]:[];if(i==="fault"||i==="error")console.log(`${y}%c${f}`,...m,"color:#ff5555");else if(i==="debug")console.log(`${y}%c${f}`,...m,"color:#6272a4");else console.log(`${y}%c${f}`,...m,"color:inherit")}catch{}},()=>{if(M)console.groupEnd();O.close()}},[X?.logsEndpoint]),!X)return $("div",{style:J0.page,children:$("div",{style:J0.empty,children:[$("h1",{style:J0.emptyTitle,children:"No serve-sim stream running"}),$("p",{style:J0.emptyHint,children:["Boot an iOS simulator and start a Hatch stream with"," ",$("code",{style:J0.code,children:"bunx serve-sim --detach"}),", then reload."]})]})});let J=R.iphone,q=U4("iphone"),K=m0("iphone"),Q=d6(X.streamUrl),z=w(null);d(()=>{let O=new WebSocket(X.wsUrl);return O.binaryType="arraybuffer",z.current=O,()=>{O.close(),z.current=null}},[X.wsUrl]);let G=j((O,U)=>{let k=z.current;if(!k||k.readyState!==WebSocket.OPEN)return;let _=new TextEncoder().encode(JSON.stringify(U)),C=new Uint8Array(1+_.length);C[0]=O,C.set(_,1),k.send(C)},[]),L=j((O)=>G(3,O),[G]),D=j((O)=>G(5,O),[G]),W=j((O)=>G(4,{button:O}),[G]);return $("div",{style:J0.page,children:[$("div",{style:{position:"relative",maxWidth:320,width:"100%",aspectRatio:`${J.width} / ${J.height}`},children:[$("div",{style:{position:"absolute",...q},children:$(x0,{url:X.url,style:{width:"100%",height:"100%",border:"none"},imageStyle:{borderRadius:K,cornerShape:"superellipse(1.3)"},hideControls:!0,onStreamingChange:Z,onStreamTouch:L,onStreamMultiTouch:D,onStreamButton:W,subscribeFrame:Q.subscribeFrame,streamFrame:Q.frame,streamConfig:Q.config})}),$("div",{style:{position:"absolute",inset:0,pointerEvents:"none",zIndex:10},children:$(h0,{type:"iphone",streaming:Y})})]}),$("div",{style:J0.bar,children:$("span",{style:{...J0.live,color:Y?"#4ade80":"#666"},children:[$("span",{style:{...J0.dot,background:Y?"#4ade80":"#666"}}),Y?"live":"connecting"]})})]})}var J0={page:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",background:"#0a0a0a",padding:24,gap:12,fontFamily:"-apple-system, system-ui, sans-serif"},bar:{display:"flex",alignItems:"center",gap:10,fontSize:12,fontFamily:"ui-monospace, monospace",color:"#666"},live:{display:"flex",alignItems:"center",gap:5,transition:"color 0.3s"},dot:{width:6,height:6,borderRadius:"50%",transition:"background 0.3s"},empty:{display:"flex",flexDirection:"column",alignItems:"center",gap:12,textAlign:"center"},emptyTitle:{fontSize:18,margin:0,color:"#eee"},emptyHint:{color:"#888",fontSize:14,maxWidth:480},code:{background:"#222",padding:"2px 6px",borderRadius:4,fontSize:13}};H5(document.getElementById("root")).render($(m6,{}));
</script>
</body></html>","base64").toString("utf-8");return V}function ge(e){let _=(e?.basePath??"/.sim").replace(/\/+$/,"");return(t,C,S)=>{let A=t.url??"";if(A===_||A===_+"/"){let i=N()[0]??null,r=le();if(i){let R=`<script>window.__SIM_PREVIEW__=${JSON.stringify({...i,logsEndpoint:_+"/logs"})}</script>`;r=r.replace("<!--__SIM_PREVIEW_CONFIG__-->",R)}C.writeHead(200,{"Content-Type":"text/html; charset=utf-8","Cache-Control":"no-store"}),C.end(r);return}if(A===_+"/api"){let B=N();C.writeHead(200,{"Content-Type":"application/json","Cache-Control":"no-store"}),C.end(JSON.stringify(B[0]||null));return}if(A===_+"/logs"||A.startsWith(_+"/logs?")){let B=N();if(B.length===0){C.writeHead(404),C.end("No serve-sim device");return}let i=B[0].device;C.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),C.write(`:
|
|
3
|
+
var Be=Object.defineProperty;var fe=(e)=>e;function Te(e,_){this[e]=fe.bind(null,_)}var pe=(e,_)=>{for(var t in _)Be(e,t,{get:_[t],enumerable:!0,configurable:!0,set:Te.bind(_,t)})};var De=(e,_)=>()=>(e&&(_=e(e=0)),_);var X={};pe(X,{simMiddleware:()=>Le});import{readdirSync as Fe,readFileSync as ue,existsSync as ge}from"fs";import{spawn as U,exec as we,execFile as ve}from"child_process";import{tmpdir as be}from"os";import{join as V}from"path";function He(e){return!me.test(e)}function Ne(e,_){if(he.has(_))return Promise.resolve(!0);return new Promise((t)=>{ve("xcrun",["simctl","get_app_container",e,_,"app"],{timeout:2000},(s,r)=>{if(s)return t(!1);let C=r.trim();if(!C)return t(!1);for(let o of Oe)if(ge(V(C,o)))return t(!0);t(!1)})})}function b(){let e;try{e=Fe(k).filter((t)=>t.startsWith("server-")&&t.endsWith(".json"))}catch{return[]}let _=[];for(let t of e)try{let s=JSON.parse(ue(V(k,t),"utf-8"));try{process.kill(s.pid,0),_.push(s)}catch{}}catch{}return _}function Ve(){if(!N)N=Buffer.from("<!doctype html>
<html><head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Simulator Preview</title>
<style>*,*::before,*::after{box-sizing:border-box}html,body{margin:0;height:100%;overflow:hidden}</style>
</head><body>
<div id="root"></div>
<!--__SIM_PREVIEW_CONFIG__-->
<script type="module">var c0,B,R4,x5,P0,T4,j4,v4,K4,m0,T0,y4,N4,$4,z4,p4,f0={},a0=[],h5=/acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i,b0=Array.isArray;function z0(X,Z){for(var J in Z)X[J]=Z[J];return X}function G4(X){X&&X.parentNode&&X.parentNode.removeChild(X)}function W0(X,Z,J){var Y,q,Q,K={};for(Q in Z)Q=="key"?Y=Z[Q]:Q=="ref"?q=Z[Q]:K[Q]=Z[Q];if(arguments.length>2&&(K.children=arguments.length>3?c0.call(arguments,2):J),typeof X=="function"&&X.defaultProps!=null)for(Q in X.defaultProps)K[Q]===void 0&&(K[Q]=X.defaultProps[Q]);return d0(X,K,Y,q,null)}function d0(X,Z,J,Y,q){var Q={type:X,props:Z,key:J,ref:Y,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:q==null?++R4:q,__i:-1,__u:0};return q==null&&B.vnode!=null&&B.vnode(Q),Q}function d(X){return X.children}function c(X,Z){this.props=X,this.context=Z}function B0(X,Z){if(Z==null)return X.__?B0(X.__,X.__i+1):null;for(var J;Z<X.__k.length;Z++)if((J=X.__k[Z])!=null&&J.__e!=null)return J.__e;return typeof X.type=="function"?B0(X):null}function m5(X){if(X.__P&&X.__d){var Z=X.__v,J=Z.__e,Y=[],q=[],Q=z0({},Z);Q.__v=Z.__v+1,B.vnode&&B.vnode(Q),V4(X.__P,Q,Z,X.__n,X.__P.namespaceURI,32&Z.__u?[J]:null,Y,J==null?B0(Z):J,!!(32&Z.__u),q),Q.__v=Z.__v,Q.__.__k[Q.__i]=Q,m4(Y,Q,q),Z.__e=Z.__=null,Q.__e!=J&&g4(Q)}}function g4(X){if((X=X.__)!=null&&X.__c!=null)return X.__e=X.__c.base=null,X.__k.some(function(Z){if(Z!=null&&Z.__e!=null)return X.__e=X.__c.base=Z.__e}),g4(X)}function W4(X){(!X.__d&&(X.__d=!0)&&P0.push(X)&&!l0.__r++||T4!=B.debounceRendering)&&((T4=B.debounceRendering)||j4)(l0)}function l0(){try{for(var X,Z=1;P0.length;)P0.length>Z&&P0.sort(v4),X=P0.shift(),Z=P0.length,m5(X)}finally{P0.length=l0.__r=0}}function x4(X,Z,J,Y,q,Q,K,W,G,z,P){var $,_,O,C,A,k,I,M=Y&&Y.__k||a0,h=Z.length;for(G=d5(J,Z,M,G,h),$=0;$<h;$++)(O=J.__k[$])!=null&&(_=O.__i!=-1&&M[O.__i]||f0,O.__i=$,k=V4(X,O,_,q,Q,K,W,G,z,P),C=O.__e,O.ref&&_.ref!=O.ref&&(_.ref&&H4(_.ref,null,O),P.push(O.ref,O.__c||C,O)),A==null&&C!=null&&(A=C),(I=!!(4&O.__u))||_.__k===O.__k?(G=h4(O,G,X,I),I&&_.__e&&(_.__e=null)):typeof O.type=="function"&&k!==void 0?G=k:C&&(G=C.nextSibling),O.__u&=-7);return J.__e=A,G}function d5(X,Z,J,Y,q){var Q,K,W,G,z,P=J.length,$=P,_=0;for(X.__k=Array(q),Q=0;Q<q;Q++)(K=Z[Q])!=null&&typeof K!="boolean"&&typeof K!="function"?(typeof K=="string"||typeof K=="number"||typeof K=="bigint"||K.constructor==String?K=X.__k[Q]=d0(null,K,null,null,null):b0(K)?K=X.__k[Q]=d0(d,{children:K},null,null,null):K.constructor===void 0&&K.__b>0?K=X.__k[Q]=d0(K.type,K.props,K.key,K.ref?K.ref:null,K.__v):X.__k[Q]=K,G=Q+_,K.__=X,K.__b=X.__b+1,W=null,(z=K.__i=f5(K,J,G,$))!=-1&&($--,(W=J[z])&&(W.__u|=2)),W==null||W.__v==null?(z==-1&&(q>P?_--:q<P&&_++),typeof K.type!="function"&&(K.__u|=4)):z!=G&&(z==G-1?_--:z==G+1?_++:(z>G?_--:_++,K.__u|=4))):X.__k[Q]=null;if($)for(Q=0;Q<P;Q++)(W=J[Q])!=null&&(2&W.__u)==0&&(W.__e==Y&&(Y=B0(W)),f4(W,W));return Y}function h4(X,Z,J,Y){var q,Q;if(typeof X.type=="function"){for(q=X.__k,Q=0;q&&Q<q.length;Q++)q[Q]&&(q[Q].__=X,Z=h4(q[Q],Z,J,Y));return Z}X.__e!=Z&&(Y&&(Z&&X.type&&!Z.parentNode&&(Z=B0(X)),J.insertBefore(X.__e,Z||null)),Z=X.__e);do Z=Z&&Z.nextSibling;while(Z!=null&&Z.nodeType==8);return Z}function L0(X,Z){return Z=Z||[],X==null||typeof X=="boolean"||(b0(X)?X.some(function(J){L0(J,Z)}):Z.push(X)),Z}function f5(X,Z,J,Y){var q,Q,K,W=X.key,G=X.type,z=Z[J],P=z!=null&&(2&z.__u)==0;if(z===null&&W==null||P&&W==z.key&&G==z.type)return J;if(Y>(P?1:0)){for(q=J-1,Q=J+1;q>=0||Q<Z.length;)if((z=Z[K=q>=0?q--:Q++])!=null&&(2&z.__u)==0&&W==z.key&&G==z.type)return K}return-1}function b4(X,Z,J){Z[0]=="-"?X.setProperty(Z,J==null?"":J):X[Z]=J==null?"":typeof J!="number"||h5.test(Z)?J:J+"px"}function h0(X,Z,J,Y,q){var Q,K;X:if(Z=="style")if(typeof J=="string")X.style.cssText=J;else{if(typeof Y=="string"&&(X.style.cssText=Y=""),Y)for(Z in Y)J&&Z in J||b4(X.style,Z,"");if(J)for(Z in J)Y&&J[Z]==Y[Z]||b4(X.style,Z,J[Z])}else if(Z[0]=="o"&&Z[1]=="n")Q=Z!=(Z=Z.replace(y4,"$1")),K=Z.toLowerCase(),Z=K in X||Z=="onFocusOut"||Z=="onFocusIn"?K.slice(2):Z.slice(2),X.l||(X.l={}),X.l[Z+Q]=J,J?Y?J[T0]=Y[T0]:(J[T0]=N4,X.addEventListener(Z,Q?z4:$4,Q)):X.removeEventListener(Z,Q?z4:$4,Q);else{if(q=="http://www.w3.org/2000/svg")Z=Z.replace(/xlink(H|:h)/,"h").replace(/sName$/,"s");else if(Z!="width"&&Z!="height"&&Z!="href"&&Z!="list"&&Z!="form"&&Z!="tabIndex"&&Z!="download"&&Z!="rowSpan"&&Z!="colSpan"&&Z!="role"&&Z!="popover"&&Z in X)try{X[Z]=J==null?"":J;break X}catch(W){}typeof J=="function"||(J==null||J===!1&&Z[4]!="-"?X.removeAttribute(Z):X.setAttribute(Z,Z=="popover"&&J==1?"":J))}}function S4(X){return function(Z){if(this.l){var J=this.l[Z.type+X];if(Z[m0]==null)Z[m0]=N4++;else if(Z[m0]<J[T0])return;return J(B.event?B.event(Z):Z)}}}function V4(X,Z,J,Y,q,Q,K,W,G,z){var P,$,_,O,C,A,k,I,M,h,E,n,Q0,g,K0,s=Z.type;if(Z.constructor!==void 0)return null;128&J.__u&&(G=!!(32&J.__u),Q=[W=Z.__e=J.__e]),(P=B.__b)&&P(Z);X:if(typeof s=="function")try{if(I=Z.props,M=s.prototype&&s.prototype.render,h=(P=s.contextType)&&Y[P.__c],E=P?h?h.props.value:P.__:Y,J.__c?k=($=Z.__c=J.__c).__=$.__E:(M?Z.__c=$=new s(I,E):(Z.__c=$=new c(I,E),$.constructor=s,$.render=l5),h&&h.sub($),$.state||($.state={}),$.__n=Y,_=$.__d=!0,$.__h=[],$._sb=[]),M&&$.__s==null&&($.__s=$.state),M&&s.getDerivedStateFromProps!=null&&($.__s==$.state&&($.__s=z0({},$.__s)),z0($.__s,s.getDerivedStateFromProps(I,$.__s))),O=$.props,C=$.state,$.__v=Z,_)M&&s.getDerivedStateFromProps==null&&$.componentWillMount!=null&&$.componentWillMount(),M&&$.componentDidMount!=null&&$.__h.push($.componentDidMount);else{if(M&&s.getDerivedStateFromProps==null&&I!==O&&$.componentWillReceiveProps!=null&&$.componentWillReceiveProps(I,E),Z.__v==J.__v||!$.__e&&$.shouldComponentUpdate!=null&&$.shouldComponentUpdate(I,$.__s,E)===!1){Z.__v!=J.__v&&($.props=I,$.state=$.__s,$.__d=!1),Z.__e=J.__e,Z.__k=J.__k,Z.__k.some(function(r){r&&(r.__=Z)}),a0.push.apply($.__h,$._sb),$._sb=[],$.__h.length&&K.push($);break X}$.componentWillUpdate!=null&&$.componentWillUpdate(I,$.__s,E),M&&$.componentDidUpdate!=null&&$.__h.push(function(){$.componentDidUpdate(O,C,A)})}if($.context=E,$.props=I,$.__P=X,$.__e=!1,n=B.__r,Q0=0,M)$.state=$.__s,$.__d=!1,n&&n(Z),P=$.render($.props,$.state,$.context),a0.push.apply($.__h,$._sb),$._sb=[];else do $.__d=!1,n&&n(Z),P=$.render($.props,$.state,$.context),$.state=$.__s;while($.__d&&++Q0<25);$.state=$.__s,$.getChildContext!=null&&(Y=z0(z0({},Y),$.getChildContext())),M&&!_&&$.getSnapshotBeforeUpdate!=null&&(A=$.getSnapshotBeforeUpdate(O,C)),g=P!=null&&P.type===d&&P.key==null?d4(P.props.children):P,W=x4(X,b0(g)?g:[g],Z,J,Y,q,Q,K,W,G,z),$.base=Z.__e,Z.__u&=-161,$.__h.length&&K.push($),k&&($.__E=$.__=null)}catch(r){if(Z.__v=null,G||Q!=null)if(r.then){for(Z.__u|=G?160:128;W&&W.nodeType==8&&W.nextSibling;)W=W.nextSibling;Q[Q.indexOf(W)]=null,Z.__e=W}else{for(K0=Q.length;K0--;)G4(Q[K0]);L4(Z)}else Z.__e=J.__e,Z.__k=J.__k,r.then||L4(Z);B.__e(r,Z,J)}else Q==null&&Z.__v==J.__v?(Z.__k=J.__k,Z.__e=J.__e):W=Z.__e=a5(J.__e,Z,J,Y,q,Q,K,G,z);return(P=B.diffed)&&P(Z),128&Z.__u?void 0:W}function L4(X){X&&(X.__c&&(X.__c.__e=!0),X.__k&&X.__k.some(L4))}function m4(X,Z,J){for(var Y=0;Y<J.length;Y++)H4(J[Y],J[++Y],J[++Y]);B.__c&&B.__c(Z,X),X.some(function(q){try{X=q.__h,q.__h=[],X.some(function(Q){Q.call(q)})}catch(Q){B.__e(Q,q.__v)}})}function d4(X){return typeof X!="object"||X==null||X.__b>0?X:b0(X)?X.map(d4):z0({},X)}function a5(X,Z,J,Y,q,Q,K,W,G){var z,P,$,_,O,C,A,k=J.props||f0,I=Z.props,M=Z.type;if(M=="svg"?q="http://www.w3.org/2000/svg":M=="math"?q="http://www.w3.org/1998/Math/MathML":q||(q="http://www.w3.org/1999/xhtml"),Q!=null){for(z=0;z<Q.length;z++)if((O=Q[z])&&"setAttribute"in O==!!M&&(M?O.localName==M:O.nodeType==3)){X=O,Q[z]=null;break}}if(X==null){if(M==null)return document.createTextNode(I);X=document.createElementNS(q,M,I.is&&I),W&&(B.__m&&B.__m(Z,Q),W=!1),Q=null}if(M==null)k===I||W&&X.data==I||(X.data=I);else{if(Q=Q&&c0.call(X.childNodes),!W&&Q!=null)for(k={},z=0;z<X.attributes.length;z++)k[(O=X.attributes[z]).name]=O.value;for(z in k)O=k[z],z=="dangerouslySetInnerHTML"?$=O:z=="children"||(z in I)||z=="value"&&("defaultValue"in I)||z=="checked"&&("defaultChecked"in I)||h0(X,z,null,O,q);for(z in I)O=I[z],z=="children"?_=O:z=="dangerouslySetInnerHTML"?P=O:z=="value"?C=O:z=="checked"?A=O:W&&typeof O!="function"||k[z]===O||h0(X,z,O,k[z],q);if(P)W||$&&(P.__html==$.__html||P.__html==X.innerHTML)||(X.innerHTML=P.__html),Z.__k=[];else if($&&(X.innerHTML=""),x4(Z.type=="template"?X.content:X,b0(_)?_:[_],Z,J,Y,M=="foreignObject"?"http://www.w3.org/1999/xhtml":q,Q,K,Q?Q[0]:J.__k&&B0(J,0),W,G),Q!=null)for(z=Q.length;z--;)G4(Q[z]);W||(z="value",M=="progress"&&C==null?X.removeAttribute("value"):C!=null&&(C!==X[z]||M=="progress"&&!C||M=="option"&&C!=k[z])&&h0(X,z,C,k[z],q),z="checked",A!=null&&A!=X[z]&&h0(X,z,A,k[z],q))}return X}function H4(X,Z,J){try{if(typeof X=="function"){var Y=typeof X.__u=="function";Y&&X.__u(),Y&&Z==null||(X.__u=X(Z))}else X.current=Z}catch(q){B.__e(q,J)}}function f4(X,Z,J){var Y,q;if(B.unmount&&B.unmount(X),(Y=X.ref)&&(Y.current&&Y.current!=X.__e||H4(Y,null,Z)),(Y=X.__c)!=null){if(Y.componentWillUnmount)try{Y.componentWillUnmount()}catch(Q){B.__e(Q,Z)}Y.base=Y.__P=null}if(Y=X.__k)for(q=0;q<Y.length;q++)Y[q]&&f4(Y[q],Z,J||typeof X.type!="function");J||G4(X.__e),X.__c=X.__=X.__e=void 0}function l5(X,Z,J){return this.constructor(X,J)}function i0(X,Z,J){var Y,q,Q,K;Z==document&&(Z=document.documentElement),B.__&&B.__(X,Z),q=(Y=typeof J=="function")?null:J&&J.__k||Z.__k,Q=[],K=[],V4(Z,X=(!Y&&J||Z).__k=W0(d,null,[X]),q||f0,f0,Z.namespaceURI,!Y&&J?[J]:q?null:Z.firstChild?c0.call(Z.childNodes):null,Q,!Y&&J?J:q?q.__e:Z.firstChild,Y,K),m4(Q,X,K)}function _0(X){function Z(J){var Y,q;return this.getChildContext||(Y=new Set,(q={})[Z.__c]=this,this.getChildContext=function(){return q},this.componentWillUnmount=function(){Y=null},this.shouldComponentUpdate=function(Q){this.props.value!=Q.value&&Y.forEach(function(K){K.__e=!0,W4(K)})},this.sub=function(Q){Y.add(Q);var K=Q.componentWillUnmount;Q.componentWillUnmount=function(){Y&&Y.delete(Q),K&&K.call(Q)}}),J.children}return Z.__c="__cC"+p4++,Z.__=X,Z.Provider=Z.__l=(Z.Consumer=function(J,Y){return J.children(Y)}).contextType=Z,Z}c0=a0.slice,B={__e:function(X,Z,J,Y){for(var q,Q,K;Z=Z.__;)if((q=Z.__c)&&!q.__)try{if((Q=q.constructor)&&Q.getDerivedStateFromError!=null&&(q.setState(Q.getDerivedStateFromError(X)),K=q.__d),q.componentDidCatch!=null&&(q.componentDidCatch(X,Y||{}),K=q.__d),K)return q.__E=q}catch(W){X=W}throw X}},R4=0,x5=function(X){return X!=null&&X.constructor===void 0},c.prototype.setState=function(X,Z){var J;J=this.__s!=null&&this.__s!=this.state?this.__s:this.__s=z0({},this.state),typeof X=="function"&&(X=X(z0({},J),this.props)),X&&z0(J,X),X!=null&&this.__v&&(Z&&this._sb.push(Z),W4(this))},c.prototype.forceUpdate=function(X){this.__v&&(this.__e=!0,X&&this.__h.push(X),W4(this))},c.prototype.render=d,P0=[],j4=typeof Promise=="function"?Promise.prototype.then.bind(Promise.resolve()):setTimeout,v4=function(X,Z){return X.__v.__b-Z.__v.__b},l0.__r=0,K4=Math.random().toString(8),m0="__d"+K4,T0="__a"+K4,y4=/(PointerCapture)$|Capture$/i,N4=0,$4=S4(!1),z4=S4(!0),p4=0;var F0,p,P4,a4,S0=0,t4=[],f=B,l4=f.__b,c4=f.__r,i4=f.diffed,u4=f.__c,o4=f.unmount,s4=f.__;function o0(X,Z){f.__h&&f.__h(p,X,S0||Z),S0=0;var J=p.__H||(p.__H={__:[],__h:[]});return X>=J.__.length&&J.__.push({}),J.__[X]}function S(X){return S0=1,O4(e4,X)}function O4(X,Z,J){var Y=o0(F0++,2);if(Y.t=X,!Y.__c&&(Y.__=[J?J(Z):e4(void 0,Z),function(W){var G=Y.__N?Y.__N[0]:Y.__[0],z=Y.t(G,W);G!==z&&(Y.__N=[z,Y.__[1]],Y.__c.setState({}))}],Y.__c=p,!p.__f)){var q=function(W,G,z){if(!Y.__c.__H)return!0;var P=Y.__c.__H.__.filter(function(_){return _.__c});if(P.every(function(_){return!_.__N}))return!Q||Q.call(this,W,G,z);var $=Y.__c.props!==W;return P.some(function(_){if(_.__N){var O=_.__[0];_.__=_.__N,_.__N=void 0,O!==_.__[0]&&($=!0)}}),Q&&Q.call(this,W,G,z)||$};p.__f=!0;var{shouldComponentUpdate:Q,componentWillUpdate:K}=p;p.componentWillUpdate=function(W,G,z){if(this.__e){var P=Q;Q=void 0,q(W,G,z),Q=P}K&&K.call(this,W,G,z)},p.shouldComponentUpdate=q}return Y.__N||Y.__}function x(X,Z){var J=o0(F0++,3);!f.__s&&n4(J.__H,Z)&&(J.__=X,J.u=Z,p.__H.__h.push(J))}function w(X){return S0=5,s0(function(){return{current:X}},[])}function s0(X,Z){var J=o0(F0++,7);return n4(J.__H,Z)&&(J.__=X(),J.__H=Z,J.__h=X),J.__}function j(X,Z){return S0=8,s0(function(){return X},Z)}function R0(X){var Z=p.context[X.__c],J=o0(F0++,9);return J.c=X,Z?(J.__==null&&(J.__=!0,Z.sub(p)),Z.props.value):X.__}function c5(){for(var X;X=t4.shift();){var Z=X.__H;if(X.__P&&Z)try{Z.__h.some(u0),Z.__h.some(A4),Z.__h=[]}catch(J){Z.__h=[],f.__e(J,X.__v)}}}f.__b=function(X){p=null,l4&&l4(X)},f.__=function(X,Z){X&&Z.__k&&Z.__k.__m&&(X.__m=Z.__k.__m),s4&&s4(X,Z)},f.__r=function(X){c4&&c4(X),F0=0;var Z=(p=X.__c).__H;Z&&(P4===p?(Z.__h=[],p.__h=[],Z.__.some(function(J){J.__N&&(J.__=J.__N),J.u=J.__N=void 0})):(Z.__h.some(u0),Z.__h.some(A4),Z.__h=[],F0=0)),P4=p},f.diffed=function(X){i4&&i4(X);var Z=X.__c;Z&&Z.__H&&(Z.__H.__h.length&&(t4.push(Z)!==1&&a4===f.requestAnimationFrame||((a4=f.requestAnimationFrame)||i5)(c5)),Z.__H.__.some(function(J){J.u&&(J.__H=J.u),J.u=void 0})),P4=p=null},f.__c=function(X,Z){Z.some(function(J){try{J.__h.some(u0),J.__h=J.__h.filter(function(Y){return!Y.__||A4(Y)})}catch(Y){Z.some(function(q){q.__h&&(q.__h=[])}),Z=[],f.__e(Y,J.__v)}}),u4&&u4(X,Z)},f.unmount=function(X){o4&&o4(X);var Z,J=X.__c;J&&J.__H&&(J.__H.__.some(function(Y){try{u0(Y)}catch(q){Z=q}}),J.__H=void 0,Z&&f.__e(Z,J.__v))};var r4=typeof requestAnimationFrame=="function";function i5(X){var Z,J=function(){clearTimeout(Y),r4&&cancelAnimationFrame(Z),setTimeout(X)},Y=setTimeout(J,35);r4&&(Z=requestAnimationFrame(J))}function u0(X){var Z=p,J=X.__c;typeof J=="function"&&(X.__c=void 0,J()),p=Z}function A4(X){var Z=p;X.__c=X.__(),p=Z}function n4(X,Z){return!X||X.length!==Z.length||Z.some(function(J,Y){return J!==X[Y]})}function e4(X,Z){return typeof Z=="function"?Z(X):Z}function e5(X,Z){for(var J in Z)X[J]=Z[J];return X}function X5(X,Z){for(var J in X)if(J!=="__source"&&!(J in Z))return!0;for(var Y in Z)if(Y!=="__source"&&X[Y]!==Z[Y])return!0;return!1}function Z5(X,Z){this.props=X,this.context=Z}(Z5.prototype=new c).isPureReactComponent=!0,Z5.prototype.shouldComponentUpdate=function(X,Z){return X5(this.props,X)||X5(this.state,Z)};var J5=B.__b;B.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),J5&&J5(X)};var X6=B.__e;B.__e=function(X,Z,J,Y){if(X.then){for(var q,Q=Z;Q=Q.__;)if((q=Q.__c)&&q.__c)return Z.__e==null&&(Z.__e=J.__e,Z.__k=J.__k),q.__c(X,Z)}X6(X,Z,J,Y)};var Y5=B.unmount;function W5(X,Z,J){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(Y){typeof Y.__c=="function"&&Y.__c()}),X.__c.__H=null),(X=e5({},X)).__c!=null&&(X.__c.__P===J&&(X.__c.__P=Z),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(Y){return W5(Y,Z,J)})),X}function L5(X,Z,J){return X&&J&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(Y){return L5(Y,Z,J)}),X.__c&&X.__c.__P===Z&&(X.__e&&J.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=J)),X}function U4(){this.__u=0,this.o=null,this.__b=null}function N5(X){var Z=X.__&&X.__.__c;return Z&&Z.__a&&Z.__a(X)}function r0(){this.i=null,this.l=null}B.unmount=function(X){var Z=X.__c;Z&&(Z.__z=!0),Z&&Z.__R&&Z.__R(),Z&&32&X.__u&&(X.type=null),Y5&&Y5(X)},(U4.prototype=new c).__c=function(X,Z){var J=Z.__c,Y=this;Y.o==null&&(Y.o=[]),Y.o.push(J);var q=N5(Y.__v),Q=!1,K=function(){Q||Y.__z||(Q=!0,J.__R=null,q?q(G):G())};J.__R=K;var W=J.__P;J.__P=null;var G=function(){if(!--Y.__u){if(Y.state.__a){var z=Y.state.__a;Y.__v.__k[0]=L5(z,z.__c.__P,z.__c.__O)}var P;for(Y.setState({__a:Y.__b=null});P=Y.o.pop();)P.__P=W,P.forceUpdate()}};Y.__u++||32&Z.__u||Y.setState({__a:Y.__b=Y.__v.__k[0]}),X.then(K,K)},U4.prototype.componentWillUnmount=function(){this.o=[]},U4.prototype.render=function(X,Z){if(this.__b){if(this.__v.__k){var J=document.createElement("div"),Y=this.__v.__k[0].__c;this.__v.__k[0]=W5(this.__b,J,Y.__O=Y.__P)}this.__b=null}var q=Z.__a&&W0(d,null,X.fallback);return q&&(q.__u&=-33),[W0(d,null,Z.__a?null:X.children),q]};var q5=function(X,Z,J){if(++J[1]===J[0]&&X.l.delete(Z),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(J=X.i;J;){for(;J.length>3;)J.pop()();if(J[1]<J[0])break;X.i=J=J[2]}};(r0.prototype=new c).__a=function(X){var Z=this,J=N5(Z.__v),Y=Z.l.get(X);return Y[0]++,function(q){var Q=function(){Z.props.revealOrder?(Y.push(q),q5(Z,X,Y)):q()};J?J(Q):Q()}},r0.prototype.render=function(X){this.i=null,this.l=new Map;var Z=L0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Z.reverse();for(var J=Z.length;J--;)this.l.set(Z[J],this.i=[1,0,this.i]);return X.children},r0.prototype.componentDidUpdate=r0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Z,J){q5(X,J,Z)})};var Z6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,J6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,Y6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,q6=/[A-Z0-9]/g,Q6=typeof document<"u",K6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};function G5(X,Z,J){return Z.__k==null&&(Z.textContent=""),i0(X,Z),typeof J=="function"&&J(),X?X.__c:null}c.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(c.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Z){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Z})}})});var Q5=B.event;B.event=function(X){return Q5&&(X=Q5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var V5,$6={configurable:!0,get:function(){return this.class}},K5=B.vnode;B.vnode=function(X){typeof X.type=="string"&&function(Z){var{props:J,type:Y}=Z,q={},Q=Y.indexOf("-")==-1;for(var K in J){var W=J[K];if(!(K==="value"&&("defaultValue"in J)&&W==null||Q6&&K==="children"&&Y==="noscript"||K==="class"||K==="className")){var G=K.toLowerCase();K==="defaultValue"&&"value"in J&&J.value==null?K="value":K==="download"&&W===!0?W="":G==="translate"&&W==="no"?W=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?K="ondblclick":G!=="onchange"||Y!=="input"&&Y!=="textarea"||K6(J.type)?G==="onfocus"?K="onfocusin":G==="onblur"?K="onfocusout":Y6.test(K)&&(K=G):G=K="oninput":Q&&J6.test(K)?K=K.replace(q6,"-$&").toLowerCase():W===null&&(W=void 0),G==="oninput"&&q[K=G]&&(K="oninputCapture"),q[K]=W}}Y=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.value.indexOf(z.props.value)!=-1})),q.defaultValue!=null&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.multiple?q.defaultValue.indexOf(z.props.value)!=-1:q.defaultValue==z.props.value}))),J.class&&!J.className?(q.class=J.class,Object.defineProperty(q,"className",$6)):J.className&&(q.class=q.className=J.className),Z.props=q}(X),X.$$typeof=Z6,K5&&K5(X)};var $5=B.__r;B.__r=function(X){$5&&$5(X),V5=X.__c};var z5=B.diffed;B.diffed=function(X){z5&&z5(X);var{props:Z,__e:J}=X;J!=null&&X.type==="textarea"&&"value"in Z&&Z.value!==J.value&&(J.value=Z.value==null?"":Z.value),V5=null};function H5(X){return!!X.__k&&(i0(null,X),!0)}function P5(X){return{render:function(Z){G5(Z,X)},unmount:function(){H5(X)}}}function M5(X,Z){for(var J in Z)X[J]=Z[J];return X}function A5(X,Z){for(var J in X)if(J!=="__source"&&!(J in Z))return!0;for(var Y in Z)if(Y!=="__source"&&X[Y]!==Z[Y])return!0;return!1}function O5(X,Z){this.props=X,this.context=Z}(O5.prototype=new c).isPureReactComponent=!0,O5.prototype.shouldComponentUpdate=function(X,Z){return A5(this.props,X)||A5(this.state,Z)};var U5=B.__b;B.__b=function(X){X.type&&X.type.__f&&X.ref&&(X.props.ref=X.ref,X.ref=null),U5&&U5(X)};var z6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.forward_ref")||3911;function D0(X){function Z(J){var Y=M5({},J);return delete Y.ref,X(Y,J.ref||null)}return Z.$$typeof=z6,Z.render=X,Z.prototype.isReactComponent=Z.__f=!0,Z.displayName="ForwardRef("+(X.displayName||X.name)+")",Z}var W6=B.__e;B.__e=function(X,Z,J,Y){if(X.then){for(var q,Q=Z;Q=Q.__;)if((q=Q.__c)&&q.__c)return Z.__e==null&&(Z.__e=J.__e,Z.__k=J.__k),q.__c(X,Z)}W6(X,Z,J,Y)};var B5=B.unmount;function C5(X,Z,J){return X&&(X.__c&&X.__c.__H&&(X.__c.__H.__.forEach(function(Y){typeof Y.__c=="function"&&Y.__c()}),X.__c.__H=null),(X=M5({},X)).__c!=null&&(X.__c.__P===J&&(X.__c.__P=Z),X.__c.__e=!0,X.__c=null),X.__k=X.__k&&X.__k.map(function(Y){return C5(Y,Z,J)})),X}function E5(X,Z,J){return X&&J&&(X.__v=null,X.__k=X.__k&&X.__k.map(function(Y){return E5(Y,Z,J)}),X.__c&&X.__c.__P===Z&&(X.__e&&J.appendChild(X.__e),X.__c.__e=!0,X.__c.__P=J)),X}function _4(){this.__u=0,this.o=null,this.__b=null}function w5(X){var Z=X.__&&X.__.__c;return Z&&Z.__a&&Z.__a(X)}function t0(){this.i=null,this.l=null}B.unmount=function(X){var Z=X.__c;Z&&(Z.__z=!0),Z&&Z.__R&&Z.__R(),Z&&32&X.__u&&(X.type=null),B5&&B5(X)},(_4.prototype=new c).__c=function(X,Z){var J=Z.__c,Y=this;Y.o==null&&(Y.o=[]),Y.o.push(J);var q=w5(Y.__v),Q=!1,K=function(){Q||Y.__z||(Q=!0,J.__R=null,q?q(G):G())};J.__R=K;var W=J.__P;J.__P=null;var G=function(){if(!--Y.__u){if(Y.state.__a){var z=Y.state.__a;Y.__v.__k[0]=E5(z,z.__c.__P,z.__c.__O)}var P;for(Y.setState({__a:Y.__b=null});P=Y.o.pop();)P.__P=W,P.forceUpdate()}};Y.__u++||32&Z.__u||Y.setState({__a:Y.__b=Y.__v.__k[0]}),X.then(K,K)},_4.prototype.componentWillUnmount=function(){this.o=[]},_4.prototype.render=function(X,Z){if(this.__b){if(this.__v.__k){var J=document.createElement("div"),Y=this.__v.__k[0].__c;this.__v.__k[0]=C5(this.__b,J,Y.__O=Y.__P)}this.__b=null}var q=Z.__a&&W0(d,null,X.fallback);return q&&(q.__u&=-33),[W0(d,null,Z.__a?null:X.children),q]};var _5=function(X,Z,J){if(++J[1]===J[0]&&X.l.delete(Z),X.props.revealOrder&&(X.props.revealOrder[0]!=="t"||!X.l.size))for(J=X.i;J;){for(;J.length>3;)J.pop()();if(J[1]<J[0])break;X.i=J=J[2]}};(t0.prototype=new c).__a=function(X){var Z=this,J=w5(Z.__v),Y=Z.l.get(X);return Y[0]++,function(q){var Q=function(){Z.props.revealOrder?(Y.push(q),_5(Z,X,Y)):q()};J?J(Q):Q()}},t0.prototype.render=function(X){this.i=null,this.l=new Map;var Z=L0(X.children);X.revealOrder&&X.revealOrder[0]==="b"&&Z.reverse();for(var J=Z.length;J--;)this.l.set(Z[J],this.i=[1,0,this.i]);return X.children},t0.prototype.componentDidUpdate=t0.prototype.componentDidMount=function(){var X=this;this.l.forEach(function(Z,J){_5(X,J,Z)})};var L6=typeof Symbol<"u"&&Symbol.for&&Symbol.for("react.element")||60103,N6=/^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|image(!S)|letter|lighting|marker(?!H|W|U)|overline|paint|pointer|shape|stop|strikethrough|stroke|text(?!L)|transform|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/,G6=/^on(Ani|Tra|Tou|BeforeInp|Compo)/,V6=/[A-Z0-9]/g,H6=typeof document<"u",P6=function(X){return(typeof Symbol<"u"&&typeof Symbol()=="symbol"?/fil|che|rad/:/fil|che|ra/).test(X)};c.prototype.isReactComponent=!0,["componentWillMount","componentWillReceiveProps","componentWillUpdate"].forEach(function(X){Object.defineProperty(c.prototype,X,{configurable:!0,get:function(){return this["UNSAFE_"+X]},set:function(Z){Object.defineProperty(this,X,{configurable:!0,writable:!0,value:Z})}})});var F5=B.event;B.event=function(X){return F5&&(X=F5(X)),X.persist=function(){},X.isPropagationStopped=function(){return this.cancelBubble},X.isDefaultPrevented=function(){return this.defaultPrevented},X.nativeEvent=X};var T5,A6={configurable:!0,get:function(){return this.class}},D5=B.vnode;B.vnode=function(X){typeof X.type=="string"&&function(Z){var{props:J,type:Y}=Z,q={},Q=Y.indexOf("-")==-1;for(var K in J){var W=J[K];if(!(K==="value"&&("defaultValue"in J)&&W==null||H6&&K==="children"&&Y==="noscript"||K==="class"||K==="className")){var G=K.toLowerCase();K==="defaultValue"&&"value"in J&&J.value==null?K="value":K==="download"&&W===!0?W="":G==="translate"&&W==="no"?W=!1:G[0]==="o"&&G[1]==="n"?G==="ondoubleclick"?K="ondblclick":G!=="onchange"||Y!=="input"&&Y!=="textarea"||P6(J.type)?G==="onfocus"?K="onfocusin":G==="onblur"?K="onfocusout":G6.test(K)&&(K=G):G=K="oninput":Q&&N6.test(K)?K=K.replace(V6,"-$&").toLowerCase():W===null&&(W=void 0),G==="oninput"&&q[K=G]&&(K="oninputCapture"),q[K]=W}}Y=="select"&&(q.multiple&&Array.isArray(q.value)&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.value.indexOf(z.props.value)!=-1})),q.defaultValue!=null&&(q.value=L0(J.children).forEach(function(z){z.props.selected=q.multiple?q.defaultValue.indexOf(z.props.value)!=-1:q.defaultValue==z.props.value}))),J.class&&!J.className?(q.class=J.class,Object.defineProperty(q,"className",A6)):J.className&&(q.class=q.className=J.className),Z.props=q}(X),X.$$typeof=L6,D5&&D5(X)};var k5=B.__r;B.__r=function(X){k5&&k5(X),T5=X.__c};var I5=B.diffed;B.diffed=function(X){I5&&I5(X);var{props:Z,__e:J}=X;J!=null&&X.type==="textarea"&&"value"in Z&&Z.value!==J.value&&(J.value=Z.value==null?"":Z.value),T5=null};var O6=0;function N(X,Z,J,Y,q,Q){Z||(Z={});var K,W,G=Z;if("ref"in G)for(W in G={},Z)W=="ref"?K=Z[W]:G[W]=Z[W];var z={type:X,props:G,key:J,ref:K,__k:null,__:null,__b:0,__e:null,__c:null,constructor:void 0,__v:--O6,__i:-1,__u:0,__source:q,__self:Q};if(typeof X=="function"&&(K=X.defaultProps))for(W in K)G[W]===void 0&&(G[W]=K[W]);return B.vnode&&B.vnode(z),z}var F4=`url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle cx='10' cy='10' r='9' fill='rgba(255,255,255,0.4)' stroke='rgba(255,255,255,0.7)' stroke-width='1'/%3E%3C/svg%3E") 10 10, pointer`,U6=3,B6=4,_6=5;function n0({url:X,wsUrl:Z,style:J,imageStyle:Y,className:q,onHomePress:Q,onStreamTouch:K,onStreamMultiTouch:W,onStreamButton:G,subscribeFrame:z,streamFrame:P,streamConfig:$,hideControls:_,onStreamingChange:O,connectionQuality:C}){let A=!!K,k=w(null),I=w(null),M=w(null),[h,E]=S(!1),[n,Q0]=S(null),[g,K0]=S(null),s=w(null),[r,O0]=S(null);x(()=>{let V=s.current;if(!V||typeof ResizeObserver>"u")return;let H=new ResizeObserver((L)=>{let U=L[0]?.contentRect;if(U)O0({width:U.width,height:U.height})});return H.observe(V),()=>H.disconnect()},[]);let[j0,v0]=S(0),G0=w(0),[J4,I0]=S(!1),F=w(null);x(()=>{if(C==="poor"){if(I0(!0),F.current)clearTimeout(F.current);F.current=setTimeout(()=>{I0(!1),F.current=null},3000)}else if(I0(!1),F.current)clearTimeout(F.current),F.current=null;return()=>{if(F.current)clearTimeout(F.current)}},[C]);let R=`${X}/stream.mjpeg`,v=w(O);v.current=O,x(()=>{v.current?.(h)},[h]),x(()=>{if(A&&$)K0($)},[A,$]);let T=w(!1);T.current=h;let i=w(null);x(()=>{if(!A||!z)return;return z((V)=>{G0.current++,e.current=Date.now();let H=I.current;if(H){if(i.current)URL.revokeObjectURL(i.current);i.current=V,H.src=V}if(!T.current)E(!0),Q0(null)})},[A,z]);let m=j((V)=>{if(A){K?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify(V)),U=new Uint8Array(1+L.length);U[0]=U6,U.set(L,1),H.send(U)},[A,K]),Z0=j((V)=>{if(A){G?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify({button:V})),U=new Uint8Array(1+L.length);U[0]=B6,U.set(L,1),H.send(U)},[A,G]),y=j((V)=>{if(A){W?.(V);return}let H=M.current;if(!H||H.readyState!==WebSocket.OPEN)return;let L=new TextEncoder().encode(JSON.stringify(V)),U=new Uint8Array(1+L.length);U[0]=_6,U.set(L,1),H.send(U)},[A,W]);x(()=>{if(A)return;fetch(`${X}/config`).then((D)=>D.json()).then((D)=>{if(D.width>0&&D.height>0)K0(D)}).catch(()=>{});let V=Z??X.replace(/^http/,"ws")+"/ws",H=new WebSocket(V);H.binaryType="arraybuffer",M.current=H,H.onopen=()=>{E(!0),Q0(null)},H.onclose=()=>{E(!1)},H.onerror=()=>{Q0("WebSocket connection failed"),E(!1)};let L=new AbortController,U=setInterval(()=>{v0(G0.current),G0.current=0},1000);return(async()=>{try{let b=(await fetch(R,{signal:L.signal})).body?.getReader();if(!b)return;let o=new TextEncoder().encode("--frame");while(!0){let{done:X0,value:q0}=await b.read();if(X0)break;if(q0)for(let Q4=0;Q4<=q0.length-o.length;Q4++){let w4=!0;for(let x0=0;x0<o.length;x0++)if(q0[Q4+x0]!==o[x0]){w4=!1;break}if(w4)G0.current++}}}catch{}})(),()=>{L.abort(),clearInterval(U),H.close(),M.current=null}},[X,R,A]);let e=w(0);x(()=>{if(!A)return;let V=2000,H=()=>{let D=e.current;if(!D||!T.current)return;if(Date.now()-D>V)E(!1)},L=setInterval(()=>{v0(G0.current),G0.current=0,H()},1000),U=()=>{if(!document.hidden)H()};return document.addEventListener("visibilitychange",U),()=>{clearInterval(L),document.removeEventListener("visibilitychange",U)}},[A]);let a=j(()=>{return A?I.current:k.current},[A]),V0=j((V,H)=>{let L=a();if(!L)return;let U=L.getBoundingClientRect(),D=(H.clientX-U.left)/U.width,b=(H.clientY-U.top)/U.height;m({type:V,x:D,y:b})},[m]),J0=3,l=w(!1),u=w(!1),U0=w(!1),M0=w({dx:0,dy:0}),C0=w(!1),[Y4,k4]=S(!1),I4=w({x:0.5,y:0.5}),[H0,Y0]=S(null);x(()=>{let V=(L)=>{if(L.key==="Alt")k4(!0)},H=(L)=>{if(L.key==="Alt"){if(k4(!1),!u.current)Y0(null)}};return window.addEventListener("keydown",V),window.addEventListener("keyup",H),()=>{window.removeEventListener("keydown",V),window.removeEventListener("keyup",H)}},[]),x(()=>{if(Y4&&!u.current){let V=I4.current;Y0({x1:V.x,y1:V.y,x2:1-V.x,y2:1-V.y})}else if(!Y4&&!u.current)Y0(null)},[Y4]);let y0=w(null),q4=w(!1),E0=w(0),M4=j((V,H)=>{q4.current=!0;let L=y0.current;if(L)cancelAnimationFrame(E0.current),E0.current=requestAnimationFrame(()=>{L.style.left=`${V*100}%`,L.style.top=`${H*100}%`,L.style.display="block"})},[]),C4=j((V,H)=>{if(!q4.current)return;let L=y0.current;if(L)cancelAnimationFrame(E0.current),E0.current=requestAnimationFrame(()=>{L.style.left=`${V*100}%`,L.style.top=`${H*100}%`})},[]),p0=j(()=>{q4.current=!1;let V=y0.current;if(V)cancelAnimationFrame(E0.current),V.style.display="none"},[]),E4=w(0),w0=w(null),g5=j(()=>{let V=Date.now(),H=V-E4.current;if(E4.current=V,H<300){if(w0.current)clearTimeout(w0.current),w0.current=null;if(Q)Q();else Z0("app_switcher")}else w0.current=setTimeout(()=>{if(Q)Q();else Z0("home");w0.current=null},300)},[Z0,Q]),g0=(()=>{if(!g||!r)return null;if(r.width===0||r.height===0)return null;let V=Math.min(r.width/g.width,r.height/g.height);return{width:g.width*V,height:g.height*V}})();return N("div",{style:{display:"flex",flexDirection:"column",flex:1,..._?{}:{border:"1px solid rgba(255,255,255,0.12)"},overflow:"hidden",minWidth:0,minHeight:0,...J},className:q,children:[N("div",{ref:s,style:{position:"relative",flex:1,minHeight:0,minWidth:0,display:"flex",alignItems:"center",justifyContent:"center"},children:N("div",{style:{position:"relative",width:g0?`${g0.width}px`:"100%",height:g0?`${g0.height}px`:"100%"},children:[N("img",{ref:k,src:A?void 0:R,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)K0((L)=>L&&L.width===H.naturalWidth&&L.height===H.naturalHeight?L:{width:H.naturalWidth,height:H.naturalHeight})},style:A?{display:"none"}:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:F4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...Y}}),A&&N("img",{ref:I,draggable:!1,onLoad:(V)=>{let H=V.currentTarget;if(H.naturalWidth>0&&H.naturalHeight>0)K0((L)=>L&&L.width===H.naturalWidth&&L.height===H.naturalHeight?L:{width:H.naturalWidth,height:H.naturalHeight})},style:{position:"absolute",inset:0,width:"100%",height:"100%",cursor:F4,display:"block",userSelect:"none",WebkitUserSelect:"none",touchAction:"none",...Y}}),N("div",{style:{position:"absolute",inset:0,cursor:F4,touchAction:"none"},onMouseDown:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(V.altKey){u.current=!0,U0.current=V.shiftKey;let b={x1:U,y1:D,x2:1-U,y2:1-D};M0.current={dx:1-U-U,dy:1-D-D},Y0(b),y({type:"begin",...b});return}if(M4(U,D),D>0.88)l.current=!0,m({type:"begin",x:U,y:D,edge:J0});else l.current=!1,V0("begin",V)},onMouseMove:(V)=>{let H=a();if(!H)return;let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(I4.current={x:U,y:D},V.buttons===0){if(V.altKey)Y0({x1:U,y1:D,x2:1-U,y2:1-D});return}if(u.current){let b;if(U0.current){let o=M0.current;b={x1:U,y1:D,x2:U+o.dx,y2:D+o.dy}}else b={x1:U,y1:D,x2:1-U,y2:1-D};Y0(b),y({type:"move",...b});return}if(C4(U,D),l.current)m({type:"move",x:U,y:D,edge:J0});else V0("move",V)},onMouseUp:(V)=>{if(u.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;if(U0.current){let b=M0.current;y({type:"end",x1:U,y1:D,x2:U+b.dx,y2:D+b.dy})}else y({type:"end",x1:U,y1:D,x2:1-U,y2:1-D})}if(u.current=!1,!V.altKey)Y0(null);return}if(p0(),l.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;m({type:"end",x:U,y:D,edge:J0})}l.current=!1;return}V0("end",V)},onMouseLeave:(V)=>{if(u.current){if(H0)y({type:"end",...H0});u.current=!1,Y0(null);return}if(p0(),l.current){let H=a();if(H){let L=H.getBoundingClientRect(),U=(V.clientX-L.left)/L.width,D=(V.clientY-L.top)/L.height;m({type:"end",x:U,y:D,edge:J0})}l.current=!1;return}if(V.buttons>0)V0("end",V);Y0(null)},onTouchStart:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(V.touches.length>=2){p0();let o=V.touches[0],X0=V.touches[1],q0={x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:(X0.clientX-L.left)/L.width,y2:(X0.clientY-L.top)/L.height};if(!C0.current&&!l.current)m({type:"end",x:q0.x1,y:q0.y1});C0.current=!0,u.current=!0,l.current=!1,Y0(q0),y({type:"begin",...q0});return}let U=V.touches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(M4(D,b),b>0.88)l.current=!0,m({type:"begin",x:D,y:b,edge:J0});else l.current=!1,m({type:"begin",x:D,y:b})},onTouchMove:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(C0.current&&V.touches.length>=2){let o=V.touches[0],X0=V.touches[1],q0={x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:(X0.clientX-L.left)/L.width,y2:(X0.clientY-L.top)/L.height};Y0(q0),y({type:"move",...q0});return}let U=V.touches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(C4(D,b),l.current)m({type:"move",x:D,y:b,edge:J0});else m({type:"move",x:D,y:b})},onTouchEnd:(V)=>{V.preventDefault();let H=a();if(!H)return;let L=H.getBoundingClientRect();if(C0.current){if(V.touches.length<2){let o=V.changedTouches[0],X0=H0;if(o&&X0)y({type:"end",x1:(o.clientX-L.left)/L.width,y1:(o.clientY-L.top)/L.height,x2:X0.x2,y2:X0.y2});else if(X0)y({type:"end",...X0});C0.current=!1,u.current=!1,Y0(null)}return}let U=V.changedTouches[0];if(!U)return;let D=(U.clientX-L.left)/L.width,b=(U.clientY-L.top)/L.height;if(p0(),l.current)m({type:"end",x:D,y:b,edge:J0}),l.current=!1;else m({type:"end",x:D,y:b})}}),N("div",{ref:y0,"data-testid":"touch-indicator",style:{position:"absolute",display:"none",width:24,height:24,borderRadius:"50%",background:"rgba(59,130,246,0.5)",boxShadow:"0 0 8px rgba(59,130,246,0.3)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}),H0&&N(d,{children:[N("div",{"data-testid":"finger-dot",style:R5(H0.x1,H0.y1)}),N("div",{"data-testid":"finger-dot",style:R5(H0.x2,H0.y2)})]}),!h&&!n&&N("div",{style:b5,children:N("span",{style:{color:"#888",fontSize:14},children:"Connecting..."})}),n&&N("div",{style:b5,children:N("span",{style:{color:"#f44",fontSize:14,padding:20,textAlign:"center"},children:n})}),J4&&N("div",{style:F6,children:N("span",{style:{color:"#fbbf24",fontSize:13,fontFamily:"monospace"},children:"Slow connection"})})]})}),!_&&N("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"4px 8px",borderTop:"1px solid rgba(255,255,255,0.12)"},children:[N("button",{onClick:g5,style:{background:"none",border:"1px solid rgba(255,255,255,0.2)",color:"#aaa",fontSize:11,fontFamily:"monospace",padding:"2px 10px",cursor:"pointer",borderRadius:4},children:"Home"}),N("span",{style:{color:j0>0?"#4f4":"#888",fontSize:12,fontFamily:"monospace",display:"flex",alignItems:"center",gap:6},children:[C&&N("span",{"data-testid":"quality-dot",style:{width:8,height:8,borderRadius:"50%",display:"inline-block",background:C==="good"?"#4ade80":C==="degraded"?"#facc15":"#ef4444"}}),j0," fps"]})]})]})}var F6={position:"absolute",top:8,left:"50%",transform:"translateX(-50%)",background:"rgba(0,0,0,0.7)",borderRadius:6,padding:"4px 12px",pointerEvents:"none"},b5={position:"absolute",inset:0,display:"flex",alignItems:"center",justifyContent:"center",background:"rgba(0,0,0,0.8)"},S5=20;function R5(X,Z){return{position:"absolute",left:`${X*100}%`,top:`${Z*100}%`,width:S5,height:S5,borderRadius:"50%",background:"rgba(255,255,255,0.4)",border:"1px solid rgba(255,255,255,0.7)",transform:"translate(-50%, -50%)",pointerEvents:"none"}}function k0(X){if(!X)return"iphone";let Z=X.toLowerCase();if(Z.includes("ipad"))return"ipad";if(Z.includes("watch"))return"watch";if(Z.includes("vision"))return"vision";return"iphone"}var $0={iphone:{width:427,height:881,bezelX:18,bezelY:18,innerRadius:55},ipad:{width:430,height:605,bezelX:16,bezelY:16,innerRadius:12},watch:{width:274,height:322,bezelX:12,bezelY:12,innerRadius:79},vision:{width:640,height:400,bezelX:12,bezelY:12,innerRadius:32}},w7=$0.iphone.width,T7=$0.iphone.height,b7=$0.iphone.bezelX,S7=$0.iphone.bezelY,R7=$0.iphone.innerRadius;function e0(X="iphone"){let Z=$0[X],J=Z.width-2*Z.bezelX,Y=Z.height-2*Z.bezelY;return`${Z.innerRadius/J*100}% / ${Z.innerRadius/Y*100}%`}var D4=_0(null);function X4(X){let Z=R0(D4);if(!Z)throw Error(`<SimulatorToolbar.${X}> must be rendered inside <SimulatorToolbar>`);return Z}var C6={display:"flex",flexWrap:"wrap",alignItems:"center",justifyContent:"space-between",gap:"4px 12px",padding:"8px 12px",borderRadius:24,background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.1)",boxShadow:"0 1px 2px rgba(0,0,0,0.2)",minWidth:240,width:"100%"};function E6({exec:X,deviceUdid:Z,deviceName:J,deviceRuntime:Y,streaming:q=!1,disabled:Q=!1,children:K,style:W,...G}){let z=k0(J),$={exec:X,deviceUdid:Z,deviceName:J,deviceRuntime:Y,deviceType:z,streaming:q,disabled:Q||!Z||!q};return N(D4.Provider,{value:$,children:N("div",{"data-simulator-toolbar":!0,style:{...C6,...W},...G,children:K})})}var w6={display:"flex",flexDirection:"column",alignItems:"flex-start",textAlign:"left",background:"transparent",border:"none",color:"#fff",padding:"2px 4px",margin:"-2px -4px",borderRadius:6,cursor:"pointer",minWidth:0,maxWidth:"100%",lineHeight:1.2,fontFamily:"inherit"},T6=D0(function({name:Z,subtitle:J,hideChevron:Y,style:q,onMouseEnter:Q,onMouseLeave:K,...W},G){let z=X4("Title"),[P,$]=S(!1),_=Z??z.deviceName??"No simulator",O=J??(z.deviceRuntime?z.deviceRuntime.replace(/\./," "):"—");return N("button",{ref:G,type:"button","data-simulator-toolbar-title":!0,onMouseEnter:(C)=>{$(!0),Q?.(C)},onMouseLeave:(C)=>{$(!1),K?.(C)},style:{...w6,background:P?"rgba(255,255,255,0.1)":"transparent",...q},...W,children:[N("span",{style:{display:"inline-flex",alignItems:"center",gap:4,fontSize:12,fontWeight:600,color:"#fff",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:[_,!Y&&N("svg",{width:"10",height:"10",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",strokeLinecap:"round",strokeLinejoin:"round",style:{color:"rgba(255,255,255,0.6)",flexShrink:0},children:N("polyline",{points:"6 9 12 15 18 9"})})]}),N("span",{style:{fontSize:10,color:"rgba(255,255,255,0.5)",maxWidth:"100%",overflow:"hidden",textOverflow:"ellipsis",whiteSpace:"nowrap"},children:O})]})}),b6={display:"flex",alignItems:"center",gap:4,flexShrink:0};function S6({style:X,...Z}){return N("div",{style:{...b6,...X},...Z})}var R6={background:"transparent",border:"none",padding:6,borderRadius:6,cursor:"pointer",display:"inline-flex",alignItems:"center",justifyContent:"center",color:"rgba(255,255,255,0.8)",transition:"background-color 0.15s, color 0.15s"},Z4=D0(function({forceDisabled:Z,style:J,disabled:Y,onMouseEnter:q,onMouseLeave:Q,children:K,...W},G){let z=R0(D4),P=Y||Z||z?.disabled,[$,_]=S(!1);return N("button",{ref:G,type:"button",disabled:P,onMouseEnter:(O)=>{_(!0),q?.(O)},onMouseLeave:(O)=>{_(!1),Q?.(O)},style:{...R6,color:P?"rgba(255,255,255,0.25)":"rgba(255,255,255,0.8)",background:$&&!P?"rgba(255,255,255,0.1)":"transparent",cursor:P?"not-allowed":"pointer",...J},...W,children:K})});function j6(){return['tell application "System Events" to tell process "Simulator" to set frontmost to true','tell application "System Events" to tell process "Simulator" to perform action "AXRaise" of (first window whose name contains "watchOS")','tell application "System Events" to tell process "Simulator" to click menu item "Home" of menu "Device" of menu bar item "Device" of menu bar 1'].map((Z)=>`-e '${Z}'`).reduce((Z,J)=>`${Z} ${J}`,"osascript")}var v6=N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:N("path",{d:"M3 10.5 12 3l9 7.5V20a1 1 0 0 1-1 1h-5v-7h-6v7H4a1 1 0 0 1-1-1z"})}),y6=N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[N("path",{d:"M14.5 4h-5L7 7H4a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2h-3z"}),N("circle",{cx:"12",cy:"13",r:"4"})]}),p6=N("svg",{width:"18",height:"18",viewBox:"0 0 12 13",fill:"currentColor",xmlns:"http://www.w3.org/2000/svg",children:N("path",{d:"M10.2305 12.8077H4.42383C3.92383 12.8077 3.54688 12.6846 3.29297 12.4385C3.04297 12.1963 2.91797 11.8194 2.91797 11.3077V5.51274C2.91797 4.99711 3.04297 4.61821 3.29297 4.37602C3.54688 4.12993 3.92383 4.00688 4.42383 4.00688H10.2305C10.7344 4.00688 11.1113 4.12993 11.3613 4.37602C11.6113 4.61821 11.7363 4.99711 11.7363 5.51274V11.3077C11.7363 11.8194 11.6113 12.1963 11.3613 12.4385C11.1113 12.6846 10.7344 12.8077 10.2305 12.8077ZM10.2129 11.8643C10.416 11.8643 10.5625 11.8194 10.6523 11.7295C10.7461 11.6436 10.793 11.4971 10.793 11.2901V5.52446C10.793 5.31743 10.7461 5.17094 10.6523 5.08501C10.5625 4.99516 10.416 4.95024 10.2129 4.95024H4.44141C4.24219 4.95024 4.0957 4.99516 4.00195 5.08501C3.9082 5.17094 3.86133 5.31743 3.86133 5.52446V11.2901C3.86133 11.4971 3.9082 11.6436 4.00195 11.7295C4.0957 11.8194 4.24219 11.8643 4.44141 11.8643H10.2129ZM2.91797 2.58305V0.415083C2.91797 0.20024 2.98633 0.0693803 3.12305 0.0225053C3.25977 -0.0282759 3.41016 0.00688033 3.57422 0.127974L5.05078 1.21196C5.17578 1.30571 5.23828 1.40141 5.23828 1.49907C5.23828 1.59672 5.17578 1.69243 5.05078 1.78618L3.57422 2.8643C3.41016 2.9854 3.25977 3.02251 3.12305 2.97563C2.98633 2.92485 2.91797 2.79399 2.91797 2.58305ZM3.5332 1.15336C3.62695 1.15336 3.70703 1.18657 3.77344 1.25297C3.84375 1.31938 3.87891 1.39751 3.87891 1.48735C3.87891 1.5811 3.84375 1.66313 3.77344 1.73344C3.70703 1.79985 3.62695 1.83305 3.5332 1.83305H2.80664C2.38086 1.83305 2.01172 1.92485 1.69922 2.10844C1.39062 2.28813 1.15234 2.53813 0.984375 2.85844C0.816406 3.17876 0.732422 3.54594 0.732422 3.96001V4.83891C0.732422 4.93657 0.697266 5.02251 0.626953 5.09672C0.552734 5.16704 0.464844 5.20219 0.363281 5.20219C0.265625 5.20219 0.181641 5.16704 0.111328 5.09672C0.0371094 5.02251 0 4.93657 0 4.83891V3.96001C0 3.40141 0.117188 2.91118 0.351562 2.4893C0.582031 2.06743 0.908203 1.7393 1.33008 1.50493C1.74805 1.27055 2.23828 1.15336 2.80078 1.15336H3.5332Z"})}),g6=D0(function({onClick:Z,...J},Y){let q=X4("HomeButton");return N(Z4,{ref:Y,"aria-label":"Home",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceType==="watch")q.exec(j6());else q.exec("serve-sim button home")},...J,children:v6})}),x6=D0(function({onClick:Z,...J},Y){let q=X4("ScreenshotButton");return N(Z4,{ref:Y,"aria-label":"Screenshot",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceUdid)q.exec(`xcrun simctl io ${q.deviceUdid} screenshot ~/Desktop/hatch-screenshot-$(date +%s).png`)},...J,children:y6})}),h6=D0(function({onClick:Z,...J},Y){let q=X4("RotateButton");return N(Z4,{ref:Y,"aria-label":"Rotate device",onClick:(Q)=>{if(Z?.(Q),Q.defaultPrevented)return;if(q.deviceUdid)q.exec(`osascript -e 'tell application "Simulator" to activate' -e 'tell application "System Events" to key code 124 using {command down}'`)},...J,children:p6})}),t=E6;t.Title=T6;t.Actions=S6;t.Button=Z4;t.HomeButton=g6;t.ScreenshotButton=x6;t.RotateButton=h6;function m6(X){let[Z,J]=S(null),Y=w(new Set),[q,Q]=S(null),K=j((W)=>{return Y.current.add(W),()=>{Y.current.delete(W)}},[]);return x(()=>{if(!X)return;let W=new AbortController,G=X.replace(/\/stream\.mjpeg$/,"");return fetch(`${G}/config`,{signal:W.signal}).then((z)=>z.json()).then((z)=>{if(z.width>0&&z.height>0)J(z)}).catch(()=>{}),(async()=>{try{let P=(await fetch(X,{signal:W.signal})).body?.getReader();if(!P)return;let $=new Uint8Array(0);while(!0){let{done:_,value:O}=await P.read();if(_)break;let C=new Uint8Array($.length+O.length);C.set($),C.set(O,$.length),$=C;while(!0){let A=-1;for(let E=0;E<$.length-1;E++)if($[E]===255&&$[E+1]===216){A=E;break}if(A===-1)break;let k=-1;for(let E=A+2;E<$.length-1;E++)if($[E]===255&&$[E+1]===217){k=E+2;break}if(k===-1)break;let I=$.slice(A,k);$=$.slice(k);let M=new Blob([I],{type:"image/jpeg"}),h=URL.createObjectURL(M);Q(h);for(let E of Y.current)E(h)}}}catch{}})(),()=>W.abort()},[X]),{subscribeFrame:K,frame:q,config:Z}}var d6={KeyA:4,KeyB:5,KeyC:6,KeyD:7,KeyE:8,KeyF:9,KeyG:10,KeyH:11,KeyI:12,KeyJ:13,KeyK:14,KeyL:15,KeyM:16,KeyN:17,KeyO:18,KeyP:19,KeyQ:20,KeyR:21,KeyS:22,KeyT:23,KeyU:24,KeyV:25,KeyW:26,KeyX:27,KeyY:28,KeyZ:29,Digit1:30,Digit2:31,Digit3:32,Digit4:33,Digit5:34,Digit6:35,Digit7:36,Digit8:37,Digit9:38,Digit0:39,Enter:40,Escape:41,Backspace:42,Tab:43,Space:44,Minus:45,Equal:46,BracketLeft:47,BracketRight:48,Backslash:49,Semicolon:51,Quote:52,Backquote:53,Comma:54,Period:55,Slash:56,CapsLock:57,F1:58,F2:59,F3:60,F4:61,F5:62,F6:63,F7:64,F8:65,F9:66,F10:67,F11:68,F12:69,PrintScreen:70,ScrollLock:71,Pause:72,Insert:73,Home:74,PageUp:75,Delete:76,End:77,PageDown:78,ArrowRight:79,ArrowLeft:80,ArrowDown:81,ArrowUp:82,NumLock:83,NumpadDivide:84,NumpadMultiply:85,NumpadSubtract:86,NumpadAdd:87,NumpadEnter:88,Numpad1:89,Numpad2:90,Numpad3:91,Numpad4:92,Numpad5:93,Numpad6:94,Numpad7:95,Numpad8:96,Numpad9:97,Numpad0:98,NumpadDecimal:99,ControlLeft:224,ShiftLeft:225,AltLeft:226,MetaLeft:227,ControlRight:228,ShiftRight:229,AltRight:230,MetaRight:231};function f6(X){return d6[X]??null}async function A0(X){return(await fetch("/exec",{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({command:X})})).json()}function a6(X){try{let Z=JSON.parse(X),J=[];for(let[Y,q]of Object.entries(Z.devices??{})){let Q=Y.replace(/^com\.apple\.CoreSimulator\.SimRuntime\./,"").replace(/-/g,".");for(let K of q)if(K.isAvailable)J.push({udid:K.udid,name:K.name,state:K.state,runtime:Q})}return J}catch{return[]}}function j5(X){let Z=X.toLowerCase();if(Z.includes("iphone"))return 0;if(Z.includes("ipad"))return 1;if(Z.includes("watch"))return 2;if(Z.includes("vision"))return 3;return 4}function v5(X){let Z=X.toLowerCase();if(Z.startsWith("ios"))return 0;if(Z.startsWith("ipados"))return 1;if(Z.startsWith("watchos"))return 2;if(Z.startsWith("visionos")||Z.startsWith("xros"))return 3;return 4}function l6({devices:X,selectedUdid:Z,loading:J,error:Y,stoppingUdids:q,onRefresh:Q,onSelect:K,onStop:W,trigger:G}){let[z,P]=S(!1),$=w(null);x(()=>{if(!z)return;let A=(k)=>{if(!$.current?.contains(k.target))P(!1)};return window.addEventListener("mousedown",A),()=>window.removeEventListener("mousedown",A)},[z]);let _=new Map;for(let A of X){if(A.udid===Z)continue;let k=_.get(A.runtime);if(!k)k=[],_.set(A.runtime,k);k.push(A)}for(let A of _.values())A.sort((k,I)=>j5(k.name)-j5(I.name)||k.name.localeCompare(I.name));let O=[..._.entries()].sort(([A],[k])=>v5(A)-v5(k)||A.localeCompare(k)),C=X.find((A)=>A.udid===Z)??null;return N("div",{ref:$,style:{position:"relative"},children:[N("div",{onClick:()=>{if(!z)Q();P((A)=>!A)},children:G}),z&&N("div",{style:i6,children:[N("div",{style:u6,children:[N("span",{style:{fontWeight:600},children:"Simulators"}),N("button",{onClick:(A)=>{A.stopPropagation(),Q()},disabled:J,style:o6,children:J?"...":"Refresh"})]}),Y&&N("div",{style:s6,children:Y}),C&&N(d,{children:[N("div",{style:{...p5,color:"#a5b4fc"},children:[N("span",{style:y5(C.state==="Booted"?"#4ade80":"#444")}),N("span",{style:{flex:1},children:C.name})]}),N("div",{style:r6})]}),X.length===0&&!J&&!Y&&N("div",{style:t6,children:"No available simulators found"}),O.map(([A,k])=>N("div",{children:[N("div",{style:n6,children:A}),k.map((I)=>{let M=q.has(I.udid),h=I.state==="Booted";return N("div",{style:p5,onMouseEnter:(E)=>E.currentTarget.style.background="rgba(255,255,255,0.08)",onMouseLeave:(E)=>E.currentTarget.style.background="transparent",onClick:()=>{K(I),P(!1)},children:[N("span",{style:y5(h?"#4ade80":"#444")}),N("span",{style:{flex:1},children:I.name}),h&&N("span",{role:"button",onClick:(E)=>{if(E.stopPropagation(),!M)W(I.udid)},style:{fontSize:10,padding:"1px 6px",borderRadius:4,color:M?"#888":"#f87171",background:M?"transparent":"rgba(248,113,113,0.1)",cursor:M?"default":"pointer"},children:M?"Stopping...":"Stop"})]},I.udid)})]},A))]})]})}function y5(X){return{width:6,height:6,borderRadius:"50%",background:X,flexShrink:0}}function c6(){let X=window.__SIM_PREVIEW__,[Z,J]=S(!1),[Y,q]=S([]),[Q,K]=S(!1),[W,G]=S(null),[z,P]=S(new Set),[$,_]=S(!1),O=j(async()=>{K(!0),G(null);try{let F=await A0("xcrun simctl list devices available -j");if(F.exitCode!==0)throw Error(F.stderr||"simctl list failed");q(a6(F.stdout))}catch(F){G(F instanceof Error?F.message:"Failed to list devices")}finally{K(!1)}},[]);if(x(()=>{O()},[O]),x(()=>{if(!X?.logsEndpoint)return;let F=new EventSource(X.logsEndpoint),R=new Map,v=["#8be9fd","#50fa7b","#ffb86c","#ff79c6","#bd93f9","#f1fa8c","#6272a4","#ff5555","#69ff94","#d6acff","#ffffa5","#a4ffff","#ff6e6e","#caa9fa","#5af78e"];function T(Z0){let y=R.get(Z0);if(!y){let e=0;for(let a=0;a<Z0.length;a++)e=(e<<5)-e+Z0.charCodeAt(a)|0;y=v[Math.abs(e)%v.length],R.set(Z0,y)}return y}let i="",m=!1;return F.onmessage=(Z0)=>{try{let y=JSON.parse(Z0.data),e=y.processImagePath?.split("/").pop()??y.senderImagePath?.split("/").pop()??"",a=y.subsystem??"",V0=y.category??"",J0=y.eventMessage??"";if(!J0)return;if(e!==i){if(m)console.groupEnd();let M0=T(e);console.groupCollapsed(`%c${e}${a?` %c${a}${V0?":"+V0:""}`:""}`,`color:${M0};font-weight:bold`,...a?["color:#888;font-weight:normal"]:[]),m=!0,i=e}let l=(y.messageType??"").toLowerCase(),u=a&&e===i?`%c${V0||a}%c `:"",U0=u?["color:#888;font-style:italic","color:inherit"]:[];if(l==="fault"||l==="error")console.log(`${u}%c${J0}`,...U0,"color:#ff5555");else if(l==="debug")console.log(`${u}%c${J0}`,...U0,"color:#6272a4");else console.log(`${u}%c${J0}`,...U0,"color:inherit")}catch{}},()=>{if(m)console.groupEnd();F.close()}},[X?.logsEndpoint]),!X)return N("div",{style:N0.page,children:N("div",{style:N0.empty,children:[N("h1",{style:N0.emptyTitle,children:"No serve-sim stream running"}),N("p",{style:N0.emptyHint,children:["Boot an iOS simulator and start a Hatch stream with"," ",N("code",{style:N0.code,children:"bunx serve-sim --detach"}),", then reload."]})]})});let C=Y.find((F)=>F.udid===X.device)??null,A=k0(C?.name),k=$0[A],I=k.width-2*k.bezelX,M=k.height-2*k.bezelY,h=e0(A),E=A==="vision"?580:A==="ipad"?400:A==="watch"?200:320,n=m6(X.streamUrl),Q0=w(null);x(()=>{let F=new WebSocket(X.wsUrl);return F.binaryType="arraybuffer",Q0.current=F,()=>{F.close(),Q0.current=null}},[X.wsUrl]);let g=j((F,R)=>{let v=Q0.current;if(!v||v.readyState!==WebSocket.OPEN)return;let T=new TextEncoder().encode(JSON.stringify(R)),i=new Uint8Array(1+T.length);i[0]=F,i.set(T,1),v.send(i)},[]),K0=j((F)=>g(3,F),[g]),s=j((F)=>g(5,F),[g]),r=j((F)=>g(4,{button:F}),[g]),O0=j((F,R)=>{g(6,{type:F,usage:R})},[g]),[j0,v0]=S(null);x(()=>{let F=new EventSource("/appstate"),R=null;return F.onmessage=(v)=>{try{let T=JSON.parse(v.data);if(R)clearTimeout(R);let i=T?.isReactNative?0:600;R=setTimeout(()=>v0(T),i)}catch{}},()=>{if(R)clearTimeout(R);F.close()}},[]);let G0=j(async()=>{O0("down",227),await new Promise((v)=>setTimeout(v,30)),O0("down",21),await new Promise((v)=>setTimeout(v,30)),O0("up",21),await new Promise((v)=>setTimeout(v,30)),O0("up",227)},[O0]);x(()=>{let F=(T,i)=>{if(T.code==="KeyH"&&T.metaKey&&T.shiftKey){if(T.preventDefault(),i==="down"&&!T.repeat)g(4,{button:"home"});return}if(T.code==="KeyA"&&T.metaKey&&T.shiftKey){if(T.preventDefault(),i==="down"&&!T.repeat)A0(`xcrun simctl ui ${X.device} appearance`).then((Z0)=>{let y=Z0.stdout.trim()==="dark"?"light":"dark";return A0(`xcrun simctl ui ${X.device} appearance ${y}`)}).catch(()=>{});return}let m=f6(T.code);if(m==null)return;T.preventDefault(),g(6,{type:i,usage:m})},R=(T)=>F(T,"down"),v=(T)=>F(T,"up");return window.addEventListener("keydown",R),window.addEventListener("keyup",v),()=>{window.removeEventListener("keydown",R),window.removeEventListener("keyup",v)}},[g,X.device]);let J4=j(async(F)=>{if($||F.udid===X.device)return;_(!0);try{if(F.state!=="Booted")await A0(`xcrun simctl boot ${F.udid}`);await A0(`bunx serve-sim --kill ${X.device}`),await A0(`bunx serve-sim --detach ${F.udid}`),window.location.reload()}catch{_(!1)}},[$,X.device]),I0=j(async(F)=>{P((R)=>new Set(R).add(F));try{await A0(`xcrun simctl shutdown ${F}`),await O()}finally{P((R)=>{let v=new Set(R);return v.delete(F),v})}},[O]);return N("div",{style:N0.page,children:[N(t,{exec:A0,deviceUdid:X.device,deviceName:C?.name??null,deviceRuntime:C?.runtime??null,streaming:Z,style:{maxWidth:E},children:[N(l6,{devices:Y,selectedUdid:X.device,loading:Q,error:W,stoppingUdids:z,onRefresh:O,onSelect:J4,onStop:I0,trigger:N(t.Title,{})}),N(t.Actions,{children:[j0?.isReactNative&&N(t.Button,{"aria-label":"Reload React Native bundle",title:"Reload (Cmd+R)",onClick:()=>void G0(),children:N("svg",{width:"18",height:"18",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[N("path",{d:"M3 12a9 9 0 1 0 3.5-7.1"}),N("polyline",{points:"3 3 3 9 9 9"})]})}),N(t.HomeButton,{onClick:(F)=>{F.preventDefault(),r("home")}}),N(t.ScreenshotButton,{}),N(t.RotateButton,{})]})]}),N("div",{style:{maxWidth:E,width:"100%",aspectRatio:`${I} / ${M}`},children:N(n0,{url:X.url,style:{width:"100%",height:"100%",border:"none"},imageStyle:{borderRadius:h,cornerShape:"superellipse(1.3)"},hideControls:!0,onStreamingChange:J,onStreamTouch:K0,onStreamMultiTouch:s,onStreamButton:r,subscribeFrame:n.subscribeFrame,streamFrame:n.frame,streamConfig:n.config})}),N("div",{style:N0.bar,children:N("span",{style:{...N0.live,color:Z?"#4ade80":"#666"},children:[N("span",{style:{...N0.dot,background:Z?"#4ade80":"#666"}}),Z?"live":"connecting"]})})]})}var N0={page:{display:"flex",flexDirection:"column",alignItems:"center",justifyContent:"center",height:"100vh",background:"#0a0a0a",padding:24,gap:12,fontFamily:"-apple-system, system-ui, sans-serif"},bar:{display:"flex",alignItems:"center",gap:10,fontSize:12,fontFamily:"ui-monospace, monospace",color:"#666"},live:{display:"flex",alignItems:"center",gap:5,transition:"color 0.3s"},dot:{width:6,height:6,borderRadius:"50%",transition:"background 0.3s"},empty:{display:"flex",flexDirection:"column",alignItems:"center",gap:12,textAlign:"center"},emptyTitle:{fontSize:18,margin:0,color:"#eee"},emptyHint:{color:"#888",fontSize:14,maxWidth:480},code:{background:"#222",padding:"2px 6px",borderRadius:4,fontSize:13}},i6={position:"absolute",top:"calc(100% + 6px)",left:0,minWidth:260,maxHeight:360,overflowY:"auto",background:"#1c1c1e",border:"1px solid rgba(255,255,255,0.12)",borderRadius:10,padding:4,boxShadow:"0 8px 24px rgba(0,0,0,0.5)",fontFamily:"ui-monospace, monospace",fontSize:13,color:"#eee",zIndex:20},u6={display:"flex",alignItems:"center",justifyContent:"space-between",padding:"6px 10px",fontSize:11,color:"#aaa"},o6={background:"transparent",border:"none",color:"#a5b4fc",fontSize:11,cursor:"pointer",padding:0},s6={padding:"6px 10px",color:"#f87171",fontSize:11},p5={display:"flex",alignItems:"center",gap:8,padding:"6px 10px",borderRadius:6,cursor:"pointer",transition:"background 0.15s"},r6={height:1,background:"rgba(255,255,255,0.08)",margin:"4px 0"},t6={padding:12,color:"rgba(255,255,255,0.4)",fontSize:11,textAlign:"center"},n6={padding:"6px 10px 2px",fontSize:10,fontWeight:600,color:"rgba(255,255,255,0.4)",textTransform:"uppercase",letterSpacing:"0.08em"};P5(document.getElementById("root")).render(N(c6,{}));
</script>
</body></html>","base64").toString("utf-8");return N}function Le(e){let _=(e?.basePath??"/.sim").replace(/\/+$/,"");return(t,s,r)=>{let C=t.url??"";if(C===_||C===_+"/"){let i=b()[0]??null,$=Ve();if(i){let a=`<script>window.__SIM_PREVIEW__=${JSON.stringify({...i,logsEndpoint:_+"/logs"})}</script>`;$=$.replace("<!--__SIM_PREVIEW_CONFIG__-->",a)}s.writeHead(200,{"Content-Type":"text/html; charset=utf-8","Cache-Control":"no-store"}),s.end($);return}if(C===_+"/api"){let o=b();s.writeHead(200,{"Content-Type":"application/json","Cache-Control":"no-store"}),s.end(JSON.stringify(o[0]||null));return}if((C===_+"/exec"||C===_+"/exec/")&&t.method==="POST"){let o="";t.on("data",(i)=>{o+=typeof i==="string"?i:i.toString()}),t.on("end",()=>{let i="";try{i=JSON.parse(o).command??""}catch{}if(!i){s.writeHead(400,{"Content-Type":"application/json"}),s.end(JSON.stringify({stdout:"",stderr:"Missing command",exitCode:1}));return}we(i,{maxBuffer:16777216},($,S,a)=>{s.writeHead(200,{"Content-Type":"application/json"}),s.end(JSON.stringify({stdout:S.toString(),stderr:a.toString(),exitCode:$?$.code??1:0}))})});return}if(C===_+"/logs"||C.startsWith(_+"/logs?")){let o=b();if(o.length===0){s.writeHead(404),s.end("No serve-sim device");return}let i=o[0].device;s.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),s.write(`:
|
|
4
4
|
|
|
5
|
-
`);let
|
|
6
|
-
`))!==-1){let
|
|
5
|
+
`);let $=U("xcrun",["simctl","spawn",i,"log","stream","--style","ndjson","--level","info"],{stdio:["ignore","pipe","ignore"]}),S="";$.stdout.on("data",(a)=>{S+=a.toString();let n;while((n=S.indexOf(`
|
|
6
|
+
`))!==-1){let y=S.slice(0,n).trim();if(S=S.slice(n+1),y)s.write("data: "+y+`
|
|
7
7
|
|
|
8
|
-
`)}})
|
|
9
|
-
|
|
10
|
-
`)
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
8
|
+
`)}}),$.on("close",()=>s.end()),t.on("close",()=>$.kill());return}if(C===_+"/appstate"||C.startsWith(_+"/appstate?")){let o=b();if(o.length===0){s.writeHead(404),s.end("No serve-sim device");return}let i=o[0].device;s.writeHead(200,{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive","X-Accel-Buffering":"no"}),s.write(`:
|
|
9
|
+
|
|
10
|
+
`);let $=U("xcrun",["simctl","spawn",i,"log","stream","--style","ndjson","--level","info","--predicate",'process == "SpringBoard" AND eventMessage CONTAINS "Setting process visibility to: Foreground"'],{stdio:["ignore","pipe","ignore"]}),S=/\[app<([^>]+)>:(\d+)\] Setting process visibility to: Foreground/,a="",n="";$.stdout.on("data",(y)=>{n+=y.toString();let A;while((A=n.indexOf(`
|
|
11
|
+
`))!==-1){let c=n.slice(0,A).trim();if(n=n.slice(A+1),!c)continue;let R;try{R=JSON.parse(c).eventMessage??""}catch{continue}let E=S.exec(R);if(!E)continue;let d=E[1],ce=parseInt(E[2],10);if(!He(d))continue;if(d===a)continue;a=d,Ne(i,d).then((Re)=>{s.write("data: "+JSON.stringify({bundleId:d,pid:ce,isReactNative:Re})+`
|
|
12
|
+
|
|
13
|
+
`)})}}),$.on("close",()=>s.end()),t.on("close",()=>$.kill());return}if(r)r()}}var k,he,Oe,me,N=null;var G=De(()=>{k=V(be(),"serve-sim"),he=new Set(["host.exp.Exponent","dev.expo.Exponent"]),Oe=["Frameworks/React.framework","Frameworks/hermes.framework","Frameworks/Hermes.framework","Frameworks/ExpoModulesCore.framework","main.jsbundle"],me=/(WidgetRenderer|ExtensionHost|\.extension(\.|$)|Service|PlaceholderApp|InCallService|CallUI|InCallUI|com\.apple\.Preferences\.Cellular|com\.apple\.purplebuddy|com\.apple\.chrono|com\.apple\.shuttle|com\.apple\.usernotificationsui)/i});import{execSync as f,spawn as j}from"child_process";import{chmodSync as We,existsSync as F,mkdirSync as z,openSync as Q,closeSync as J,readFileSync as O,unlinkSync as W,writeFileSync as Z}from"fs";import{createHash as Pe}from"crypto";import{homedir as qe,networkInterfaces as Me}from"os";import{join as Ie,resolve as L}from"path";import{tmpdir as Ee}from"os";import{join as g}from"path";import{readdirSync as de}from"fs";var T=g(Ee(),"serve-sim"),o_=g(T,"server.json");function w(e){return g(T,`server-${e}.json`)}function v(){try{return de(T).filter((e)=>e.startsWith("server-")&&e.endsWith(".json")).map((e)=>g(T,e))}catch{return[]}}var D="./serve-sim-bin-2vgfd507.";function I(){if(!F(T))z(T,{recursive:!0})}function p(e){if(e)return P(w(e));for(let _ of v()){let t=P(_);if(t)return t}return null}function P(e){try{if(!F(e))return null;let _=JSON.parse(O(e,"utf-8"));try{return process.kill(_.pid,0),_}catch{return W(e),null}}catch{return null}}function m(){let e=[];for(let _ of v()){let t=P(_);if(t)e.push(t)}return e}function x(e){I(),Z(w(e.device),JSON.stringify(e,null,2))}function u(e){if(e)try{W(w(e))}catch{}else for(let _ of v())try{W(_)}catch{}}function Ue(){let e=D.startsWith("/$bunfs/");if(!e&&F(D))return D;if(!e){let C=L(import.meta.dir,"../bin/serve-sim-bin");if(F(C))return C;throw Error(`serve-sim-bin not found. Run 'bun run build:swift' first.
|
|
14
|
+
Checked: ${D}, ${C}`)}let _=O(D),t=Pe("sha256").update(_).digest("hex").slice(0,16),s=L(qe(),"Library/Caches/serve-sim");z(s,{recursive:!0});let r=L(s,`serve-sim-bin-${t}`);if(!F(r)){Z(r,_),We(r,493);try{f(`codesign -s - -f ${JSON.stringify(r)}`,{stdio:"ignore"})}catch{}}return r}function Y(){try{let e=f("xcrun simctl list devices booted -j",{encoding:"utf-8"}),_=JSON.parse(e);for(let t of Object.values(_.devices))for(let s of t)if(s.state==="Booted")return s.udid}catch{}return null}function K(e){try{let _=f("xcrun simctl list devices -j",{encoding:"utf-8"}),t=JSON.parse(_);for(let s of Object.values(t.devices))for(let r of s)if(r.udid===e)return r.name}catch{}return null}function H(e){if(/^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i.test(e))return e;try{let _=f("xcrun simctl list devices -j",{encoding:"utf-8"}),t=JSON.parse(_);for(let s of Object.values(t.devices))for(let r of s)if(r.name.toLowerCase()===e.toLowerCase())return r.udid}catch{}console.error(`Could not resolve device: ${e}`),process.exit(1)}function ee(e){try{let _=f("xcrun simctl list devices -j",{encoding:"utf-8"}),t=JSON.parse(_);for(let s of Object.values(t.devices))for(let r of s)if(r.udid===e)return r.state==="Booted"}catch{}return!1}function q(e){try{return process.kill(e,0),!0}catch{return!1}}function M(e){try{process.kill(e,"SIGTERM")}catch{return}let _=Date.now()+500;while(Date.now()<_)try{process.kill(e,0),Bun.sleepSync(25)}catch{return}try{process.kill(e,"SIGKILL")}catch{}let t=Date.now()+500;while(Date.now()<t)try{process.kill(e,0),Bun.sleepSync(25)}catch{return}}function ke(e){try{let _=f(`lsof -ti tcp:${e}`,{encoding:"utf-8",stdio:"pipe"}).trim();if(!_)return[];let t=process.pid;return _.split(`
|
|
15
|
+
`).map((s)=>parseInt(s,10)).filter((s)=>Number.isFinite(s)&&s!==t)}catch{return[]}}function Xe(e){let _=ke(e);if(_.length===0)return;console.log(`\x1B[90mPort ${e} busy, killing holder pid(s): ${_.join(", ")}\x1B[0m`);for(let t of _)try{process.kill(t,"SIGKILL")}catch{}Bun.sleepSync(100)}function Ge(e){if(!ee(e))try{f(`xcrun simctl boot ${e}`,{encoding:"utf-8",stdio:"pipe"})}catch(_){let t=(_.stderr??_.message??"").toLowerCase();if(!t.includes("booted")&&!t.includes("current state"))throw Error(`Failed to boot device ${e}: ${_.stderr||_.message}`)}try{f("open -ga Simulator",{encoding:"utf-8",stdio:"pipe",timeout:3000})}catch{}}function xe(){let e=Me();for(let _ of Object.values(e))for(let t of _??[])if(t.family==="IPv4"&&!t.internal)return t.address;return null}async function _e(e){let _=new Set(m().map((t)=>t.port));for(let t=e;t<e+100;t++){if(_.has(t))continue;try{return Bun.serve({port:t,fetch:()=>new Response("ok")}).stop(!0),t}catch{continue}}throw Error(`No available port found in range ${e}-${e+99}`)}async function Ke(e){Ge(e);try{f(`xcrun simctl bootstatus ${e} -b`,{encoding:"utf-8",stdio:"pipe",timeout:60000})}catch(_){if(!ee(e))console.error(`Device ${e} failed to reach booted state: ${_.stderr||_.message}`),process.exit(1)}}async function te(e,_,t,s){let r=!1;for(let o=0;o<30;o++){if(!s())break;try{if((await fetch(`${_}/health`)).ok){r=!0;break}}catch{}await new Promise((i)=>setTimeout(i,100))}if(r){let o=Date.now()+8000;while(Date.now()<o){if(await new Promise((i)=>setTimeout(i,200)),!s()){r=!1;break}try{if(O(t,"utf-8").includes("Capture started"))break}catch{}}}let C="";try{C=O(t,"utf-8").trim()}catch{}return{ready:r,log:C}}async function je(e){let{helperPath:_,udid:t,port:s,host:r,logFile:C}=e,o=`http://${r}:${s}`;I();let i=Q(C,"w"),$=j(_,[t,"--port",String(s)],{detached:!0,stdio:["ignore",i,i]});$.unref(),J(i);let S=$.pid,a=!1;$.once("exit",()=>{a=!0});let{ready:n,log:y}=await te(S,o,C,()=>!a&&q(S));return{ready:n,pid:S,exited:a||!q(S),log:y}}async function ze(e){let{helperPath:_,udid:t,port:s,host:r,logFile:C}=e,o=`http://${r}:${s}`;I();let i=Q(C,"w"),$=j(_,[t,"--port",String(s)],{detached:!1,stdio:["ignore",i,i]});J(i);let S=$.pid,a=!1;$.once("exit",()=>{a=!0});let{ready:n,log:y}=await te(S,o,C,()=>!a&&q(S));return{ready:n,child:$,log:y}}async function se(e,_,t){await Ke(e);let s="127.0.0.1",r=Ue(),C=Ie(T,`server-${e}.log`),o={helperPath:r,udid:e,port:_,host:s,logFile:C},i="",$=2;for(let a=1;a<=$;a++){if(Xe(_),t.detach){let n=await je(o);if(n.ready){let y={pid:n.pid,port:_,device:e,url:`http://${s}:${_}`,streamUrl:`http://${s}:${_}/stream.mjpeg`,wsUrl:`ws://${s}:${_}/ws`};return x(y),{pid:n.pid}}M(n.pid),i=n.log}else{let n=await ze(o);if(n.ready){let y={pid:n.child.pid,port:_,device:e,url:`http://${s}:${_}`,streamUrl:`http://${s}:${_}/stream.mjpeg`,wsUrl:`ws://${s}:${_}/ws`};return x(y),{pid:n.child.pid,child:n.child}}M(n.child.pid),i=n.log}if(a<$)await new Promise((n)=>setTimeout(n,500))}let S=i?`Helper failed:
|
|
16
|
+
${i}`:"Helper process failed to start";console.error(S),process.exit(1)}async function Qe(e,_,t){let s=e.length>0?e.map(H):(()=>{let S=Y();if(!S)console.error("No device specified and no booted simulator found."),process.exit(1);return[S]})(),r=new Map,C=[],o=_;for(let S of s){let a=p(S);if(a){if(!t){let R=K(S)??S;if(s.length>1)console.log(`
|
|
17
|
+
==> ${R} (${S}) <==`);console.log(` Already running on port ${a.port}`),console.log(` Stream: ${a.streamUrl}`),console.log(` WebSocket: ${a.wsUrl}`)}C.push(a);continue}o=await _e(o);let{pid:n,child:y}=await se(S,o,{detach:!1});if(y)r.set(S,y);let A="127.0.0.1",c={pid:n,port:o,device:S,url:`http://${A}:${o}`,streamUrl:`http://${A}:${o}/stream.mjpeg`,wsUrl:`ws://${A}:${o}/ws`};if(C.push(c),!t){let R=K(S)??S;if(s.length>1)console.log(`
|
|
18
|
+
==> ${R} (${S}) <==`);console.log(` Stream: ${c.streamUrl}`),console.log(` WebSocket: ${c.wsUrl}`),console.log(` Port: ${o}`)}o++}if(C.length===1){let S=C[0];console.log(JSON.stringify({url:S.url,streamUrl:S.streamUrl,wsUrl:S.wsUrl,port:S.port,device:S.device}))}else console.log(JSON.stringify({devices:C.map((S)=>({url:S.url,streamUrl:S.streamUrl,wsUrl:S.wsUrl,port:S.port,device:S.device}))}));if(r.size===0)return;let i=!1,$=(S)=>{if(i)return;if(i=!0,!t)console.log(`
|
|
19
|
+
Shutting down...`);for(let[a,n]of r){let y=n.pid;if(y)M(y);u(a)}r.clear(),process.exit(S)};for(let[S,a]of r)a.on("exit",(n)=>{if(i)return;if(!t)console.error(`[${S}] Helper exited (code ${n})`);if(u(S),r.delete(S),r.size===0)$(n??1)});process.on("SIGINT",()=>$(0)),process.on("SIGTERM",()=>$(0)),process.on("SIGHUP",()=>$(0)),process.on("exit",()=>{for(let[S,a]of r){try{if(a.pid)process.kill(a.pid,"SIGTERM")}catch{}try{u(S)}catch{}}}),await new Promise(()=>{})}async function Se(e,_){let t=e.length>0?e.map(H):(()=>{let C=Y();if(!C)console.error("No device specified and no booted simulator found."),process.exit(1);return[C]})(),s=[],r=_;for(let C of t){let o=p(C);if(o){s.push(o);continue}r=await _e(r),await se(C,r,{detach:!0});let i="127.0.0.1";s.push({pid:p(C).pid,port:r,device:C,url:`http://${i}:${r}`,streamUrl:`http://${i}:${r}/stream.mjpeg`,wsUrl:`ws://${i}:${r}/ws`}),r++}return s}function Je(e){if(e.length===1){let _=e[0];console.log(JSON.stringify({url:_.url,streamUrl:_.streamUrl,wsUrl:_.wsUrl,port:_.port,device:_.device}))}else console.log(JSON.stringify({devices:e.map((_)=>({url:_.url,streamUrl:_.streamUrl,wsUrl:_.wsUrl,port:_.port,device:_.device}))}))}function Ze(e){if(e){let t=H(e),s=p(t);if(!s)console.log(JSON.stringify({running:!1,device:t}));else console.log(JSON.stringify({running:!0,url:s.url,streamUrl:s.streamUrl,wsUrl:s.wsUrl,port:s.port,device:s.device,pid:s.pid}));return}let _=m();if(_.length===0)console.log(JSON.stringify({running:!1}));else if(_.length===1){let t=_[0];console.log(JSON.stringify({running:!0,url:t.url,streamUrl:t.streamUrl,wsUrl:t.wsUrl,port:t.port,device:t.device,pid:t.pid}))}else console.log(JSON.stringify({running:!0,streams:_.map((t)=>({url:t.url,streamUrl:t.streamUrl,wsUrl:t.wsUrl,port:t.port,device:t.device,pid:t.pid}))}))}function Ye(e){if(e){let _=H(e),t=p(_);if(!t){console.log(JSON.stringify({disconnected:!0,device:_}));return}try{process.kill(t.pid,"SIGTERM")}catch{}u(_),console.log(JSON.stringify({disconnected:!0,device:t.device}))}else{let _=m();if(_.length===0){console.log(JSON.stringify({disconnected:!0,devices:[]}));return}let t=[];for(let s of _){try{process.kill(s.pid,"SIGTERM")}catch{}t.push(s.device)}u(),console.log(JSON.stringify({disconnected:!0,devices:t}))}}async function e_(e){let _,t=[];for(let o=0;o<e.length;o++)if(e[o]==="--device"||e[o]==="-d")_=e[++o];else t.push(e[o]);let s=p(_);if(!s)console.error("No serve-sim server running. Run `serve-sim` first."),process.exit(1);let r=t[0];if(!r)console.error("Usage: serve-sim gesture '<json>'"),console.error(`Example: serve-sim gesture '{"type":"begin","x":0.5,"y":0.5}'`),process.exit(1);let C;try{C=JSON.parse(r)}catch{console.error("Invalid JSON:",r),process.exit(1)}return new Promise((o,i)=>{let $=new WebSocket(s.wsUrl);$.binaryType="arraybuffer",$.onopen=()=>{let S=new TextEncoder().encode(JSON.stringify(C)),a=new Uint8Array(1+S.length);a[0]=3,a.set(S,1),$.send(a),setTimeout(()=>{$.close(),o()},50)},$.onerror=()=>{console.error("Failed to connect to serve-sim server at",s.wsUrl),i(Error("WebSocket connection failed"))}})}async function __(e){let _,t=[];for(let C=0;C<e.length;C++)if(e[C]==="--device"||e[C]==="-d")_=e[++C];else t.push(e[C]);let s=p(_);if(!s)console.error("No serve-sim server running. Run `serve-sim` first."),process.exit(1);let r=t[0]??"home";return new Promise((C,o)=>{let i=new WebSocket(s.wsUrl);i.binaryType="arraybuffer",i.onopen=()=>{let $=new TextEncoder().encode(JSON.stringify({button:r})),S=new Uint8Array(1+$.length);S[0]=4,S.set($,1),i.send(S),setTimeout(()=>{i.close(),C()},50)},i.onerror=()=>{console.error("Failed to connect to serve-sim server at",s.wsUrl),o(Error("WebSocket connection failed"))}})}async function t_(e,_,t){if(m().length===0)console.log("Starting simulator stream..."),await Se(_,3100);let{simMiddleware:r}=await Promise.resolve().then(() => (G(),X)),C=r({basePath:"/"}),o=t?1:50,i=e,$,S=!1;for(let n=0;n<o;n++){let y=e+n;try{s_(y,C),i=y,S=!0;break}catch(A){if($=A,A?.code!=="EADDRINUSE")break}}if(!S){if($?.code==="EADDRINUSE")if(t)console.error(`Port ${e} is already in use. Pass a different --port or stop the other process.`);else console.error(`No available port found in range ${e}-${e+o-1}.`);else console.error(`Failed to start preview server: ${$?.message??$}`);process.exit(1)}let a=xe();if(console.log(""),console.log(` - Local: http://localhost:${i}`),a)console.log(` - Network: http://${a}:${i}`);console.log(""),process.on("SIGINT",()=>process.exit(0)),process.on("SIGTERM",()=>process.exit(0)),await new Promise(()=>{})}function s_(e,_){return Bun.serve({port:e,idleTimeout:255,async fetch(t){return new Promise((s)=>{let r=new URL(t.url),C={url:r.pathname+r.search,method:t.method,headers:Object.fromEntries(t.headers.entries()),on(A,c){}},o=[];C.on=(A,c)=>{if(A==="close")o.push(c)},t.signal.addEventListener("abort",()=>{for(let A of o)A()});let i=200,$=new Headers,S=[],a=!1,n=null;_(C,{writeHead(A,c){if(i=A,c)for(let[R,E]of Object.entries(c))$.set(R,E)},setHeader(A,c){$.set(A,c)},get statusCode(){return i},set statusCode(A){i=A},write(A){if(!a){a=!0;let c=new ReadableStream({start(R){n=R}});s(new Response(c,{status:i,headers:$}))}try{n?.enqueue(typeof A==="string"?new TextEncoder().encode(A):A)}catch{}},end(A){if(a){if(A)try{n?.enqueue(typeof A==="string"?new TextEncoder().encode(A):A)}catch{}try{n?.close()}catch{}}else{if(A)S.push(A);let c=S.map((R)=>typeof R==="string"?R:new TextDecoder().decode(R)).join("");s(new Response(c,{status:i,headers:$}))}}},()=>{s(new Response("Not found",{status:404}))})})}})}function ie(){console.log(`
|
|
15
20
|
serve-sim - Stream iOS Simulator to the browser
|
|
16
21
|
|
|
17
22
|
Usage:
|
|
@@ -37,4 +42,4 @@ Examples:
|
|
|
37
42
|
serve-sim --detach Start streaming in background (daemon)
|
|
38
43
|
serve-sim --list Show all running streams
|
|
39
44
|
serve-sim --kill Stop all streams
|
|
40
|
-
`)}var
|
|
45
|
+
`)}var B=process.argv.slice(2);if(B[0]==="gesture")await e_(B.slice(1)),process.exit(0);if(B[0]==="button")await __(B.slice(1)),process.exit(0);var l,re=!1,Ce=!1,oe=!1,$e=!1,ne=!1,ae=!1,h=[],Ae,ye;for(let e=0;e<B.length;e++){let _=B[e];switch(_){case"--port":case"-p":l=parseInt(B[++e]??"3100",10);break;case"--detach":case"-d":re=!0;break;case"--quiet":case"-q":Ce=!0;break;case"--no-preview":ae=!0;break;case"--list":case"-l":if(oe=!0,B[e+1]&&!B[e+1].startsWith("-"))Ae=B[++e];break;case"--kill":case"-k":if($e=!0,B[e+1]&&!B[e+1].startsWith("-"))ye=B[++e];break;case"--help":case"-h":case"help":ne=!0;break;default:if(!_.startsWith("-"))h.push(_);else console.error(`Unknown flag: ${_}`),ie(),process.exit(1)}}if(ne)ie(),process.exit(0);if(oe)Ze(Ae),process.exit(0);if($e)Ye(ye),process.exit(0);if(re){let e=await Se(h,l??3100);Je(e)}else if(ae)await Qe(h,l??3100,Ce);else await t_(l??3200,h,l!==void 0);
|
package/package.json
CHANGED
|
@@ -1,7 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "serve-sim",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.2",
|
|
4
4
|
"type": "module",
|
|
5
|
+
"author": {
|
|
6
|
+
"name": "Evan Bacon",
|
|
7
|
+
"email": "baconbrix@gmail.com",
|
|
8
|
+
"url": "https://evanbacon.dev"
|
|
9
|
+
},
|
|
10
|
+
"license": "Apache-2.0",
|
|
5
11
|
"bin": {
|
|
6
12
|
"serve-sim": "dist/serve-sim.js"
|
|
7
13
|
},
|
package/src/middleware.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { readdirSync, readFileSync } from "fs";
|
|
2
|
-
import { spawn, type ChildProcess } from "child_process";
|
|
1
|
+
import { readdirSync, readFileSync, existsSync } from "fs";
|
|
2
|
+
import { spawn, exec, execFile, type ChildProcess } from "child_process";
|
|
3
3
|
import { tmpdir } from "os";
|
|
4
4
|
import { join } from "path";
|
|
5
5
|
|
|
@@ -16,6 +16,48 @@ interface ServeSimState {
|
|
|
16
16
|
wsUrl: string;
|
|
17
17
|
}
|
|
18
18
|
|
|
19
|
+
// Known bundle IDs that are always React Native shells (used as a fallback
|
|
20
|
+
// before the app-container path resolves, since simctl can lag after launch).
|
|
21
|
+
const RN_BUNDLE_IDS = new Set<string>([
|
|
22
|
+
"host.exp.Exponent", // Expo Go (App Store)
|
|
23
|
+
"dev.expo.Exponent", // Expo Go dev builds
|
|
24
|
+
]);
|
|
25
|
+
|
|
26
|
+
const RN_MARKERS = [
|
|
27
|
+
"Frameworks/React.framework",
|
|
28
|
+
"Frameworks/hermes.framework",
|
|
29
|
+
"Frameworks/Hermes.framework",
|
|
30
|
+
"Frameworks/ExpoModulesCore.framework",
|
|
31
|
+
"main.jsbundle",
|
|
32
|
+
];
|
|
33
|
+
|
|
34
|
+
// Processes that SpringBoard logs as "Foreground" but are not the visible
|
|
35
|
+
// user-facing app — widgets, extensions, background services. Emitting
|
|
36
|
+
// these to the client causes the app indicator to flicker as the user
|
|
37
|
+
// actually-foreground app switches mid-launch.
|
|
38
|
+
const NON_UI_BUNDLE_RE = /(WidgetRenderer|ExtensionHost|\.extension(\.|$)|Service|PlaceholderApp|InCallService|CallUI|InCallUI|com\.apple\.Preferences\.Cellular|com\.apple\.purplebuddy|com\.apple\.chrono|com\.apple\.shuttle|com\.apple\.usernotificationsui)/i;
|
|
39
|
+
|
|
40
|
+
function isUserFacingBundle(bundleId: string): boolean {
|
|
41
|
+
return !NON_UI_BUNDLE_RE.test(bundleId);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function detectReactNative(udid: string, bundleId: string): Promise<boolean> {
|
|
45
|
+
if (RN_BUNDLE_IDS.has(bundleId)) return Promise.resolve(true);
|
|
46
|
+
return new Promise((resolve) => {
|
|
47
|
+
execFile("xcrun", ["simctl", "get_app_container", udid, bundleId, "app"],
|
|
48
|
+
{ timeout: 2000 },
|
|
49
|
+
(err, stdout) => {
|
|
50
|
+
if (err) return resolve(false);
|
|
51
|
+
const appPath = stdout.trim();
|
|
52
|
+
if (!appPath) return resolve(false);
|
|
53
|
+
for (const marker of RN_MARKERS) {
|
|
54
|
+
if (existsSync(join(appPath, marker))) return resolve(true);
|
|
55
|
+
}
|
|
56
|
+
resolve(false);
|
|
57
|
+
});
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
|
|
19
61
|
function readServeSimStates(): ServeSimState[] {
|
|
20
62
|
let files: string[];
|
|
21
63
|
try {
|
|
@@ -102,6 +144,36 @@ export function simMiddleware(options?: SimMiddlewareOptions) {
|
|
|
102
144
|
return;
|
|
103
145
|
}
|
|
104
146
|
|
|
147
|
+
// POST /exec — run a shell command on the host. The preview server binds
|
|
148
|
+
// to localhost only and is meant for local dev, so we shell through
|
|
149
|
+
// /bin/sh and return stdout/stderr/exitCode.
|
|
150
|
+
if ((url === base + "/exec" || url === base + "/exec/") && req.method === "POST") {
|
|
151
|
+
let body = "";
|
|
152
|
+
req.on("data", (chunk: Buffer | string) => {
|
|
153
|
+
body += typeof chunk === "string" ? chunk : chunk.toString();
|
|
154
|
+
});
|
|
155
|
+
req.on("end", () => {
|
|
156
|
+
let command = "";
|
|
157
|
+
try {
|
|
158
|
+
command = JSON.parse(body).command ?? "";
|
|
159
|
+
} catch {}
|
|
160
|
+
if (!command) {
|
|
161
|
+
res.writeHead(400, { "Content-Type": "application/json" });
|
|
162
|
+
res.end(JSON.stringify({ stdout: "", stderr: "Missing command", exitCode: 1 }));
|
|
163
|
+
return;
|
|
164
|
+
}
|
|
165
|
+
exec(command, { maxBuffer: 16 * 1024 * 1024 }, (err, stdout, stderr) => {
|
|
166
|
+
res.writeHead(200, { "Content-Type": "application/json" });
|
|
167
|
+
res.end(JSON.stringify({
|
|
168
|
+
stdout: stdout.toString(),
|
|
169
|
+
stderr: stderr.toString(),
|
|
170
|
+
exitCode: err ? (err as any).code ?? 1 : 0,
|
|
171
|
+
}));
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
|
|
105
177
|
// SSE: simctl log stream
|
|
106
178
|
if (url === base + "/logs" || url.startsWith(base + "/logs?")) {
|
|
107
179
|
const states = readServeSimStates();
|
|
@@ -141,6 +213,65 @@ export function simMiddleware(options?: SimMiddlewareOptions) {
|
|
|
141
213
|
return;
|
|
142
214
|
}
|
|
143
215
|
|
|
216
|
+
// SSE: foreground-app change stream. Emits `{bundleId, pid}` events
|
|
217
|
+
// parsed from SpringBoard's "Setting process visibility to: Foreground"
|
|
218
|
+
// log line. Filtering is done here (not in the browser) so the SSE stream
|
|
219
|
+
// stays narrow and the client can listen without rate-limit concerns.
|
|
220
|
+
if (url === base + "/appstate" || url.startsWith(base + "/appstate?")) {
|
|
221
|
+
const states = readServeSimStates();
|
|
222
|
+
if (states.length === 0) {
|
|
223
|
+
res.writeHead(404);
|
|
224
|
+
res.end("No serve-sim device");
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
const udid = states[0].device;
|
|
228
|
+
res.writeHead(200, {
|
|
229
|
+
"Content-Type": "text/event-stream",
|
|
230
|
+
"Cache-Control": "no-cache",
|
|
231
|
+
Connection: "keep-alive",
|
|
232
|
+
"X-Accel-Buffering": "no",
|
|
233
|
+
});
|
|
234
|
+
res.write(":\n\n");
|
|
235
|
+
|
|
236
|
+
const child: ChildProcess = spawn("xcrun", [
|
|
237
|
+
"simctl", "spawn", udid, "log", "stream",
|
|
238
|
+
"--style", "ndjson",
|
|
239
|
+
"--level", "info",
|
|
240
|
+
"--predicate",
|
|
241
|
+
'process == "SpringBoard" AND eventMessage CONTAINS "Setting process visibility to: Foreground"',
|
|
242
|
+
], { stdio: ["ignore", "pipe", "ignore"] });
|
|
243
|
+
|
|
244
|
+
// e.g. "[app<com.apple.mobilesafari>:43117] Setting process visibility to: Foreground"
|
|
245
|
+
const FG_RE = /\[app<([^>]+)>:(\d+)\] Setting process visibility to: Foreground/;
|
|
246
|
+
let lastBundle = "";
|
|
247
|
+
let buf = "";
|
|
248
|
+
child.stdout!.on("data", (chunk: Buffer) => {
|
|
249
|
+
buf += chunk.toString();
|
|
250
|
+
let nl: number;
|
|
251
|
+
while ((nl = buf.indexOf("\n")) !== -1) {
|
|
252
|
+
const line = buf.slice(0, nl).trim();
|
|
253
|
+
buf = buf.slice(nl + 1);
|
|
254
|
+
if (!line) continue;
|
|
255
|
+
let msg: string;
|
|
256
|
+
try { msg = JSON.parse(line).eventMessage ?? ""; } catch { continue; }
|
|
257
|
+
const m = FG_RE.exec(msg);
|
|
258
|
+
if (!m) continue;
|
|
259
|
+
const bundleId = m[1]!;
|
|
260
|
+
const pid = parseInt(m[2]!, 10);
|
|
261
|
+
if (!isUserFacingBundle(bundleId)) continue;
|
|
262
|
+
if (bundleId === lastBundle) continue;
|
|
263
|
+
lastBundle = bundleId;
|
|
264
|
+
detectReactNative(udid, bundleId).then((isReactNative) => {
|
|
265
|
+
res.write("data: " + JSON.stringify({ bundleId, pid, isReactNative }) + "\n\n");
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
});
|
|
269
|
+
|
|
270
|
+
child.on("close", () => res.end());
|
|
271
|
+
req.on("close", () => child.kill());
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
|
|
144
275
|
// Not ours — pass through
|
|
145
276
|
if (next) next();
|
|
146
277
|
};
|