@latticexyz/entrykit 2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2 → 2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5

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.
@@ -1436,7 +1436,7 @@ video {
1436
1436
  --tw-text-opacity: 1;
1437
1437
  color: rgb(255 255 255 / var(--tw-text-opacity));
1438
1438
  }
1439
- `;import{useResizeObserver as Jt}from"usehooks-ts";import{mergeRefs as Zt}from"react-merge-refs";import{createContext as Wt,useContext as qt}from"react";import{jsx as Ut}from"react/jsx-runtime";var Ce=Wt(null);function ke({frame:e,children:t}){if(qt(Ce))throw new Error("`FrameProvider` can only be used once.");return Ut(Ce.Provider,{value:{frame:e},children:t})}import{useMediaQuery as Yt}from"usehooks-ts";import"@rainbow-me/rainbowkit/styles.css";import{createContext as Qt,useContext as Ne}from"react";import{RainbowKitProvider as Vt,lightTheme as Ae,midnightTheme as Se}from"@rainbow-me/rainbowkit";import{useChains as _t}from"wagmi";import{getChainContractAddress as Gt}from"viem";function B(e){return Gt({chain:e,contract:"quarryPaymaster"})}import{jsx as Pe}from"react/jsx-runtime";var oe=Qt(null);function Ee({config:e,children:t}){if(Ne(oe))throw new Error("`EntryKitProvider` can only be used once.");let n=_t().find(({id:c})=>c===e.chainId);if(!n)throw new Error(`Could not find configured chain for chain ID ${e.chainId}.`);let a=B(n);return Pe(Vt,{initialChain:0,appInfo:{appName:e.appName},theme:e.theme==="light"?Ae({borderRadius:"none"}):e.theme==="dark"?Se({borderRadius:"none"}):{lightMode:Ae({borderRadius:"none"}),darkMode:Se({borderRadius:"none"})},children:Pe(oe.Provider,{value:{...e,chain:n,paymasterAddress:a},children:t})})}function m(){let e=Ne(oe);if(!e)throw new Error("`useEntryKitConfig` can only be used within a `EntryKitProvider`.");return e}function Me(){let{theme:e}=m(),t=Yt("(prefers-color-scheme: dark)");return e??(t?"dark":"light")}import{jsx as M,jsxs as tr}from"react/jsx-runtime";function er({onSize:e,...t}){let r=Te(null);return Jt({ref:r,onResize:e}),M("div",{ref:r,...t,style:{...t.style,display:"inline-grid"}})}var F=jt(function({mode:t,children:r},o){let n=Te(null),[a,c]=Ie(!1),l=a?n.current:null,[d,i]=Ie({width:void 0,height:void 0}),s=l?.contentDocument,p=Me();Xt(()=>{s&&s.body.setAttribute("data-theme",p)},[s,p]);let u=t==="modal"?{all:"unset",display:"block",position:"fixed",inset:"0",width:"100%",height:"100%",zIndex:"2147483646"}:d.width&&d.height?{all:"unset",display:"inline-grid",width:`${d.width}px`,height:`${d.height}px`}:{all:"unset",display:"block",position:"fixed",inset:"0",width:"100%",height:"100%",opacity:0,pointerEvents:"none"};return M("iframe",{ref:Zt([o,n]),style:u,onLoad:()=>c(!0),srcDoc:"<!doctype html><title>\u2026</title>",children:s?$t.createPortal(tr(ke,{frame:l,children:[M("div",{children:t==="modal"?r:M(er,{onSize:i,children:r})}),M("style",{dangerouslySetInnerHTML:{__html:ve}})]}),s.body):null})});import{twMerge as He}from"tailwind-merge";import{jsx as A,jsxs as ar}from"react/jsx-runtime";function Re({open:e,onOpenChange:t,children:r}){return A(rr,{open:e,onOpenChange:t,children:A(or,{children:ar(F,{mode:"modal",children:[A("div",{className:He("fixed inset-0","bg-neutral-800/85","animate-in animate-duration-300 fade-in")}),A("div",{className:He("fixed inset-0","grid items-end sm:items-center","animate-in animate-duration-300 fade-in slide-in-from-bottom-16"),children:A("div",{children:A(nr,{className:"outline-none w-full max-w-[26rem] mx-auto","aria-describedby":void 0,onOpenAutoFocus:o=>{o.preventDefault()},children:r})})})]})})})}import{useCallback as ne,useMemo as ir}from"react";import{useStore as sr}from"zustand";import{createStore as cr}from"zustand/vanilla";var L=cr(()=>({open:!1}));function y(){let e=sr(L,n=>n.open),t=ne(()=>{L.setState({open:!0})},[]),r=ne(()=>{L.setState({open:!1})},[]),o=ne(n=>{L.setState({open:n})},[]);return ir(()=>({accountModalOpen:e,openAccountModal:t,closeAccountModal:r,toggleAccountModal:o}),[e,t,r,o])}import{twMerge as Et}from"tailwind-merge";import{useAccount as bn,useConnectorClient as xn}from"wagmi";import{useAccount as to}from"wagmi";import{twMerge as T}from"tailwind-merge";import{twMerge as lr}from"tailwind-merge";import{jsx as ze,jsxs as dr}from"react/jsx-runtime";function v({className:e,...t}){return dr("svg",{className:lr("-my-[0.125em] h-[1.25em] w-[1.25em] animate-spin",e),xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",...t,children:[ze("circle",{className:"opacity-25",cx:"12",cy:"12",r:"10",stroke:"currentColor",strokeWidth:"4"}),ze("path",{className:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"})]})}import{jsx as I,jsxs as mr}from"react/jsx-runtime";var pr=({variant:e="secondary"}={})=>T("group/button self-center leading-none outline-none border-4 border-transparent","transition hover:brightness-125 active:brightness-150","focus:border-orange-500","aria-disabled:pointer-events-none aria-busy:pointer-events-none","aria-disabled:opacity-50","p-[.75em] font-medium",{primary:T("bg-orange-600 text-white focus:border-yellow-400"),secondary:T("bg-neutral-700 text-white focus:border-orange-500"),tertiary:T("bg-neutral-800 text-white focus:border-orange-500")}[e]),w=({pending:e,variant:t,type:r,className:o,children:n,disabled:a,...c})=>I("button",{type:r||"button",className:T(pr({variant:t,pending:e}),o),"aria-busy":e,"aria-disabled":a,disabled:a||e,...c,children:mr("span",{className:"grid grid-cols-[1fr_auto_1fr] gap-2",children:[I("span",{className:"flex items-center justify-end text-[.75em]",children:I("span",{className:"transition opacity-0 translate-x-2 group-aria-busy/button:opacity-100 group-aria-busy/button:translate-x-0 duration-100 group-aria-busy/button:duration-300",children:I(v,{})})}),I("span",{children:n})]})});import{useConnectModal as ro}from"@rainbow-me/rainbowkit";import{useMutation as Ye}from"@tanstack/react-query";import{useConnectors as Xr}from"wagmi";import{createClient as Wr,custom as qr,getAddress as Ur,numberToHex as Qe,SwitchChainError as Gr}from"viem";import{ChainNotConfiguredError as Qr,createConnector as Vr}from"wagmi";import{createStore as ur}from"zustand/vanilla";import{persist as fr}from"zustand/middleware";var g=ur(fr(()=>({publicKeys:{},activeCredential:null}),{name:"mud:id:cache"}));function gr(e){e.key===g.persist.getOptions().name&&g.persist.rehydrate()}window.addEventListener("storage",gr);import{smartAccountActions as _r}from"permissionless/clients";import{toCoinbaseSmartAccount as br}from"@latticexyz/common/accounts";import{hashMessage as hr,hashTypedData as yr}from"viem";import{createBridge as wr}from"@latticexyz/id/internal";function De(e){let{id:t,publicKey:r}=e.credential;return{publicKey:r,async sign({hash:o}){let n=await wr({message:"Requesting signature\u2026",url:e.bridgeUrl});try{let{signature:a,metadata:c}=await n.request("sign",{credentialId:t,challenge:o});return{signature:a,webauthn:c,raw:{id:t}}}finally{n.close()}},async signMessage({message:o}){return this.sign({hash:hr(o)})},async signTypedData(o){return this.sign({hash:yr(o)})},type:"webAuthn"}}async function H(e,t){let{publicKeys:r}=g.getState(),o=r[t];if(!o)throw new Error("No public key found for passkey credential.");let a=[De({credential:{id:t,publicKey:o},bridgeUrl:e.chain.mudIdUrl})];return await br({client:e,owners:a})}import{bytesToHex as Sr,hashMessage as Le}from"viem";import{bytesToHex as xr,hexToBytes as Ke}from"webauthn-p256";import{concatBytes as vr,utf8ToBytes as Cr}from"@noble/curves/abstract/utils";async function ae(e){let{authenticatorData:t,challengeIndex:r,clientDataJSON:o,typeIndex:n,userVerificationRequired:a}=e,c=n||o.indexOf('"type"'),l=r||o.indexOf('"challenge"'),d=Ke(t);if(d.length<37)throw new Error("Invalid authenticatorData");let i=d[32];if((i&1)!==1)throw new Error("Invalid authenticatorData");if(a&&(i&4)!==4)throw new Error("Invalid authenticatorData");if((i&8)!==8&&(i&16)===16)throw new Error("Invalid authenticatorData");let s='"type":"webauthn.get"';if(s!==o.slice(Number(c),s.length+1))throw new Error("Invalid clientDataJSON");if(!o.slice(Number(l)).match(/^"challenge":"(.*?)"/))throw new Error("Invalid clientDataJSON");let u=new Uint8Array(await crypto.subtle.digest("SHA-256",Cr(o))),h=new Uint8Array(await crypto.subtle.digest("SHA-256",vr(Ke(t),u)));return xr(h)}import{parseSignature as kr,serializePublicKey as Oe}from"webauthn-p256";import{secp256r1 as Be}from"@noble/curves/p256";function ie(e){let{r:t,s:r}=kr(e.signatureHex),o=new Be.Signature(t,r).addRecoveryBit(1).recoverPublicKey(e.messageHash.slice(2)),n=new Be.Signature(t,r).addRecoveryBit(0).recoverPublicKey(e.messageHash.slice(2));return[Oe(o),Oe(n)]}function Fe([e,t]){return Ar([...ie(e),...ie(t)])}function Ar(e){let t=new Set;for(let r of e){if(t.has(r))return r;t.add(r)}}import{createBridge as Pr}from"@latticexyz/id/internal";async function se(e){let t=await Pr({url:e.mudIdUrl,message:"Signing in\u2026"});try{let r=Le(Sr(crypto.getRandomValues(new Uint8Array(256)))),{credentialId:o,signature:n,metadata:a}=await t.request("sign",{challenge:r}),c=await(async()=>{let l=g.getState().publicKeys[o];if(l)return l;let d=await ae(a),i=Le(n),s=await t.request("sign",{credentialId:o,challenge:i});if(s.credentialId!==o)throw new Error("wrong credential");let p=Fe([{messageHash:d,signatureHex:n},{messageHash:await ae(s.metadata),signatureHex:s.signature}]);if(!p)throw new Error("recovery failed");return g.setState(u=>({publicKeys:{...u.publicKeys,[o]:p}})),p})();return console.log("recovered passkey",o,c),g.setState(()=>({activeCredential:o})),{credentialId:o,publicKey:c}}finally{t.close()}}import{createBridge as Nr}from"@latticexyz/id/internal";async function We(e){let t=await Nr({url:e.mudIdUrl,message:"Creating account\u2026"});try{let r=await t.request("create");return console.log("created passkey",r),g.setState(o=>({activeCredential:r.credentialId,publicKeys:{...o.publicKeys,[r.credentialId]:r.publicKey}})),r}finally{t.close()}}import{resourceToHex as Er}from"@latticexyz/common";import{parseAbi as Mr}from"viem";import Ir from"@latticexyz/world/mud.config";var W={pollingInterval:250},R=Er({type:"system",namespace:"",name:"unlimited"}),qe=Ir.namespaces.world.tables,Ue=Mr(["function registerDelegation(address delegatee, bytes32 delegationControlId, bytes initCallData)"]);import{createBundlerClient as Tr}from"viem/account-abstraction";var Hr=new Set([31337,17420,17069,690]);function q({paymasterAddress:e,...t}){let r=t.chain??t.client?.chain;return Tr({...W,paymaster:{getPaymasterData:async()=>({paymaster:e,paymasterData:"0x"})},userOperation:{estimateFeesPerGas:r&&Hr.has(r.id)?async()=>({maxFeePerGas:100000n,maxPriorityFeePerGas:0n}):void 0},...t})}import{observer as Yr}from"@latticexyz/explorer/observer";import{transactionQueue as Rr}from"@latticexyz/common/actions";import{createClient as zr,fallback as Dr,http as Ge,webSocket as Kr}from"viem";import{privateKeyToAccount as Or,generatePrivateKey as Br}from"viem/accounts";import{wiresaw as Fr}from"@latticexyz/wiresaw/internal";import{userOpExecutor as Lr}from"@latticexyz/paymaster/internal";function U(e){let t=e.rpcUrls.bundler?.http[0],r=t?Fr(Ge(t)):e.id===31337?Lr({executor:zr({chain:e,transport:Dr([Kr(),Ge()]),account:Or(Br())}).extend(Rr())}):null;if(!r)throw new Error(`Chain ${e.id} config did not include a bundler RPC URL.`);return r}import{wiresaw as jr}from"@latticexyz/wiresaw/internal";S.type="passkey";function S({chainId:e}){return Vr(t=>{if(!t.transports)throw new Error("Wagmi must be configured with transports to use the passkey connector.");let r=t.chains.find(i=>i.id===e);if(!r)throw new Error(`Could not find configured chain for chain ID ${e}.`);let o=t.transports[r.id];if(!o)throw new Error(`Could not find configured transport for chain ID ${e}.`);let n=jr(o),a=B(r),c=U(r),l=Wr({...W,chain:r,transport:n}),d=g.getState().activeCredential!=null;return{id:"passkey",type:S.type,name:"Passkey",async createPasskey(){let{credentialId:i}=await We(r),s=await H(l,i);this.onAccountsChanged([s.address]),this.onConnect?.({chainId:Qe(e)})},async reusePasskey(){let{credentialId:i}=await se(r),s=await H(l,i);this.onAccountsChanged([s.address]),this.onConnect?.({chainId:Qe(e)})},hasPasskey(){return Object.keys(g.getState().publicKeys).length>0},async connect(i){if(console.log("connect"),i?.chainId!=null&&i.chainId!==e)throw new Error(`Can't connect to chain ${i.chainId}. Passkey connector is bound to chain ${e}.`);!g.getState().activeCredential&&!i?.isReconnecting&&await se(r);let s=await this.getAccounts();return d=s.length>0,{accounts:s,chainId:e}},async disconnect(){console.log("disconnect"),d=!1,g.setState({activeCredential:null})},async getAccounts(){console.log("getAccounts");let i=g.getState().activeCredential;if(!i)return[];try{console.log("getting account for credential",i);let s=await H(l,i);return console.log("got account",s),[s.address]}catch{console.log("could not get address for credential ID",i)}return[]},async getChainId(){return e},async isAuthorized(){return console.log("isAuthorized"),d?(await this.getAccounts()).length>0:!1},async switchChain(i){if(i.chainId!==e)throw new Error(`Can't connect to chain ${i.chainId}. Passkey connector is bound to chain ${e}.`);let s=t.chains.find(p=>p.id===i.chainId);if(!s)throw new Gr(new Qr);return s},onAccountsChanged(i){console.log("onAccountsChanged"),i.length>0?t.emitter.emit("change",{accounts:i.map(s=>Ur(s))}):this.onDisconnect()},onChainChanged(i){console.log("onChainChanged"),t.emitter.emit("change",{chainId:Number(i)})},async onConnect(i){console.log("onConnect");let s=await this.getAccounts();t.emitter.emit("connect",{accounts:s,chainId:e})},async onDisconnect(i){console.log("onDisconnect"),t.emitter.emit("disconnect"),d=!1},async getClient(i){console.log("passkeyConnector.getClient",i);let s=g.getState().activeCredential;if(!s)throw new Error("Not connected.");let p=await H(l,s);return q({paymasterAddress:a,transport:c,client:l,account:p}).extend(_r()).extend(Yr())},async getProvider(i){return qr({request:l.transport.request})({retryCount:0})}}})}function Ve(){let t=Xr().find(r=>r.type===S.type);if(!t)throw new Error("Could not find passkey connector. Did you configure Wagmi with the EntryKit passkey connector or passkey wallet?");return t}import{twMerge as $r}from"tailwind-merge";import{jsx as ce,jsxs as Jr}from"react/jsx-runtime";function C({className:e,...t}){return Jr("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 8 8",fill:"currentColor",shapeRendering:"crispEdges",className:$r("-my-[0.125em] h-[1.25em] w-[1.25em]",e),...t,children:[ce("path",{d:"M0 0h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm2-1h1v1H7zm0 1h1v1H7zM6 7h1v1H6zm1-2h1v1H7zm0-1h1v1H7zm0-1h1v1H7z"}),ce("path",{d:"M2 2h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm1-3h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm0 1h1v1H5zm0 1h1v1H5zm0 1h1v1H5zM4 5h1v1H4zM3 5h1v1H3z",opacity:".5"}),ce("path",{d:"M7 2h1v1H7zm0-1h1v1H7zM1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm1 0h1v1H6zm1 0h1v1H7z"})]})}import{useQuery as Zr}from"@tanstack/react-query";function G(e){return Zr({enabled:!!e,retry:!1,retryOnMount:!1,refetchOnMount:!1,refetchOnWindowFocus:!1,queryKey:["preloadImage",e],queryFn:()=>new Promise((t,r)=>{if(!e)throw new Error("usePreloadImage: Must provide `url` to preload image.");let o=new Image;o.onload=()=>t(o),o.onerror=()=>r(new Error(`usePreloadImage: Could not load image.
1439
+ `;import{useResizeObserver as Jt}from"usehooks-ts";import{mergeRefs as Zt}from"react-merge-refs";import{createContext as Wt,useContext as qt}from"react";import{jsx as Ut}from"react/jsx-runtime";var Ce=Wt(null);function ke({frame:e,children:t}){if(qt(Ce))throw new Error("`FrameProvider` can only be used once.");return Ut(Ce.Provider,{value:{frame:e},children:t})}import{useMediaQuery as Yt}from"usehooks-ts";import"@rainbow-me/rainbowkit/styles.css";import{createContext as Qt,useContext as Ne}from"react";import{RainbowKitProvider as Vt,lightTheme as Ae,midnightTheme as Se}from"@rainbow-me/rainbowkit";import{useChains as _t}from"wagmi";import{getChainContractAddress as Gt}from"viem";function B(e){return Gt({chain:e,contract:"quarryPaymaster"})}import{jsx as Pe}from"react/jsx-runtime";var oe=Qt(null);function Ee({config:e,children:t}){if(Ne(oe))throw new Error("`EntryKitProvider` can only be used once.");let n=_t().find(({id:c})=>c===e.chainId);if(!n)throw new Error(`Could not find configured chain for chain ID ${e.chainId}.`);let a=B(n);return Pe(Vt,{initialChain:0,appInfo:{appName:e.appName},theme:e.theme==="light"?Ae({borderRadius:"none"}):e.theme==="dark"?Se({borderRadius:"none"}):{lightMode:Ae({borderRadius:"none"}),darkMode:Se({borderRadius:"none"})},children:Pe(oe.Provider,{value:{...e,chain:n,paymasterAddress:a},children:t})})}function m(){let e=Ne(oe);if(!e)throw new Error("`useEntryKitConfig` can only be used within a `EntryKitProvider`.");return e}function Me(){let{theme:e}=m(),t=Yt("(prefers-color-scheme: dark)");return e??(t?"dark":"light")}import{jsx as M,jsxs as tr}from"react/jsx-runtime";function er({onSize:e,...t}){let r=Te(null);return Jt({ref:r,onResize:e}),M("div",{ref:r,...t,style:{...t.style,display:"inline-grid"}})}var F=jt(function({mode:t,children:r},o){let n=Te(null),[a,c]=Ie(!1),l=a?n.current:null,[d,i]=Ie({width:void 0,height:void 0}),s=l?.contentDocument,p=Me();Xt(()=>{s&&s.body.setAttribute("data-theme",p)},[s,p]);let u=t==="modal"?{all:"unset",display:"block",position:"fixed",inset:"0",width:"100%",height:"100%",zIndex:"2147483646"}:d.width&&d.height?{all:"unset",display:"inline-grid",width:`${d.width}px`,height:`${d.height}px`}:{all:"unset",display:"block",position:"fixed",inset:"0",width:"100%",height:"100%",opacity:0,pointerEvents:"none"};return M("iframe",{ref:Zt([o,n]),style:u,onLoad:()=>c(!0),srcDoc:"<!doctype html><title>\u2026</title>",children:s?$t.createPortal(tr(ke,{frame:l,children:[M("div",{children:t==="modal"?r:M(er,{onSize:i,children:r})}),M("style",{dangerouslySetInnerHTML:{__html:ve}})]}),s.body):null})});import{twMerge as He}from"tailwind-merge";import{jsx as A,jsxs as ar}from"react/jsx-runtime";function Re({open:e,onOpenChange:t,children:r}){return A(rr,{open:e,onOpenChange:t,children:A(or,{children:ar(F,{mode:"modal",children:[A("div",{className:He("fixed inset-0","bg-neutral-800/85","animate-in animate-duration-300 fade-in")}),A("div",{className:He("fixed inset-0","grid items-end sm:items-center","animate-in animate-duration-300 fade-in slide-in-from-bottom-16"),children:A("div",{children:A(nr,{className:"outline-none w-full max-w-[26rem] mx-auto","aria-describedby":void 0,onOpenAutoFocus:o=>{o.preventDefault()},children:r})})})]})})})}import{useCallback as ne,useMemo as ir}from"react";import{useStore as sr}from"zustand";import{createStore as cr}from"zustand/vanilla";var L=cr(()=>({open:!1}));function y(){let e=sr(L,n=>n.open),t=ne(()=>{L.setState({open:!0})},[]),r=ne(()=>{L.setState({open:!1})},[]),o=ne(n=>{L.setState({open:n})},[]);return ir(()=>({accountModalOpen:e,openAccountModal:t,closeAccountModal:r,toggleAccountModal:o}),[e,t,r,o])}import{twMerge as Et}from"tailwind-merge";import{useAccount as xn,useConnectorClient as vn}from"wagmi";import{useAccount as ro}from"wagmi";import{twMerge as T}from"tailwind-merge";import{twMerge as lr}from"tailwind-merge";import{jsx as ze,jsxs as dr}from"react/jsx-runtime";function v({className:e,...t}){return dr("svg",{className:lr("-my-[0.125em] h-[1.25em] w-[1.25em] animate-spin",e),xmlns:"http://www.w3.org/2000/svg",fill:"none",viewBox:"0 0 24 24",...t,children:[ze("circle",{className:"opacity-25",cx:"12",cy:"12",r:"10",stroke:"currentColor",strokeWidth:"4"}),ze("path",{className:"opacity-75",fill:"currentColor",d:"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"})]})}import{jsx as I,jsxs as mr}from"react/jsx-runtime";var pr=({variant:e="secondary"}={})=>T("group/button self-center leading-none outline-none border-4 border-transparent","transition hover:brightness-125 active:brightness-150","focus:border-orange-500","aria-disabled:pointer-events-none aria-busy:pointer-events-none","aria-disabled:opacity-50","p-[.75em] font-medium",{primary:T("bg-orange-600 text-white focus:border-yellow-400"),secondary:T("bg-neutral-700 text-white focus:border-orange-500"),tertiary:T("bg-neutral-800 text-white focus:border-orange-500")}[e]),w=({pending:e,variant:t,type:r,className:o,children:n,disabled:a,...c})=>I("button",{type:r||"button",className:T(pr({variant:t,pending:e}),o),"aria-busy":e,"aria-disabled":a,disabled:a||e,...c,children:mr("span",{className:"grid grid-cols-[1fr_auto_1fr] gap-2",children:[I("span",{className:"flex items-center justify-end text-[.75em]",children:I("span",{className:"transition opacity-0 translate-x-2 group-aria-busy/button:opacity-100 group-aria-busy/button:translate-x-0 duration-100 group-aria-busy/button:duration-300",children:I(v,{})})}),I("span",{children:n})]})});import{useConnectModal as oo}from"@rainbow-me/rainbowkit";import{useMutation as Ye}from"@tanstack/react-query";import{useConnectors as $r}from"wagmi";import{createClient as qr,custom as Ur,getAddress as Gr,numberToHex as Qe,SwitchChainError as Qr}from"viem";import{ChainNotConfiguredError as Vr,createConnector as _r}from"wagmi";import{createStore as ur}from"zustand/vanilla";import{persist as fr}from"zustand/middleware";var g=ur(fr(()=>({publicKeys:{},activeCredential:null}),{name:"mud:id:cache"}));function gr(e){e.key===g.persist.getOptions().name&&g.persist.rehydrate()}window.addEventListener("storage",gr);import{smartAccountActions as Yr}from"permissionless/clients";import{toCoinbaseSmartAccount as br}from"@latticexyz/common/accounts";import{hashMessage as hr,hashTypedData as yr}from"viem";import{createBridge as wr}from"@latticexyz/id/internal";function De(e){let{id:t,publicKey:r}=e.credential;return{publicKey:r,async sign({hash:o}){let n=await wr({message:"Requesting signature\u2026",url:e.bridgeUrl});try{let{signature:a,metadata:c}=await n.request("sign",{credentialId:t,challenge:o});return{signature:a,webauthn:c,raw:{id:t}}}finally{n.close()}},async signMessage({message:o}){return this.sign({hash:hr(o)})},async signTypedData(o){return this.sign({hash:yr(o)})},type:"webAuthn"}}async function H(e,t){let{publicKeys:r}=g.getState(),o=r[t];if(!o)throw new Error("No public key found for passkey credential.");let a=[De({credential:{id:t,publicKey:o},bridgeUrl:e.chain.mudIdUrl})];return await br({client:e,owners:a})}import{bytesToHex as Sr,hashMessage as Le}from"viem";import{bytesToHex as xr,hexToBytes as Ke}from"webauthn-p256";import{concatBytes as vr,utf8ToBytes as Cr}from"@noble/curves/abstract/utils";async function ae(e){let{authenticatorData:t,challengeIndex:r,clientDataJSON:o,typeIndex:n,userVerificationRequired:a}=e,c=n||o.indexOf('"type"'),l=r||o.indexOf('"challenge"'),d=Ke(t);if(d.length<37)throw new Error("Invalid authenticatorData");let i=d[32];if((i&1)!==1)throw new Error("Invalid authenticatorData");if(a&&(i&4)!==4)throw new Error("Invalid authenticatorData");if((i&8)!==8&&(i&16)===16)throw new Error("Invalid authenticatorData");let s='"type":"webauthn.get"';if(s!==o.slice(Number(c),s.length+1))throw new Error("Invalid clientDataJSON");if(!o.slice(Number(l)).match(/^"challenge":"(.*?)"/))throw new Error("Invalid clientDataJSON");let u=new Uint8Array(await crypto.subtle.digest("SHA-256",Cr(o))),h=new Uint8Array(await crypto.subtle.digest("SHA-256",vr(Ke(t),u)));return xr(h)}import{parseSignature as kr,serializePublicKey as Oe}from"webauthn-p256";import{secp256r1 as Be}from"@noble/curves/p256";function ie(e){let{r:t,s:r}=kr(e.signatureHex),o=new Be.Signature(t,r).addRecoveryBit(1).recoverPublicKey(e.messageHash.slice(2)),n=new Be.Signature(t,r).addRecoveryBit(0).recoverPublicKey(e.messageHash.slice(2));return[Oe(o),Oe(n)]}function Fe([e,t]){return Ar([...ie(e),...ie(t)])}function Ar(e){let t=new Set;for(let r of e){if(t.has(r))return r;t.add(r)}}import{createBridge as Pr}from"@latticexyz/id/internal";async function se(e){let t=await Pr({url:e.mudIdUrl,message:"Signing in\u2026"});try{let r=Le(Sr(crypto.getRandomValues(new Uint8Array(256)))),{credentialId:o,signature:n,metadata:a}=await t.request("sign",{challenge:r}),c=await(async()=>{let l=g.getState().publicKeys[o];if(l)return l;let d=await ae(a),i=Le(n),s=await t.request("sign",{credentialId:o,challenge:i});if(s.credentialId!==o)throw new Error("wrong credential");let p=Fe([{messageHash:d,signatureHex:n},{messageHash:await ae(s.metadata),signatureHex:s.signature}]);if(!p)throw new Error("recovery failed");return g.setState(u=>({publicKeys:{...u.publicKeys,[o]:p}})),p})();return console.log("recovered passkey",o,c),g.setState(()=>({activeCredential:o})),{credentialId:o,publicKey:c}}finally{t.close()}}import{createBridge as Nr}from"@latticexyz/id/internal";async function We(e){let t=await Nr({url:e.mudIdUrl,message:"Creating account\u2026"});try{let r=await t.request("create");return console.log("created passkey",r),g.setState(o=>({activeCredential:r.credentialId,publicKeys:{...o.publicKeys,[r.credentialId]:r.publicKey}})),r}finally{t.close()}}import{resourceToHex as Er}from"@latticexyz/common";import{parseAbi as Mr}from"viem";import Ir from"@latticexyz/world/mud.config";var W={pollingInterval:250},R=Er({type:"system",namespace:"",name:"unlimited"}),qe=Ir.namespaces.world.tables,Ue=Mr(["function registerDelegation(address delegatee, bytes32 delegationControlId, bytes initCallData)"]);import{createBundlerClient as Tr}from"viem/account-abstraction";var Hr=new Set([31337,17420,17069,690]);function q({paymasterAddress:e,...t}){let r=t.chain??t.client?.chain;return Tr({...W,paymaster:{getPaymasterData:async()=>({paymaster:e,paymasterData:"0x"})},userOperation:{estimateFeesPerGas:r&&Hr.has(r.id)?async()=>({maxFeePerGas:100000n,maxPriorityFeePerGas:0n}):void 0},...t})}import{observer as jr}from"@latticexyz/explorer/observer";import{transactionQueue as Rr}from"@latticexyz/common/actions";import{createClient as zr,fallback as Dr,http as Ge,webSocket as Kr}from"viem";import{privateKeyToAccount as Or,generatePrivateKey as Br}from"viem/accounts";import{wiresaw as Fr}from"@latticexyz/wiresaw/internal";import{gasEstimator as Lr,userOpExecutor as Wr}from"@latticexyz/paymaster/internal";function U(e){let t=e.rpcUrls.bundler?.http[0],r=t?Lr(Fr(Ge(t))):e.id===31337?Wr({executor:zr({chain:e,transport:Dr([Kr(),Ge()]),account:Or(Br())}).extend(Rr())}):null;if(!r)throw new Error(`Chain ${e.id} config did not include a bundler RPC URL.`);return r}import{wiresaw as Xr}from"@latticexyz/wiresaw/internal";S.type="passkey";function S({chainId:e}){return _r(t=>{if(!t.transports)throw new Error("Wagmi must be configured with transports to use the passkey connector.");let r=t.chains.find(i=>i.id===e);if(!r)throw new Error(`Could not find configured chain for chain ID ${e}.`);let o=t.transports[r.id];if(!o)throw new Error(`Could not find configured transport for chain ID ${e}.`);let n=Xr(o),a=B(r),c=U(r),l=qr({...W,chain:r,transport:n}),d=g.getState().activeCredential!=null;return{id:"passkey",type:S.type,name:"Passkey",async createPasskey(){let{credentialId:i}=await We(r),s=await H(l,i);this.onAccountsChanged([s.address]),this.onConnect?.({chainId:Qe(e)})},async reusePasskey(){let{credentialId:i}=await se(r),s=await H(l,i);this.onAccountsChanged([s.address]),this.onConnect?.({chainId:Qe(e)})},hasPasskey(){return Object.keys(g.getState().publicKeys).length>0},async connect(i){if(console.log("connect"),i?.chainId!=null&&i.chainId!==e)throw new Error(`Can't connect to chain ${i.chainId}. Passkey connector is bound to chain ${e}.`);!g.getState().activeCredential&&!i?.isReconnecting&&await se(r);let s=await this.getAccounts();return d=s.length>0,{accounts:s,chainId:e}},async disconnect(){console.log("disconnect"),d=!1,g.setState({activeCredential:null})},async getAccounts(){console.log("getAccounts");let i=g.getState().activeCredential;if(!i)return[];try{console.log("getting account for credential",i);let s=await H(l,i);return console.log("got account",s),[s.address]}catch{console.log("could not get address for credential ID",i)}return[]},async getChainId(){return e},async isAuthorized(){return console.log("isAuthorized"),d?(await this.getAccounts()).length>0:!1},async switchChain(i){if(i.chainId!==e)throw new Error(`Can't connect to chain ${i.chainId}. Passkey connector is bound to chain ${e}.`);let s=t.chains.find(p=>p.id===i.chainId);if(!s)throw new Qr(new Vr);return s},onAccountsChanged(i){console.log("onAccountsChanged"),i.length>0?t.emitter.emit("change",{accounts:i.map(s=>Gr(s))}):this.onDisconnect()},onChainChanged(i){console.log("onChainChanged"),t.emitter.emit("change",{chainId:Number(i)})},async onConnect(i){console.log("onConnect");let s=await this.getAccounts();t.emitter.emit("connect",{accounts:s,chainId:e})},async onDisconnect(i){console.log("onDisconnect"),t.emitter.emit("disconnect"),d=!1},async getClient(i){console.log("passkeyConnector.getClient",i);let s=g.getState().activeCredential;if(!s)throw new Error("Not connected.");let p=await H(l,s);return q({paymasterAddress:a,transport:c,client:l,account:p}).extend(Yr()).extend(jr())},async getProvider(i){return Ur({request:l.transport.request})({retryCount:0})}}})}function Ve(){let t=$r().find(r=>r.type===S.type);if(!t)throw new Error("Could not find passkey connector. Did you configure Wagmi with the EntryKit passkey connector or passkey wallet?");return t}import{twMerge as Jr}from"tailwind-merge";import{jsx as ce,jsxs as Zr}from"react/jsx-runtime";function C({className:e,...t}){return Zr("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 8 8",fill:"currentColor",shapeRendering:"crispEdges",className:Jr("-my-[0.125em] h-[1.25em] w-[1.25em]",e),...t,children:[ce("path",{d:"M0 0h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm2-1h1v1H7zm0 1h1v1H7zM6 7h1v1H6zm1-2h1v1H7zm0-1h1v1H7zm0-1h1v1H7z"}),ce("path",{d:"M2 2h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm1-3h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm0 1h1v1H5zm0 1h1v1H5zm0 1h1v1H5zM4 5h1v1H4zM3 5h1v1H3z",opacity:".5"}),ce("path",{d:"M7 2h1v1H7zm0-1h1v1H7zM1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm1 0h1v1H6zm1 0h1v1H7z"})]})}import{useQuery as eo}from"@tanstack/react-query";function G(e){return eo({enabled:!!e,retry:!1,retryOnMount:!1,refetchOnMount:!1,refetchOnWindowFocus:!1,queryKey:["preloadImage",e],queryFn:()=>new Promise((t,r)=>{if(!e)throw new Error("usePreloadImage: Must provide `url` to preload image.");let o=new Image;o.onload=()=>t(o),o.onerror=()=>r(new Error(`usePreloadImage: Could not load image.
1440
1440
 
1441
- URL: ${e}`)),o.src=e})})}import{jsx as Q,jsxs as eo}from"react/jsx-runtime";function _e(){let{appName:e,appIcon:t}=m(),{data:r,isLoading:o}=G(t);return eo("div",{className:"flex-grow flex flex-col items-center justify-center gap-2",children:[Q("div",{className:"w-16 h-16 m-2",children:o?null:r?Q("img",{src:t,className:"w-full h-full object-cover"}):Q(C,{className:"w-full h-full text-orange-500 dark:bg-neutral-800"})}),Q("div",{className:"text-2xl text-white text-center",children:e})]})}import{twMerge as oo}from"tailwind-merge";import{jsx as z,jsxs as je}from"react/jsx-runtime";function Xe(){let e=to(),{accountModalOpen:t}=y(),{openConnectModal:r,connectModalOpen:o}=ro(),n=Ve(),a=Ye({onError:i=>console.error(i),mutationKey:["createPasskey",n.id,t,o,e.status],mutationFn:()=>n.createPasskey()}),c=Ye({onError:i=>console.error(i),mutationKey:["reusePasskey",n.id,t,o,e.status],mutationFn:()=>n.reusePasskey()}),l=n.hasPasskey(),d=[z(w,{variant:l?"tertiary":"secondary",className:"self-auto flex justify-center",pending:a.status==="pending"||a.status==="success",onClick:()=>a.mutate(),autoFocus:!l,children:"Create account"},"create"),z(w,{variant:l?"secondary":"tertiary",className:"self-auto flex justify-center",pending:c.status==="pending"||c.status==="success",onClick:()=>c.mutate(),autoFocus:l,children:"Sign in"},"signin")];return l&&d.reverse(),je("div",{className:oo("flex flex-col gap-6 p-6","animate-in animate-duration-300 fade-in slide-in-from-bottom-8"),children:[z("div",{className:"p-4",children:z(_e,{})}),je("div",{className:"self-center flex flex-col gap-2 w-60",children:[d,z("button",{className:"text-sm self-center transition text-neutral-500 hover:text-white p-2",disabled:e.status==="connecting",onClick:r,children:"Already have a wallet?"})]})]})}import{useEffect as gn,useMemo as hn,useRef as yn,useState as wn}from"react";import{twMerge as we}from"tailwind-merge";import{parseEther as no}from"viem";var V=no("0.01");import{useClient as lo}from"wagmi";import{queryOptions as po,useQuery as mo}from"@tanstack/react-query";import{defineStore as ao}from"@latticexyz/store";import{parseAbi as io}from"viem";var le=io(["error SpenderSystem_AlreadyRegistered(address spender, address user)","error SpenderSystem_HasOwnBalance(address spender)","function registerSpender(address spender)"]),so=ao({namespaces:{root:{namespace:"",tables:{Allowance:{schema:{user:"address",allowance:"uint256"},key:["user"]},Grantor:{schema:{grantor:"address",allowance:"uint256"},key:["grantor"]},PassHolder:{schema:{user:"address",passId:"bytes32",lastRenewed:"uint256",lastClaimed:"uint256"},key:["user","passId"]},PassConfig:{schema:{passId:"bytes32",claimAmount:"uint256",claimInterval:"uint256",validityPeriod:"uint256",grantor:"address"},key:["passId"]},Spender:{schema:{spender:"address",user:"address"},key:["spender"]},SystemConfig:{schema:{entryPoint:"address"},key:[]}}}}}),_=so.namespaces.root.tables;import{getRecord as co}from"@latticexyz/store/internal";async function $e({client:e,paymasterAddress:t,userAddress:r}){return(await co(e,{address:t,table:_.Allowance,key:{user:r},blockTag:"pending"})).allowance}function de({client:e,paymasterAddress:t,userAddress:r}){let o=["getAllowance",e?.chain.id,t,r];return po(e&&r?{queryKey:o,queryFn:()=>$e({client:e,paymasterAddress:t,userAddress:r})}:{queryKey:o,enabled:!1})}function Je(e){let{chainId:t,paymasterAddress:r}=m(),o=lo({chainId:t});return mo(de({client:o,paymasterAddress:r,userAddress:e}))}import{useClient as tc}from"wagmi";import{queryOptions as fo,useQuery as oc}from"@tanstack/react-query";import{getRecord as uo}from"@latticexyz/store/internal";async function Ze({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o}){return(await uo(e,{address:t,table:_.Spender,key:{spender:o},blockTag:"pending"})).user.toLowerCase()===r.toLowerCase()}function et({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o}){let n=["getSpender",e?.chain.id,t,r,o];return fo(e&&r&&o?{queryKey:n,queryFn:()=>Ze({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o})}:{queryKey:n,enabled:!1})}import{useClient as pc}from"wagmi";import{queryOptions as ho,useQuery as uc}from"@tanstack/react-query";import{getRecord as go}from"@latticexyz/store/internal";async function tt({client:e,worldAddress:t,userAddress:r,sessionAddress:o}){return(await go(e,{address:t,table:qe.UserDelegationControl,key:{delegator:r,delegatee:o},blockTag:"pending"})).delegationControlId===R}function rt({client:e,worldAddress:t,userAddress:r,sessionAddress:o}){let n=["getDelegation",e?.chain.id,t,r,o];return ho(e&&r&&o?{queryKey:n,queryFn:()=>tt({client:e,worldAddress:t,userAddress:r,sessionAddress:o})}:{queryKey:n,enabled:!1})}import{queryOptions as Po,useQuery as No,useQueryClient as Eo}from"@tanstack/react-query";import{useClient as Mo}from"wagmi";import{useClient as ko}from"wagmi";import{queryOptions as Ao,useQuery as So}from"@tanstack/react-query";import{toCoinbaseSmartAccount as Co}from"@latticexyz/common/accounts";import{createStore as yo}from"zustand/vanilla";import{persist as wo}from"zustand/middleware";var D=yo(wo(()=>({signers:{}}),{name:"mud:entrykit",partialize:({signers:e})=>({signers:e})}));function bo(e){e.key===D.persist.getOptions().name&&D.persist.rehydrate()}window.addEventListener("storage",bo);import{generatePrivateKey as xo,privateKeyToAccount as vo}from"viem/accounts";function ot(e){let t=D.getState().signers[e]??(()=>{let r=xo();return D.setState(o=>({signers:{...o.signers,[e]:r}})),r})();return vo(t)}async function nt({client:e,userAddress:t}){let r=ot(t);return await Co({client:e,owners:[r]})}function pe({client:e,userAddress:t}){let r=["getSessionAccount",e?.chain.id,t];return Ao(e&&t?{queryKey:r,queryFn:()=>nt({client:e,userAddress:t}),staleTime:1/0}:{queryKey:r,enabled:!1})}function at(e){let{chainId:t}=m(),r=ko({chainId:t});return So(pe({userAddress:e,client:r}))}function Io({queryClient:e,client:t,userAddress:r,paymasterAddress:o,worldAddress:n}){let a=["getPrerequisites",t?.chain.id,r];return Po(t&&r?{queryKey:a,queryFn:async()=>{let{address:c}=await e.fetchQuery(pe({client:t,userAddress:r})),[l,d,i]=await Promise.all([e.fetchQuery(de({client:t,paymasterAddress:o,userAddress:r})),e.fetchQuery(et({client:t,paymasterAddress:o,userAddress:r,sessionAddress:c})),e.fetchQuery(rt({client:t,worldAddress:n,userAddress:r,sessionAddress:c}))]),s=l>=V;return{hasAllowance:s,isSpender:d,hasDelegation:i,complete:s&&d&&i}}}:{queryKey:a,enabled:!1})}function P(e){let t=Eo(),{chainId:r,paymasterAddress:o,worldAddress:n}=m(),a=Mo({chainId:r});return No(Io({queryClient:t,client:a,userAddress:e,paymasterAddress:o,worldAddress:n}),t)}import{useDisconnect as Ro}from"wagmi";import{useQuery as To}from"@tanstack/react-query";function Y(e){let t=e?.toLowerCase();return To({enabled:!!t,queryKey:["ens",t],queryFn:async()=>{let r=await fetch(`https://api.ensideas.com/ens/resolve/${t}`).then(o=>o.json());return{address:r.address??void 0,name:r.name??void 0,displayName:r.displayName??void 0,avatar:r.avatar??void 0}}})}import{jsx as me,jsxs as Ho}from"react/jsx-runtime";function j({hex:e}){return e.length<=10?me("span",{title:e,children:e}):Ho("span",{title:e,children:[me("span",{className:"after:select-none after:content-['\u2026']",children:e.slice(0,6)}),me("span",{className:"tracking-[-1ch] text-transparent",children:e.slice(6,-4)}),e.slice(-4)]})}import{jsx as K,jsxs as ue}from"react/jsx-runtime";function it({isActive:e,isExpanded:t,userAddress:r}){let{data:o}=Y(r),{disconnect:n,isPending:a}=Ro(),{closeAccountModal:c}=y();return ue("div",{className:"flex flex-col gap-4",children:[ue("div",{className:"flex justify-between gap-4",children:[ue("div",{children:[K("div",{children:"Account"}),K("div",{className:"font-mono text-white",children:o?.name??K(j,{hex:r})})]}),K(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,pending:a,onClick:()=>{c(),n()},children:"Sign out"})]}),t?K("p",{className:"text-sm",children:"Each of your onchain actions in this app is associated with your account."}):null]})}import{useMutation as zo,useQueryClient as Do}from"@tanstack/react-query";import{claimGasPass as Ko}from"@latticexyz/paymaster/internal";function st(){let e=Do(),{chain:t}=m(),r=["claimGasPass",t.id];return zo({mutationKey:r,onError:o=>console.error(o),mutationFn:async o=>{await Ko({chain:t,userAddress:o}),await Promise.all([e.invalidateQueries({queryKey:["getAllowance"]}),e.invalidateQueries({queryKey:["getPrerequisites"]})])},retry:0})}import{twMerge as Oo}from"tailwind-merge";import{jsx as X,jsxs as Bo}from"react/jsx-runtime";function ct({className:e,...t}){return Bo("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 263 428",fill:"currentColor",className:Oo("w-[0.6em] h-[1em]",e),...t,children:[X("path",{d:"M132 321V428L263 243L132 321Z"}),X("path",{d:"M0 243L132 321V428",fillOpacity:"0.5"}),X("path",{d:"M132 0V296L263 218"}),X("path",{d:"M0 218L132 296V0L0 218Z",fillOpacity:"0.5"})]})}import{formatEther as Fo}from"viem";function lt(e){let t=Fo(e),r=Math.floor(parseFloat(t)).toString().length;return parseFloat(t).toLocaleString("en-US",{maximumFractionDigits:Math.max(0,6-r)})}import{jsx as Lo,jsxs as Wo}from"react/jsx-runtime";function dt({wei:e}){return Wo("span",{className:"inline-flex items-center gap-1",children:[lt(e)," ",Lo(ct,{})]})}import{useEffect as qo}from"react";import{jsx as N,jsxs as fe}from"react/jsx-runtime";function pt({isActive:e,isExpanded:t,userAddress:r}){let o=Je(r),n=st();return qo(()=>{let a=setTimeout(()=>{e&&n.status==="idle"&&o.isSuccess&&o.data<V&&n.mutate(r)});return()=>clearTimeout(a)},[o.data,o.isSuccess,n,e,r]),fe("div",{className:"flex flex-col gap-4",children:[fe("div",{className:"flex justify-between gap-4",children:[fe("div",{children:[N("div",{children:"Allowance"}),N("div",{className:"font-mono text-white",children:o.data!=null?N(dt,{wei:o.data}):N(v,{className:"text-sm"})})]}),N(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e||t,pending:o.status==="pending"||n.status==="pending",onClick:()=>n.mutate(r),children:"Top up"})]}),t?N("p",{className:"text-sm",children:"Your allowance is used to pay for onchain computation."}):null]})}import{encodeFunctionData as ut}from"viem";import{useMutation as Zo,useQueryClient as en}from"@tanstack/react-query";import{getAction as he}from"viem/utils";import{sendUserOperation as tn,waitForUserOperationReceipt as rn}from"viem/account-abstraction";import{waitForTransactionReceipt as on}from"viem/actions";import{useClient as nn}from"wagmi";import{resourceToHex as ft}from"@latticexyz/common";import an from"@latticexyz/world/out/IBaseWorld.sol/IBaseWorld.abi.json";import{writeContract as Xo}from"viem/actions";import{getAction as $o}from"viem/utils";import{toHex as Uo}from"viem";import{signTypedData as Go}from"viem/actions";import{callWithSignatureTypes as Qo}from"@latticexyz/world/internal";import{getRecord as Vo}from"@latticexyz/store/internal";import _o from"@latticexyz/world-modules/internal/mud.config";import{hexToResource as Yo}from"@latticexyz/common";import{getAction as jo}from"viem/utils";async function mt({userClient:e,worldAddress:t,systemId:r,callData:o,nonce:n,client:a}){let c=n??(a?(await Vo(a,{address:t,table:_o.tables.CallWithSignatureNonces,key:{signer:e.account.address},blockTag:"pending"})).nonce:0n),{namespace:l,name:d}=Yo(r);return await jo(e,Go,"signTypedData")({account:e.account,domain:{verifyingContract:t,salt:Uo(e.chain.id,{size:32})},types:Qo,primaryType:"Call",message:{signer:e.account.address,systemNamespace:l,systemName:d,callData:o,nonce:c}})}import Jo from"@latticexyz/world-modules/out/Unstable_CallWithSignatureSystem.sol/Unstable_CallWithSignatureSystem.abi.json";async function ge({sessionClient:e,...t}){let r=await mt(t);return $o(e,Xo,"writeContract")({address:t.worldAddress,abi:Jo,functionName:"callWithSignature",args:[t.userClient.account.address,t.systemId,t.callData,r]})}function gt({userClient:e}){let t=en(),{chainId:r,worldAddress:o,paymasterAddress:n}=m(),a=nn({chainId:r}),c=["setupSession",a?.chain.id,e.account.address];return Zo({mutationKey:c,onError:l=>console.error(l),mutationFn:async({sessionClient:l,registerSpender:d,registerDelegation:i})=>{if(!a)throw new Error("Client not ready.");let s=l.account.address;if(console.log("setting up session"),e.account.type!=="smart"){let p=[];if(d){console.log("registering spender");let u=await ge({client:a,userClient:e,sessionClient:l,worldAddress:n,systemId:ft({type:"system",namespace:"",name:"SpenderSystem"}),callData:ut({abi:le,functionName:"registerSpender",args:[s]})});console.log("got spender tx",u),p.push(u)}if(i){console.log("registering delegation");let u=await ge({client:a,userClient:e,sessionClient:l,worldAddress:o,systemId:ft({type:"system",namespace:"",name:"Registration"}),callData:ut({abi:an,functionName:"registerDelegation",args:[s,R,"0x"]})});console.log("got delegation tx",u),p.push(u)}if(!p.length)return;console.log("waiting for",p.length,"receipts");for(let u of p){let h=await he(a,on,"waitForTransactionReceipt")({hash:u});console.log("got tx receipt",h),h.status==="reverted"&&console.error("tx reverted?",h)}}else{let p=[];if(d&&(console.log("registering spender"),p.push({to:n,abi:le,functionName:"registerSpender",args:[s]})),i&&(console.log("registering delegation"),p.push({to:o,abi:Ue,functionName:"registerDelegation",args:[s,R,"0x"]})),!p.length)return;console.log("setting up account with",p,e);let u=await he(e,tn,"sendUserOperation")({calls:p});console.log("got user op hash",u);let h=await he(e,rn,"waitForUserOperationReceipt")({hash:u});console.log("got user op receipt",h),h.success||console.error("not successful?",h)}await Promise.all([t.invalidateQueries({queryKey:["getSpender"]}),t.invalidateQueries({queryKey:["getDelegation"]}),t.invalidateQueries({queryKey:["getPrerequisites"]})])},retry:0})}import{useEffect as fn}from"react";import{useClient as dn}from"wagmi";import{queryOptions as pn,useQuery as mn}from"@tanstack/react-query";import{smartAccountActions as sn}from"permissionless";import{callFrom as cn}from"@latticexyz/world/internal";import{observer as ln}from"@latticexyz/explorer/observer";async function ht({client:e,userAddress:t,sessionAccount:r,worldAddress:o,paymasterAddress:n}){let a=U(e.chain);return q({paymasterAddress:n,transport:a,client:e,account:r}).extend(sn()).extend(cn({worldAddress:o,delegatorAddress:t,publicClient:e})).extend(ln()).extend(()=>({userAddress:t}))}function un({sessionAccount:e,client:t,userAddress:r,worldAddress:o,paymasterAddress:n}){let a=["getSessionClient",t?.uid,r,e?.address,o];return pn(t&&r&&e?{queryKey:a,queryFn:()=>ht({sessionAccount:e,client:t,userAddress:r,worldAddress:o,paymasterAddress:n}),staleTime:1/0}:{queryKey:a,enabled:!1})}function $(e){let{chainId:t,worldAddress:r,paymasterAddress:o}=m(),n=dn({chainId:t}),{data:a}=at(e);return mn(un({sessionAccount:a,userAddress:e,client:n,worldAddress:r,paymasterAddress:o}))}import{jsx as O,jsxs as ye}from"react/jsx-runtime";function yt({isActive:e,isExpanded:t,userClient:r,registerSpender:o,registerDelegation:n}){let{data:a}=$(r.account.address),c=gt({userClient:r}),l=!n&&!n;return fn(()=>{let d=setTimeout(()=>{e&&c.status==="idle"&&a&&!l&&c.mutate({sessionClient:a,registerSpender:o,registerDelegation:n})});return()=>clearTimeout(d)},[l,e,n,o,a,c]),ye("div",{className:"flex flex-col gap-4",children:[ye("div",{className:"flex justify-between gap-4",children:[ye("div",{children:[O("div",{children:"Session"}),O("div",{className:"font-mono text-white",children:l?"Enabled":"Set up"})]}),l?O(w,{variant:"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,disabled:!0,children:"Enabled"}):O(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,pending:!a||c.status==="pending",onClick:a?()=>c.mutate({sessionClient:a,registerSpender:o,registerDelegation:n}):void 0,children:"Enable"})]}),t?O("p",{className:"text-sm",children:"You can perform actions in this app without interruptions for approvals."}):null]})}import{jsx as E}from"react/jsx-runtime";function wt({userClient:e,initialUserAddress:t}){let r=e.account.address,{data:o}=P(r),{closeAccountModal:n}=y(),a=r!==t,c=yn(o);gn(()=>{o!=null&&(c.current==null&&(c.current=o),o.complete&&(a||!c.current.complete)&&n())},[n,a,o]);let{hasAllowance:l,isSpender:d,hasDelegation:i}=o??{},s=hn(()=>r?[{id:"wallet",isComplete:!0,content:f=>E(it,{...f,userAddress:r})},{id:"allowance",isComplete:!!l,content:f=>E(pt,{...f,userAddress:r})},{id:"session",isComplete:!!d&&!!i,content:f=>E(yt,{...f,userClient:e,registerSpender:!d,registerDelegation:!i})}]:[{id:"wallet",isComplete:!1,content:()=>null}],[l,i,d,r,e]),[p]=wn(null),u=s.find(f=>f.content!=null&&!f.isComplete),h=s.filter(f=>f.isComplete),te=(p!=null?s.find(f=>f.id===p):null)??u??(h.length<s.length?h.at(-1):null),xe=te?s.indexOf(te):-1;return E("div",{className:we("min-h-[26rem] px-8 flex flex-col divide-y divide-neutral-800","animate-in animate-duration-300 fade-in slide-in-from-bottom-8"),children:s.map((f,Kt)=>{let re=f===te,Ot=re||h.length===s.length,Bt=!f.isComplete&&xe!==-1&&Kt>xe;return E("div",{className:we("py-8 flex flex-col justify-center",re?"flex-grow":null),children:E("div",{className:we("flex flex-col",Bt?"opacity-30 pointer-events-none":null),children:f.content({isActive:re,isExpanded:Ot})})},f.id)})})}import{useRef as vn}from"react";import{jsx as bt}from"react/jsx-runtime";function xt(){let{chainId:e}=m(),t=xn({chainId:e}),{address:r}=bn(),o=vn(r);return t.status!=="success"?bt(Xe,{}):bt(wt,{userClient:t.data,initialUserAddress:o.current})}import{useState as Pn}from"react";import{ErrorBoundary as Nn}from"react-error-boundary";import{twMerge as Cn}from"tailwind-merge";import{BaseError as kn,UserRejectedRequestError as An}from"viem";import{jsx as vt,jsxs as Sn}from"react/jsx-runtime";function Ct({title:e,error:t}){if(!t||t instanceof kn&&t.walk(n=>n instanceof An)!=null)return null;let r=e??"Error",o=typeof t=="string"?t:t instanceof Error?String(t):"Something unexpected happened.";return Sn("div",{className:Cn("text-sm border-l-4 border-red-500","bg-red-100 text-red-900","dark:bg-red-900 dark:text-red-50"),children:[vt("div",{className:"p-3 font-semibold",children:r}),vt("div",{className:"px-3 whitespace-break-spaces break-all max-h-32 overflow-y-scroll",children:o})]})}import{wait as En}from"@latticexyz/common/utils";import{twMerge as Mn}from"tailwind-merge";import{useIsMounted as In}from"usehooks-ts";import{jsx as J,jsxs as kt}from"react/jsx-runtime";function At({children:e}){let t=In(),[r,o]=Pn(1);return J(Nn,{fallbackRender:({error:n,resetErrorBoundary:a})=>kt("div",{className:Mn("flex-grow flex flex-col justify-center p-5 gap-2"),children:[J(Ct,{error:n instanceof Error?n.stack??n.message:n}),r>0?kt("button",{type:"button",onClick:async c=>{c.currentTarget.ariaBusy="true",await En(1e3),a(),t()&&(o(l=>l-1),c.currentTarget.ariaBusy=null)},className:"group aria-busy:pointer-events-none self-end flex items-center gap-1",children:[J(v,{className:"transition opacity-0 group-aria-busy:opacity-100 text-xs text-neutral-500 dark:text-neutral-400"}),J("span",{className:"text-sm text-neutral-500 dark:text-neutral-400 group-hover:text-black dark:group-hover:text-white",children:"Retry?"})]}):null]}),children:e})}import{DialogClose as Rn,DialogTitle as zn}from"@radix-ui/react-dialog";import{twMerge as Tn}from"tailwind-merge";import{jsx as Hn}from"react/jsx-runtime";function St({className:e,children:t,...r}){return Hn("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:Tn("-my-[0.125em] h-[1.25em] w-[1.25em]",e),...r,children:t})}import{jsx as Pt}from"react/jsx-runtime";function Nt(e){return Pt(St,{strokeWidth:"2",stroke:"currentColor",...e,children:Pt("path",{d:"M6 18L18 6M6 6L18 18",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}import{jsx as b,jsxs as be}from"react/jsx-runtime";function Mt(){let{accountModalOpen:e,toggleAccountModal:t}=y();return be(Re,{open:e,onOpenChange:t,children:[b(zn,{className:"sr-only",children:"Connect with EntryKit"}),e?be("div",{className:Et("relative py-2 ring-1","bg-neutral-900 text-neutral-400 ring-neutral-700/50 divide-neutral-700","links:font-medium links:underline links:underline-offset-4","links:text-white","links:decoration-neutral-500 hover:links:decoration-orange-500"),children:[b(At,{children:b(xt,{})}),be("a",{href:"https://mud.dev",target:"_blank",rel:"noreferrer noopener",className:"group self-center p-3 flex items-center justify-center gap-2 links-unset text-sm font-mono transition text-neutral-400 hover:text-white",children:[b("span",{className:"block w-4 h-4",children:b(C,{className:"w-full h-full text-orange-500 group-hover:rotate-90 transition duration-300"})}),b("span",{children:"Powered by MUD"})]}),b("div",{className:"absolute top-0 right-0",children:b(Rn,{className:Et("pointer-events-auto leading-none p-2 transition","text-neutral-700 hover:text-neutral-500"),title:"Close",children:b(Nt,{className:"m-0"})})})]}):null]})}import{jsx as Kn,jsxs as On}from"react/jsx-runtime";function Dn({config:e,children:t}){return On(Ee,{config:e,children:[t,Kn(Mt,{})]})}import{useAccount as Fn}from"wagmi";import{twMerge as k}from"tailwind-merge";import{twMerge as It}from"tailwind-merge";import{Fragment as Bn,jsx as Z,jsxs as Tt}from"react/jsx-runtime";function Ht({address:e}){let{data:t}=Y(e),r=G(t?.avatar);return Tt(Bn,{children:[Tt("span",{className:"flex-shrink-0 w-6 h-6 -my-1 -mx-0.5 grid place-items-center",children:[Z("img",{src:t?.avatar&&r.isSuccess?t.avatar:void 0,className:It("col-start-1 row-start-1","inline-flex w-full h-full rounded-full bg-black/10 dark:bg-white/10 bg-cover bg-no-repeat bg-center","transtion duration-300",r.isSuccess?"opacity-100":"opacity-0")}),Z(C,{className:It("col-start-1 row-start-1 text-orange-500","transition duration-300",t&&(!t.avatar||r.isError)?"opacity-100":"opacity-0")})]}),Z("span",{className:"flex-grow",children:t?.name??Z(j,{hex:e})})]})}import{useRef as Ln}from"react";import{jsx as x,jsxs as zt}from"react/jsx-runtime";var Rt=k("w-48 p-3 inline-flex outline-none transition","border border-transparent","text-base leading-none"),Wn=k("bg-neutral-100 border-neutral-300 text-black","dark:bg-neutral-800 dark:border-neutral-700 dark:text-white"),qn=k("cursor-pointer outline-none hover:bg-neutral-200 data-[highlighted]:bg-neutral-200 dark:hover:bg-neutral-700");function Un(){let{openAccountModal:e,accountModalOpen:t}=y(),{status:r,address:o}=Fn(),n=Ln(o),a=P(o),c=r==="connected"||r==="reconnecting"&&o,l=o!==n.current,d=a.isSuccess?a.data.complete:l?!1:c,i=(()=>{if(a.isSuccess){if(!a.data.hasAllowance)return"Top up";if(!a.data.hasDelegation||!a.data.isSpender)return"Set up"}return"Sign in"})();return x(F,{mode:"child",children:d?x("button",{type:"button",className:k(Rt,Wn,qn),onClick:e,children:x("span",{className:"flex-grow inline-flex gap-2.5 items-center text-left font-medium",children:o?x(Ht,{address:o}):null})},"connected"):zt("button",{type:"button",className:k(Rt,"group","items-center justify-center gap-2.5","bg-orange-500 text-white font-medium","hover:bg-orange-400","active:bg-orange-600"),"aria-busy":t,onClick:e,children:[zt("span",{className:"pointer-events-none inline-grid place-items-center -ml-3",children:[x("span",{className:k("col-start-1 row-start-1 leading-none","scale-100 opacity-100 transition duration-300","group-aria-busy:scale-125 group-aria-busy:opacity-0"),children:x(C,{})}),x("span",{"aria-hidden":!0,className:k("col-start-1 row-start-1","scale-50 opacity-0 transition duration-300 delay-50","group-aria-busy:scale-100 group-aria-busy:opacity-100"),children:x(v,{})})]}),x("span",{className:"font-medium",children:i})]},"sign in")})}import{useConnectorClient as Gn}from"wagmi";function Qn(){let{chainId:e}=m(),t=Gn({chainId:e});t.error&&console.error("Error retrieving user client",t.error);let r=t.data?.account.address,o=P(r),n=$(r);return t.isSuccess?!o.isSuccess||!o.data.complete?{...o,data:void 0}:n:{...t,data:void 0}}import{connectorsForWallets as _n,getDefaultWallets as Yn}from"@rainbow-me/rainbowkit";import{createConfig as jn}from"wagmi";var Vn=`data:image/svg+xml;base64,${btoa('<svg xmlns="http://www.w3.org/2000/svg" shape-rendering="geometricPrecision" text-rendering="geometricPrecision" image-rendering="optimizeQuality" fill-rule="evenodd" clip-rule="evenodd" width="512" height="512" viewBox="-64 -32 608 512"><path d="M6.206 425.469A6.202 6.202 0 010 419.263c0-1.771.235-3.517.663-5.245 9.95-78.847 57.22-96.006 100.964-107.256 21.008-5.412 62.901-26.489 57.822-53.668-10.596-9.819-21.113-23.39-22.946-43.63l-1.274.026c-2.932-.044-5.778-.716-8.422-2.217-5.848-3.325-9.051-9.697-10.596-16.958-3.238-22.186-4.058-33.515 7.768-38.464l.096-.035c-1.467-27.37 3.159-67.64-24.944-76.141C154.622 7.1 218.597-30.203 266.627 30.805c53.519 2.801 77.389 78.611 44.154 121.046h-1.405c11.826 4.949 10.045 17.674 7.767 38.464-1.544 7.261-4.747 13.633-10.595 16.958-2.645 1.501-5.481 2.173-8.422 2.217l-1.275-.026c-1.833 20.24-12.376 33.811-22.972 43.63-4.459 23.871 27.275 43.011 49.33 50.997a139.442 139.442 0 004.268 5.525c-7.2 9.941-8.771 22.797-4.564 34.038-17.002 8.763-24.255 29.334-16.479 46.86-11.966 7.55-18.258 21.305-16.609 34.955H6.206zm419.058-105.362a86.778 86.778 0 0019.446-1.641c29.36-5.822 53.152-27.467 62.657-55.823 3.596-10.544 5.071-21.663 4.521-33.341-1.179-23.46-12.193-46.633-29.631-62.369-17.107-15.361-38.342-23.574-61.383-23.042-22.841.507-45.359 11.216-60.187 28.593-14.977 17.551-22.003 39.144-20.921 62.133.585 11.661 3.482 23.016 8.737 34.074 7.741 16.303 19.934 29.735 35.391 39.048l-22.457 20.711 13.232 27.86-29.413 13.973 13.991 29.456-26.769 12.717 16.81 35.374 35.601-16.915 40.375-110.808zm15.239-129.364c13.685 4.869 20.824 19.908 15.954 33.593-4.87 13.685-19.908 20.833-33.593 15.963-13.685-4.87-20.834-19.917-15.963-33.602 4.87-13.685 19.917-20.825 33.602-15.954z"/></svg>')}`,ee=e=>()=>({id:"passkey",name:"Passkey",iconUrl:Vn,iconBackground:"#fec",createConnector:t=>r=>({...S(e)(r),...t})});import{mapObject as Xn}from"@latticexyz/common/utils";import{wiresaw as $n}from"@latticexyz/wiresaw/internal";function Jn(e){let{wallets:t}=Yn(),r=[{groupName:"Recommended",wallets:[ee({chainId:e.chainId})]},...t],o=_n(r,{appName:e.appName,projectId:e.walletConnectProjectId});return jn({connectors:o,chains:e.chains,transports:Xn(e.transports,n=>$n(n)),pollingInterval:e.pollingInterval})}import{connectorsForWallets as ea}from"@rainbow-me/rainbowkit";import{getDefaultWallets as Zn}from"@rainbow-me/rainbowkit";function Dt(e){let{wallets:t}=Zn();return[{groupName:"Recommended",wallets:[ee({chainId:e.chainId})]},...t]}function cm({wallets:e,...t}){return ea(e??Dt(t),{appName:t.appName,projectId:t.walletConnectProjectId})}export{Un as AccountButton,Dn as EntryKitProvider,Jn as createWagmiConfig,Ft as defineConfig,cm as getConnectors,Dt as getWallets,S as passkeyConnector,ee as passkeyWallet,y as useAccountModal,m as useEntryKitConfig,Qn as useSessionClient};
1441
+ URL: ${e}`)),o.src=e})})}import{jsx as Q,jsxs as to}from"react/jsx-runtime";function _e(){let{appName:e,appIcon:t}=m(),{data:r,isLoading:o}=G(t);return to("div",{className:"flex-grow flex flex-col items-center justify-center gap-2",children:[Q("div",{className:"w-16 h-16 m-2",children:o?null:r?Q("img",{src:t,className:"w-full h-full object-cover"}):Q(C,{className:"w-full h-full text-orange-500 dark:bg-neutral-800"})}),Q("div",{className:"text-2xl text-white text-center",children:e})]})}import{twMerge as no}from"tailwind-merge";import{jsx as z,jsxs as je}from"react/jsx-runtime";function Xe(){let e=ro(),{accountModalOpen:t}=y(),{openConnectModal:r,connectModalOpen:o}=oo(),n=Ve(),a=Ye({onError:i=>console.error(i),mutationKey:["createPasskey",n.id,t,o,e.status],mutationFn:()=>n.createPasskey()}),c=Ye({onError:i=>console.error(i),mutationKey:["reusePasskey",n.id,t,o,e.status],mutationFn:()=>n.reusePasskey()}),l=n.hasPasskey(),d=[z(w,{variant:l?"tertiary":"secondary",className:"self-auto flex justify-center",pending:a.status==="pending"||a.status==="success",onClick:()=>a.mutate(),autoFocus:!l,children:"Create account"},"create"),z(w,{variant:l?"secondary":"tertiary",className:"self-auto flex justify-center",pending:c.status==="pending"||c.status==="success",onClick:()=>c.mutate(),autoFocus:l,children:"Sign in"},"signin")];return l&&d.reverse(),je("div",{className:no("flex flex-col gap-6 p-6","animate-in animate-duration-300 fade-in slide-in-from-bottom-8"),children:[z("div",{className:"p-4",children:z(_e,{})}),je("div",{className:"self-center flex flex-col gap-2 w-60",children:[d,z("button",{className:"text-sm self-center transition text-neutral-500 hover:text-white p-2",disabled:e.status==="connecting",onClick:r,children:"Already have a wallet?"})]})]})}import{useEffect as hn,useMemo as yn,useRef as wn,useState as bn}from"react";import{twMerge as we}from"tailwind-merge";import{parseEther as ao}from"viem";var V=ao("0.01");import{useClient as po}from"wagmi";import{queryOptions as mo,useQuery as uo}from"@tanstack/react-query";import{defineStore as io}from"@latticexyz/store";import{parseAbi as so}from"viem";var le=so(["error SpenderSystem_AlreadyRegistered(address spender, address user)","error SpenderSystem_HasOwnBalance(address spender)","function registerSpender(address spender)"]),co=io({namespaces:{root:{namespace:"",tables:{Allowance:{schema:{user:"address",allowance:"uint256"},key:["user"]},Grantor:{schema:{grantor:"address",allowance:"uint256"},key:["grantor"]},PassHolder:{schema:{user:"address",passId:"bytes32",lastRenewed:"uint256",lastClaimed:"uint256"},key:["user","passId"]},PassConfig:{schema:{passId:"bytes32",claimAmount:"uint256",claimInterval:"uint256",validityPeriod:"uint256",grantor:"address"},key:["passId"]},Spender:{schema:{spender:"address",user:"address"},key:["spender"]},SystemConfig:{schema:{entryPoint:"address"},key:[]}}}}}),_=co.namespaces.root.tables;import{getRecord as lo}from"@latticexyz/store/internal";async function $e({client:e,paymasterAddress:t,userAddress:r}){return(await lo(e,{address:t,table:_.Allowance,key:{user:r},blockTag:"pending"})).allowance}function de({client:e,paymasterAddress:t,userAddress:r}){let o=["getAllowance",e?.chain.id,t,r];return mo(e&&r?{queryKey:o,queryFn:()=>$e({client:e,paymasterAddress:t,userAddress:r})}:{queryKey:o,enabled:!1})}function Je(e){let{chainId:t,paymasterAddress:r}=m(),o=po({chainId:t});return uo(de({client:o,paymasterAddress:r,userAddress:e}))}import{useClient as rc}from"wagmi";import{queryOptions as go,useQuery as nc}from"@tanstack/react-query";import{getRecord as fo}from"@latticexyz/store/internal";async function Ze({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o}){return(await fo(e,{address:t,table:_.Spender,key:{spender:o},blockTag:"pending"})).user.toLowerCase()===r.toLowerCase()}function et({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o}){let n=["getSpender",e?.chain.id,t,r,o];return go(e&&r&&o?{queryKey:n,queryFn:()=>Ze({client:e,paymasterAddress:t,userAddress:r,sessionAddress:o})}:{queryKey:n,enabled:!1})}import{useClient as mc}from"wagmi";import{queryOptions as yo,useQuery as fc}from"@tanstack/react-query";import{getRecord as ho}from"@latticexyz/store/internal";async function tt({client:e,worldAddress:t,userAddress:r,sessionAddress:o}){return(await ho(e,{address:t,table:qe.UserDelegationControl,key:{delegator:r,delegatee:o},blockTag:"pending"})).delegationControlId===R}function rt({client:e,worldAddress:t,userAddress:r,sessionAddress:o}){let n=["getDelegation",e?.chain.id,t,r,o];return yo(e&&r&&o?{queryKey:n,queryFn:()=>tt({client:e,worldAddress:t,userAddress:r,sessionAddress:o})}:{queryKey:n,enabled:!1})}import{queryOptions as No,useQuery as Eo,useQueryClient as Mo}from"@tanstack/react-query";import{useClient as Io}from"wagmi";import{useClient as Ao}from"wagmi";import{queryOptions as So,useQuery as Po}from"@tanstack/react-query";import{toCoinbaseSmartAccount as ko}from"@latticexyz/common/accounts";import{createStore as wo}from"zustand/vanilla";import{persist as bo}from"zustand/middleware";var D=wo(bo(()=>({signers:{}}),{name:"mud:entrykit",partialize:({signers:e})=>({signers:e})}));function xo(e){e.key===D.persist.getOptions().name&&D.persist.rehydrate()}window.addEventListener("storage",xo);import{generatePrivateKey as vo,privateKeyToAccount as Co}from"viem/accounts";function ot(e){let t=D.getState().signers[e]??(()=>{let r=vo();return D.setState(o=>({signers:{...o.signers,[e]:r}})),r})();return Co(t)}async function nt({client:e,userAddress:t}){let r=ot(t);return await ko({client:e,owners:[r]})}function pe({client:e,userAddress:t}){let r=["getSessionAccount",e?.chain.id,t];return So(e&&t?{queryKey:r,queryFn:()=>nt({client:e,userAddress:t}),staleTime:1/0}:{queryKey:r,enabled:!1})}function at(e){let{chainId:t}=m(),r=Ao({chainId:t});return Po(pe({userAddress:e,client:r}))}function To({queryClient:e,client:t,userAddress:r,paymasterAddress:o,worldAddress:n}){let a=["getPrerequisites",t?.chain.id,r];return No(t&&r?{queryKey:a,queryFn:async()=>{let{address:c}=await e.fetchQuery(pe({client:t,userAddress:r})),[l,d,i]=await Promise.all([e.fetchQuery(de({client:t,paymasterAddress:o,userAddress:r})),e.fetchQuery(et({client:t,paymasterAddress:o,userAddress:r,sessionAddress:c})),e.fetchQuery(rt({client:t,worldAddress:n,userAddress:r,sessionAddress:c}))]),s=l>=V;return{hasAllowance:s,isSpender:d,hasDelegation:i,complete:s&&d&&i}}}:{queryKey:a,enabled:!1})}function P(e){let t=Mo(),{chainId:r,paymasterAddress:o,worldAddress:n}=m(),a=Io({chainId:r});return Eo(To({queryClient:t,client:a,userAddress:e,paymasterAddress:o,worldAddress:n}),t)}import{useDisconnect as zo}from"wagmi";import{useQuery as Ho}from"@tanstack/react-query";function Y(e){let t=e?.toLowerCase();return Ho({enabled:!!t,queryKey:["ens",t],queryFn:async()=>{let r=await fetch(`https://api.ensideas.com/ens/resolve/${t}`).then(o=>o.json());return{address:r.address??void 0,name:r.name??void 0,displayName:r.displayName??void 0,avatar:r.avatar??void 0}}})}import{jsx as me,jsxs as Ro}from"react/jsx-runtime";function j({hex:e}){return e.length<=10?me("span",{title:e,children:e}):Ro("span",{title:e,children:[me("span",{className:"after:select-none after:content-['\u2026']",children:e.slice(0,6)}),me("span",{className:"tracking-[-1ch] text-transparent",children:e.slice(6,-4)}),e.slice(-4)]})}import{jsx as K,jsxs as ue}from"react/jsx-runtime";function it({isActive:e,isExpanded:t,userAddress:r}){let{data:o}=Y(r),{disconnect:n,isPending:a}=zo(),{closeAccountModal:c}=y();return ue("div",{className:"flex flex-col gap-4",children:[ue("div",{className:"flex justify-between gap-4",children:[ue("div",{children:[K("div",{children:"Account"}),K("div",{className:"font-mono text-white",children:o?.name??K(j,{hex:r})})]}),K(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,pending:a,onClick:()=>{c(),n()},children:"Sign out"})]}),t?K("p",{className:"text-sm",children:"Each of your onchain actions in this app is associated with your account."}):null]})}import{useMutation as Do,useQueryClient as Ko}from"@tanstack/react-query";import{claimGasPass as Oo}from"@latticexyz/paymaster/internal";function st(){let e=Ko(),{chain:t}=m(),r=["claimGasPass",t.id];return Do({mutationKey:r,onError:o=>console.error(o),mutationFn:async o=>{await Oo({chain:t,userAddress:o}),await Promise.all([e.invalidateQueries({queryKey:["getAllowance"]}),e.invalidateQueries({queryKey:["getPrerequisites"]})])},retry:0})}import{twMerge as Bo}from"tailwind-merge";import{jsx as X,jsxs as Fo}from"react/jsx-runtime";function ct({className:e,...t}){return Fo("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 263 428",fill:"currentColor",className:Bo("w-[0.6em] h-[1em]",e),...t,children:[X("path",{d:"M132 321V428L263 243L132 321Z"}),X("path",{d:"M0 243L132 321V428",fillOpacity:"0.5"}),X("path",{d:"M132 0V296L263 218"}),X("path",{d:"M0 218L132 296V0L0 218Z",fillOpacity:"0.5"})]})}import{formatEther as Lo}from"viem";function lt(e){let t=Lo(e),r=Math.floor(parseFloat(t)).toString().length;return parseFloat(t).toLocaleString("en-US",{maximumFractionDigits:Math.max(0,6-r)})}import{jsx as Wo,jsxs as qo}from"react/jsx-runtime";function dt({wei:e}){return qo("span",{className:"inline-flex items-center gap-1",children:[lt(e)," ",Wo(ct,{})]})}import{useEffect as Uo}from"react";import{jsx as N,jsxs as fe}from"react/jsx-runtime";function pt({isActive:e,isExpanded:t,userAddress:r}){let o=Je(r),n=st();return Uo(()=>{let a=setTimeout(()=>{e&&n.status==="idle"&&o.isSuccess&&o.data<V&&n.mutate(r)});return()=>clearTimeout(a)},[o.data,o.isSuccess,n,e,r]),fe("div",{className:"flex flex-col gap-4",children:[fe("div",{className:"flex justify-between gap-4",children:[fe("div",{children:[N("div",{children:"Allowance"}),N("div",{className:"font-mono text-white",children:o.data!=null?N(dt,{wei:o.data}):N(v,{className:"text-sm"})})]}),N(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e||t,pending:o.status==="pending"||n.status==="pending",onClick:()=>n.mutate(r),children:"Top up"})]}),t?N("p",{className:"text-sm",children:"Your allowance is used to pay for onchain computation."}):null]})}import{encodeFunctionData as ut}from"viem";import{useMutation as en,useQueryClient as tn}from"@tanstack/react-query";import{getAction as he}from"viem/utils";import{sendUserOperation as rn,waitForUserOperationReceipt as on}from"viem/account-abstraction";import{waitForTransactionReceipt as nn}from"viem/actions";import{useClient as an}from"wagmi";import{resourceToHex as ft}from"@latticexyz/common";import sn from"@latticexyz/world/out/IBaseWorld.sol/IBaseWorld.abi.json";import{writeContract as $o}from"viem/actions";import{getAction as Jo}from"viem/utils";import{toHex as Go}from"viem";import{signTypedData as Qo}from"viem/actions";import{callWithSignatureTypes as Vo}from"@latticexyz/world/internal";import{getRecord as _o}from"@latticexyz/store/internal";import Yo from"@latticexyz/world-modules/internal/mud.config";import{hexToResource as jo}from"@latticexyz/common";import{getAction as Xo}from"viem/utils";async function mt({userClient:e,worldAddress:t,systemId:r,callData:o,nonce:n,client:a}){let c=n??(a?(await _o(a,{address:t,table:Yo.tables.CallWithSignatureNonces,key:{signer:e.account.address},blockTag:"pending"})).nonce:0n),{namespace:l,name:d}=jo(r);return await Xo(e,Qo,"signTypedData")({account:e.account,domain:{verifyingContract:t,salt:Go(e.chain.id,{size:32})},types:Vo,primaryType:"Call",message:{signer:e.account.address,systemNamespace:l,systemName:d,callData:o,nonce:c}})}import Zo from"@latticexyz/world-modules/out/Unstable_CallWithSignatureSystem.sol/Unstable_CallWithSignatureSystem.abi.json";async function ge({sessionClient:e,...t}){let r=await mt(t);return Jo(e,$o,"writeContract")({address:t.worldAddress,abi:Zo,functionName:"callWithSignature",args:[t.userClient.account.address,t.systemId,t.callData,r]})}function gt({userClient:e}){let t=tn(),{chainId:r,worldAddress:o,paymasterAddress:n}=m(),a=an({chainId:r}),c=["setupSession",a?.chain.id,e.account.address];return en({mutationKey:c,onError:l=>console.error(l),mutationFn:async({sessionClient:l,registerSpender:d,registerDelegation:i})=>{if(!a)throw new Error("Client not ready.");let s=l.account.address;if(console.log("setting up session"),e.account.type!=="smart"){let p=[];if(d){console.log("registering spender");let u=await ge({client:a,userClient:e,sessionClient:l,worldAddress:n,systemId:ft({type:"system",namespace:"",name:"SpenderSystem"}),callData:ut({abi:le,functionName:"registerSpender",args:[s]})});console.log("got spender tx",u),p.push(u)}if(i){console.log("registering delegation");let u=await ge({client:a,userClient:e,sessionClient:l,worldAddress:o,systemId:ft({type:"system",namespace:"",name:"Registration"}),callData:ut({abi:sn,functionName:"registerDelegation",args:[s,R,"0x"]})});console.log("got delegation tx",u),p.push(u)}if(!p.length)return;console.log("waiting for",p.length,"receipts");for(let u of p){let h=await he(a,nn,"waitForTransactionReceipt")({hash:u});console.log("got tx receipt",h),h.status==="reverted"&&console.error("tx reverted?",h)}}else{let p=[];if(d&&(console.log("registering spender"),p.push({to:n,abi:le,functionName:"registerSpender",args:[s]})),i&&(console.log("registering delegation"),p.push({to:o,abi:Ue,functionName:"registerDelegation",args:[s,R,"0x"]})),!p.length)return;console.log("setting up account with",p,e);let u=await he(e,rn,"sendUserOperation")({calls:p});console.log("got user op hash",u);let h=await he(e,on,"waitForUserOperationReceipt")({hash:u});console.log("got user op receipt",h),h.success||console.error("not successful?",h)}await Promise.all([t.invalidateQueries({queryKey:["getSpender"]}),t.invalidateQueries({queryKey:["getDelegation"]}),t.invalidateQueries({queryKey:["getPrerequisites"]})])},retry:0})}import{useEffect as gn}from"react";import{useClient as pn}from"wagmi";import{queryOptions as mn,useQuery as un}from"@tanstack/react-query";import{smartAccountActions as cn}from"permissionless";import{callFrom as ln}from"@latticexyz/world/internal";import{observer as dn}from"@latticexyz/explorer/observer";async function ht({client:e,userAddress:t,sessionAccount:r,worldAddress:o,paymasterAddress:n}){let a=U(e.chain);return q({paymasterAddress:n,transport:a,client:e,account:r}).extend(cn()).extend(ln({worldAddress:o,delegatorAddress:t,publicClient:e})).extend(dn()).extend(()=>({userAddress:t}))}function fn({sessionAccount:e,client:t,userAddress:r,worldAddress:o,paymasterAddress:n}){let a=["getSessionClient",t?.uid,r,e?.address,o];return mn(t&&r&&e?{queryKey:a,queryFn:()=>ht({sessionAccount:e,client:t,userAddress:r,worldAddress:o,paymasterAddress:n}),staleTime:1/0}:{queryKey:a,enabled:!1})}function $(e){let{chainId:t,worldAddress:r,paymasterAddress:o}=m(),n=pn({chainId:t}),{data:a}=at(e);return un(fn({sessionAccount:a,userAddress:e,client:n,worldAddress:r,paymasterAddress:o}))}import{jsx as O,jsxs as ye}from"react/jsx-runtime";function yt({isActive:e,isExpanded:t,userClient:r,registerSpender:o,registerDelegation:n}){let{data:a}=$(r.account.address),c=gt({userClient:r}),l=!n&&!n;return gn(()=>{let d=setTimeout(()=>{e&&c.status==="idle"&&a&&!l&&c.mutate({sessionClient:a,registerSpender:o,registerDelegation:n})});return()=>clearTimeout(d)},[l,e,n,o,a,c]),ye("div",{className:"flex flex-col gap-4",children:[ye("div",{className:"flex justify-between gap-4",children:[ye("div",{children:[O("div",{children:"Session"}),O("div",{className:"font-mono text-white",children:l?"Enabled":"Set up"})]}),l?O(w,{variant:"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,disabled:!0,children:"Enabled"}):O(w,{variant:e?"primary":"tertiary",className:"flex-shrink-0 text-sm p-1 w-28",autoFocus:e,pending:!a||c.status==="pending",onClick:a?()=>c.mutate({sessionClient:a,registerSpender:o,registerDelegation:n}):void 0,children:"Enable"})]}),t?O("p",{className:"text-sm",children:"You can perform actions in this app without interruptions for approvals."}):null]})}import{jsx as E}from"react/jsx-runtime";function wt({userClient:e,initialUserAddress:t}){let r=e.account.address,{data:o}=P(r),{closeAccountModal:n}=y(),a=r!==t,c=wn(o);hn(()=>{o!=null&&(c.current==null&&(c.current=o),o.complete&&(a||!c.current.complete)&&n())},[n,a,o]);let{hasAllowance:l,isSpender:d,hasDelegation:i}=o??{},s=yn(()=>r?[{id:"wallet",isComplete:!0,content:f=>E(it,{...f,userAddress:r})},{id:"allowance",isComplete:!!l,content:f=>E(pt,{...f,userAddress:r})},{id:"session",isComplete:!!d&&!!i,content:f=>E(yt,{...f,userClient:e,registerSpender:!d,registerDelegation:!i})}]:[{id:"wallet",isComplete:!1,content:()=>null}],[l,i,d,r,e]),[p]=bn(null),u=s.find(f=>f.content!=null&&!f.isComplete),h=s.filter(f=>f.isComplete),te=(p!=null?s.find(f=>f.id===p):null)??u??(h.length<s.length?h.at(-1):null),xe=te?s.indexOf(te):-1;return E("div",{className:we("min-h-[26rem] px-8 flex flex-col divide-y divide-neutral-800","animate-in animate-duration-300 fade-in slide-in-from-bottom-8"),children:s.map((f,Kt)=>{let re=f===te,Ot=re||h.length===s.length,Bt=!f.isComplete&&xe!==-1&&Kt>xe;return E("div",{className:we("py-8 flex flex-col justify-center",re?"flex-grow":null),children:E("div",{className:we("flex flex-col",Bt?"opacity-30 pointer-events-none":null),children:f.content({isActive:re,isExpanded:Ot})})},f.id)})})}import{useRef as Cn}from"react";import{jsx as bt}from"react/jsx-runtime";function xt(){let{chainId:e}=m(),t=vn({chainId:e}),{address:r}=xn(),o=Cn(r);return t.status!=="success"?bt(Xe,{}):bt(wt,{userClient:t.data,initialUserAddress:o.current})}import{useState as Nn}from"react";import{ErrorBoundary as En}from"react-error-boundary";import{twMerge as kn}from"tailwind-merge";import{BaseError as An,UserRejectedRequestError as Sn}from"viem";import{jsx as vt,jsxs as Pn}from"react/jsx-runtime";function Ct({title:e,error:t}){if(!t||t instanceof An&&t.walk(n=>n instanceof Sn)!=null)return null;let r=e??"Error",o=typeof t=="string"?t:t instanceof Error?String(t):"Something unexpected happened.";return Pn("div",{className:kn("text-sm border-l-4 border-red-500","bg-red-100 text-red-900","dark:bg-red-900 dark:text-red-50"),children:[vt("div",{className:"p-3 font-semibold",children:r}),vt("div",{className:"px-3 whitespace-break-spaces break-all max-h-32 overflow-y-scroll",children:o})]})}import{wait as Mn}from"@latticexyz/common/utils";import{twMerge as In}from"tailwind-merge";import{useIsMounted as Tn}from"usehooks-ts";import{jsx as J,jsxs as kt}from"react/jsx-runtime";function At({children:e}){let t=Tn(),[r,o]=Nn(1);return J(En,{fallbackRender:({error:n,resetErrorBoundary:a})=>kt("div",{className:In("flex-grow flex flex-col justify-center p-5 gap-2"),children:[J(Ct,{error:n instanceof Error?n.stack??n.message:n}),r>0?kt("button",{type:"button",onClick:async c=>{c.currentTarget.ariaBusy="true",await Mn(1e3),a(),t()&&(o(l=>l-1),c.currentTarget.ariaBusy=null)},className:"group aria-busy:pointer-events-none self-end flex items-center gap-1",children:[J(v,{className:"transition opacity-0 group-aria-busy:opacity-100 text-xs text-neutral-500 dark:text-neutral-400"}),J("span",{className:"text-sm text-neutral-500 dark:text-neutral-400 group-hover:text-black dark:group-hover:text-white",children:"Retry?"})]}):null]}),children:e})}import{DialogClose as zn,DialogTitle as Dn}from"@radix-ui/react-dialog";import{twMerge as Hn}from"tailwind-merge";import{jsx as Rn}from"react/jsx-runtime";function St({className:e,children:t,...r}){return Rn("svg",{xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24",fill:"currentColor",className:Hn("-my-[0.125em] h-[1.25em] w-[1.25em]",e),...r,children:t})}import{jsx as Pt}from"react/jsx-runtime";function Nt(e){return Pt(St,{strokeWidth:"2",stroke:"currentColor",...e,children:Pt("path",{d:"M6 18L18 6M6 6L18 18",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}import{jsx as b,jsxs as be}from"react/jsx-runtime";function Mt(){let{accountModalOpen:e,toggleAccountModal:t}=y();return be(Re,{open:e,onOpenChange:t,children:[b(Dn,{className:"sr-only",children:"Connect with EntryKit"}),e?be("div",{className:Et("relative py-2 ring-1","bg-neutral-900 text-neutral-400 ring-neutral-700/50 divide-neutral-700","links:font-medium links:underline links:underline-offset-4","links:text-white","links:decoration-neutral-500 hover:links:decoration-orange-500"),children:[b(At,{children:b(xt,{})}),be("a",{href:"https://mud.dev",target:"_blank",rel:"noreferrer noopener",className:"group self-center p-3 flex items-center justify-center gap-2 links-unset text-sm font-mono transition text-neutral-400 hover:text-white",children:[b("span",{className:"block w-4 h-4",children:b(C,{className:"w-full h-full text-orange-500 group-hover:rotate-90 transition duration-300"})}),b("span",{children:"Powered by MUD"})]}),b("div",{className:"absolute top-0 right-0",children:b(zn,{className:Et("pointer-events-auto leading-none p-2 transition","text-neutral-700 hover:text-neutral-500"),title:"Close",children:b(Nt,{className:"m-0"})})})]}):null]})}import{jsx as On,jsxs as Bn}from"react/jsx-runtime";function Kn({config:e,children:t}){return Bn(Ee,{config:e,children:[t,On(Mt,{})]})}import{useAccount as Ln}from"wagmi";import{twMerge as k}from"tailwind-merge";import{twMerge as It}from"tailwind-merge";import{Fragment as Fn,jsx as Z,jsxs as Tt}from"react/jsx-runtime";function Ht({address:e}){let{data:t}=Y(e),r=G(t?.avatar);return Tt(Fn,{children:[Tt("span",{className:"flex-shrink-0 w-6 h-6 -my-1 -mx-0.5 grid place-items-center",children:[Z("img",{src:t?.avatar&&r.isSuccess?t.avatar:void 0,className:It("col-start-1 row-start-1","inline-flex w-full h-full rounded-full bg-black/10 dark:bg-white/10 bg-cover bg-no-repeat bg-center","transtion duration-300",r.isSuccess?"opacity-100":"opacity-0")}),Z(C,{className:It("col-start-1 row-start-1 text-orange-500","transition duration-300",t&&(!t.avatar||r.isError)?"opacity-100":"opacity-0")})]}),Z("span",{className:"flex-grow",children:t?.name??Z(j,{hex:e})})]})}import{useRef as Wn}from"react";import{jsx as x,jsxs as zt}from"react/jsx-runtime";var Rt=k("w-48 p-3 inline-flex outline-none transition","border border-transparent","text-base leading-none"),qn=k("bg-neutral-100 border-neutral-300 text-black","dark:bg-neutral-800 dark:border-neutral-700 dark:text-white"),Un=k("cursor-pointer outline-none hover:bg-neutral-200 data-[highlighted]:bg-neutral-200 dark:hover:bg-neutral-700");function Gn(){let{openAccountModal:e,accountModalOpen:t}=y(),{status:r,address:o}=Ln(),n=Wn(o),a=P(o),c=r==="connected"||r==="reconnecting"&&o,l=o!==n.current,d=a.isSuccess?a.data.complete:l?!1:c,i=(()=>{if(a.isSuccess){if(!a.data.hasAllowance)return"Top up";if(!a.data.hasDelegation||!a.data.isSpender)return"Set up"}return"Sign in"})();return x(F,{mode:"child",children:d?x("button",{type:"button",className:k(Rt,qn,Un),onClick:e,children:x("span",{className:"flex-grow inline-flex gap-2.5 items-center text-left font-medium",children:o?x(Ht,{address:o}):null})},"connected"):zt("button",{type:"button",className:k(Rt,"group","items-center justify-center gap-2.5","bg-orange-500 text-white font-medium","hover:bg-orange-400","active:bg-orange-600"),"aria-busy":t,onClick:e,children:[zt("span",{className:"pointer-events-none inline-grid place-items-center -ml-3",children:[x("span",{className:k("col-start-1 row-start-1 leading-none","scale-100 opacity-100 transition duration-300","group-aria-busy:scale-125 group-aria-busy:opacity-0"),children:x(C,{})}),x("span",{"aria-hidden":!0,className:k("col-start-1 row-start-1","scale-50 opacity-0 transition duration-300 delay-50","group-aria-busy:scale-100 group-aria-busy:opacity-100"),children:x(v,{})})]}),x("span",{className:"font-medium",children:i})]},"sign in")})}import{useConnectorClient as Qn}from"wagmi";function Vn(){let{chainId:e}=m(),t=Qn({chainId:e});t.error&&console.error("Error retrieving user client",t.error);let r=t.data?.account.address,o=P(r),n=$(r);return t.isSuccess?!o.isSuccess||!o.data.complete?{...o,data:void 0}:n:{...t,data:void 0}}import{connectorsForWallets as Yn,getDefaultWallets as jn}from"@rainbow-me/rainbowkit";import{createConfig as Xn}from"wagmi";var _n=`data:image/svg+xml;base64,${btoa('<svg xmlns="http://www.w3.org/2000/svg" shape-rendering="geometricPrecision" text-rendering="geometricPrecision" image-rendering="optimizeQuality" fill-rule="evenodd" clip-rule="evenodd" width="512" height="512" viewBox="-64 -32 608 512"><path d="M6.206 425.469A6.202 6.202 0 010 419.263c0-1.771.235-3.517.663-5.245 9.95-78.847 57.22-96.006 100.964-107.256 21.008-5.412 62.901-26.489 57.822-53.668-10.596-9.819-21.113-23.39-22.946-43.63l-1.274.026c-2.932-.044-5.778-.716-8.422-2.217-5.848-3.325-9.051-9.697-10.596-16.958-3.238-22.186-4.058-33.515 7.768-38.464l.096-.035c-1.467-27.37 3.159-67.64-24.944-76.141C154.622 7.1 218.597-30.203 266.627 30.805c53.519 2.801 77.389 78.611 44.154 121.046h-1.405c11.826 4.949 10.045 17.674 7.767 38.464-1.544 7.261-4.747 13.633-10.595 16.958-2.645 1.501-5.481 2.173-8.422 2.217l-1.275-.026c-1.833 20.24-12.376 33.811-22.972 43.63-4.459 23.871 27.275 43.011 49.33 50.997a139.442 139.442 0 004.268 5.525c-7.2 9.941-8.771 22.797-4.564 34.038-17.002 8.763-24.255 29.334-16.479 46.86-11.966 7.55-18.258 21.305-16.609 34.955H6.206zm419.058-105.362a86.778 86.778 0 0019.446-1.641c29.36-5.822 53.152-27.467 62.657-55.823 3.596-10.544 5.071-21.663 4.521-33.341-1.179-23.46-12.193-46.633-29.631-62.369-17.107-15.361-38.342-23.574-61.383-23.042-22.841.507-45.359 11.216-60.187 28.593-14.977 17.551-22.003 39.144-20.921 62.133.585 11.661 3.482 23.016 8.737 34.074 7.741 16.303 19.934 29.735 35.391 39.048l-22.457 20.711 13.232 27.86-29.413 13.973 13.991 29.456-26.769 12.717 16.81 35.374 35.601-16.915 40.375-110.808zm15.239-129.364c13.685 4.869 20.824 19.908 15.954 33.593-4.87 13.685-19.908 20.833-33.593 15.963-13.685-4.87-20.834-19.917-15.963-33.602 4.87-13.685 19.917-20.825 33.602-15.954z"/></svg>')}`,ee=e=>()=>({id:"passkey",name:"Passkey",iconUrl:_n,iconBackground:"#fec",createConnector:t=>r=>({...S(e)(r),...t})});import{mapObject as $n}from"@latticexyz/common/utils";import{wiresaw as Jn}from"@latticexyz/wiresaw/internal";function Zn(e){let{wallets:t}=jn(),r=[{groupName:"Recommended",wallets:[ee({chainId:e.chainId})]},...t],o=Yn(r,{appName:e.appName,projectId:e.walletConnectProjectId});return Xn({connectors:o,chains:e.chains,transports:$n(e.transports,n=>Jn(n)),pollingInterval:e.pollingInterval})}import{connectorsForWallets as ta}from"@rainbow-me/rainbowkit";import{getDefaultWallets as ea}from"@rainbow-me/rainbowkit";function Dt(e){let{wallets:t}=ea();return[{groupName:"Recommended",wallets:[ee({chainId:e.chainId})]},...t]}function lm({wallets:e,...t}){return ta(e??Dt(t),{appName:t.appName,projectId:t.walletConnectProjectId})}export{Gn as AccountButton,Kn as EntryKitProvider,Zn as createWagmiConfig,Ft as defineConfig,lm as getConnectors,Dt as getWallets,S as passkeyConnector,ee as passkeyWallet,y as useAccountModal,m as useEntryKitConfig,Vn as useSessionClient};
1442
1442
  //# sourceMappingURL=internal.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/config/defineConfig.ts","../../src/ui/Modal.tsx","../../src/ui/Shadow.tsx","../../src/ui/FrameProvider.tsx","../../src/useTheme.ts","../../src/EntryKitConfigProvider.tsx","../../src/getPaymasterAddress.ts","../../src/useAccountModal.ts","../../src/AccountModal.tsx","../../src/AccountModalContent.tsx","../../src/ConnectWallet.tsx","../../src/ui/Button.tsx","../../src/icons/PendingIcon.tsx","../../src/usePasskeyConnector.ts","../../src/passkey/passkeyConnector.ts","../../src/passkey/cache.ts","../../src/passkey/getAccount.ts","../../src/passkey/toWebAuthnAccount.ts","../../src/passkey/reusePasskey.ts","../../src/passkey/getMessageHash.ts","../../src/passkey/getCandidatePublicKeys.ts","../../src/passkey/findPublicKey.ts","../../src/passkey/createPasskey.ts","../../src/common.ts","../../src/createBundlerClient.ts","../../src/getBundlerTransport.ts","../../src/icons/Logo.tsx","../../src/usePreloadImage.tsx","../../src/AppInfo.tsx","../../src/onboarding/ConnectedSteps.tsx","../../src/onboarding/common.ts","../../src/onboarding/useAllowance.ts","../../src/paymaster.ts","../../src/onboarding/getAllowance.ts","../../src/onboarding/useSpender.ts","../../src/onboarding/getSpender.ts","../../src/onboarding/useDelegation.ts","../../src/onboarding/getDelegation.ts","../../src/onboarding/usePrerequisites.ts","../../src/useSessionAccount.ts","../../src/getSessionAccount.ts","../../src/store.ts","../../src/getSessionSigner.ts","../../src/onboarding/Wallet.tsx","../../src/useENS.ts","../../src/ui/TruncatedHex.tsx","../../src/onboarding/useClaimGasPass.ts","../../src/icons/EthIcon.tsx","../../src/formatBalance.ts","../../src/ui/Balance.tsx","../../src/onboarding/Allowance.tsx","../../src/onboarding/useSetupSession.ts","../../src/utils/callWithSignature.ts","../../src/utils/signCall.tsx","../../src/onboarding/Session.tsx","../../src/useSessionClient.ts","../../src/getSessionClient.ts","../../src/AccountModalErrorBoundary.tsx","../../src/ErrorNotice.tsx","../../src/icons/IconSVG.tsx","../../src/icons/CloseIcon.tsx","../../src/EntryKitProvider.tsx","../../src/AccountButton.tsx","../../src/AccountName.tsx","../../src/useSessionClientReady.ts","../../src/createWagmiConfig.ts","../../src/passkey/passkeyWallet.ts","../../src/getConnectors.ts","../../src/getWallets.ts"],"sourcesContent":["import { EntryKitConfigInput } from \"./input\";\nimport { EntryKitConfig } from \"./output\";\n\nexport function defineConfig(input: EntryKitConfigInput): EntryKitConfig {\n return {\n ...input,\n appName: input.appName ?? document.title,\n appIcon: input.appIcon ?? document.querySelector(\"link[rel~='icon']\")?.getAttribute(\"href\") ?? \"/favico.ico\",\n };\n}\n","import { ReactNode } from \"react\";\nimport { Root as DialogRoot, DialogPortal, DialogContent } from \"@radix-ui/react-dialog\";\nimport { Shadow } from \"./Shadow\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = {\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n children: ReactNode;\n};\n\nexport function Modal({ open, onOpenChange, children }: Props) {\n return (\n <DialogRoot open={open} onOpenChange={onOpenChange}>\n {/* This intentionally does not use `<DialogTrigger>` because it doesn't play nicely with `<Shadow>` trigger (our primary use case). */}\n <DialogPortal>\n <Shadow mode=\"modal\">\n {/**\n * This intentionally does not use `<DialogOverlay>` due to an issue it causes with scrolling the modal contents.\n * See https://github.com/radix-ui/primitives/issues/1159#issuecomment-1105320294\n */}\n <div className={twMerge(\"fixed inset-0\", \"bg-neutral-800/85\", \"animate-in animate-duration-300 fade-in\")} />\n <div\n className={twMerge(\n \"fixed inset-0\",\n \"grid items-end sm:items-center\",\n \"animate-in animate-duration-300 fade-in slide-in-from-bottom-16\",\n )}\n >\n <div>\n <DialogContent\n className=\"outline-none w-full max-w-[26rem] mx-auto\"\n // TODO description\n aria-describedby={undefined}\n onOpenAutoFocus={(event) => {\n event.preventDefault();\n }}\n >\n {children}\n </DialogContent>\n </div>\n </div>\n </Shadow>\n </DialogPortal>\n </DialogRoot>\n );\n}\n","import { CSSProperties, HTMLProps, ReactNode, forwardRef, useEffect, useRef, useState } from \"react\";\nimport ReactDOM from \"react-dom\";\nimport css from \"tailwindcss/tailwind.css?inline\";\nimport { useResizeObserver } from \"usehooks-ts\";\nimport { mergeRefs } from \"react-merge-refs\";\nimport { FrameProvider } from \"./FrameProvider\";\nimport { useTheme } from \"../useTheme\";\n\nexport type Props = {\n mode: \"modal\" | \"child\";\n children: ReactNode;\n};\n\nfunction Resizer({\n onSize,\n ...props\n}: {\n onSize: (size: { width: number | undefined; height: number | undefined }) => void;\n} & HTMLProps<HTMLDivElement>) {\n const ref = useRef<HTMLDivElement | null>(null);\n useResizeObserver({ ref, onResize: onSize });\n return <div ref={ref} {...props} style={{ ...props.style, display: \"inline-grid\" }} />;\n}\n\n// TODO: make a container inside the iframe that is at least the size of the window, render content into that so we can correctly measure size relative to window\n// otherwise as the iframe shrinks, the measurement will be based on that shrunk value and it'll never get bigger, only smaller\n\nexport const Shadow = forwardRef<HTMLIFrameElement, Props>(function Shadow({ mode, children }, forwardedRef) {\n const frameRef = useRef<HTMLIFrameElement | null>(null);\n const [loaded, setLoaded] = useState(false);\n const frame = loaded ? frameRef.current : null;\n\n const [frameSize, setFrameSize] = useState<{ width: number | undefined; height: number | undefined }>({\n width: undefined,\n height: undefined,\n });\n\n const frameDocument = frame?.contentDocument;\n const theme = useTheme();\n useEffect(() => {\n if (frameDocument) {\n frameDocument.body.setAttribute(\"data-theme\", theme);\n }\n }, [frameDocument, theme]);\n\n const frameStyle: CSSProperties =\n mode === \"modal\"\n ? {\n all: \"unset\",\n display: \"block\",\n position: \"fixed\",\n inset: \"0\",\n width: \"100%\",\n height: \"100%\",\n zIndex: \"2147483646\",\n }\n : frameSize.width && frameSize.height\n ? {\n all: \"unset\",\n display: \"inline-grid\",\n width: `${frameSize.width}px`,\n height: `${frameSize.height}px`,\n }\n : {\n all: \"unset\",\n display: \"block\",\n position: \"fixed\",\n inset: \"0\",\n width: \"100%\",\n height: \"100%\",\n opacity: 0,\n pointerEvents: \"none\",\n };\n\n return (\n <iframe\n ref={mergeRefs([forwardedRef, frameRef])}\n style={frameStyle}\n onLoad={() => setLoaded(true)}\n srcDoc=\"<!doctype html><title>…</title>\"\n >\n {frameDocument\n ? ReactDOM.createPortal(\n <FrameProvider frame={frame}>\n {/*\n * TODO: make this the size of the outer window so that any container-based resizing in iframe\n * is done from that rather than the potentially-small size of this iframe\n */}\n <div>{mode === \"modal\" ? children : <Resizer onSize={setFrameSize}>{children}</Resizer>}</div>\n <style dangerouslySetInnerHTML={{ __html: css }} />\n </FrameProvider>,\n frameDocument.body,\n )\n : null}\n </iframe>\n );\n});\n","import { createContext, useContext, type ReactNode } from \"react\";\n\ntype ContextValue = {\n readonly frame: HTMLIFrameElement;\n};\n\n/** @internal */\nconst Context = createContext<ContextValue | null>(null);\n\nexport type Props = {\n frame: HTMLIFrameElement;\n children?: ReactNode;\n};\n\nexport function FrameProvider({ frame, children }: Props) {\n const value = useContext(Context);\n if (value) throw new Error(\"`FrameProvider` can only be used once.\");\n return <Context.Provider value={{ frame }}>{children}</Context.Provider>;\n}\n\nexport function useFrame(): ContextValue {\n const value = useContext(Context);\n if (!value) throw new Error(\"`useFrame` can only be used within a `FrameProvider`.\");\n return value;\n}\n","import { useMediaQuery } from \"usehooks-ts\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\n\nexport function useTheme() {\n const { theme: initialTheme } = useEntryKitConfig();\n const darkMode = useMediaQuery(\"(prefers-color-scheme: dark)\");\n const theme = initialTheme ?? (darkMode ? \"dark\" : \"light\");\n return theme;\n}\n","import \"@rainbow-me/rainbowkit/styles.css\";\nimport { createContext, useContext, type ReactNode } from \"react\";\nimport { RainbowKitProvider, lightTheme, midnightTheme } from \"@rainbow-me/rainbowkit\";\nimport { EntryKitConfig } from \"./config/output\";\nimport { Address, Chain } from \"viem\";\nimport { useChains } from \"wagmi\";\nimport { getPaymasterAddress } from \"./getPaymasterAddress\";\n\ntype ContextValue = EntryKitConfig & {\n chain: Chain;\n paymasterAddress: Address;\n};\n\n/** @internal */\nconst Context = createContext<ContextValue | null>(null);\n\nexport type Props = {\n config: EntryKitConfig;\n children?: ReactNode;\n};\n\nexport function EntryKitConfigProvider({ config, children }: Props) {\n const currentConfig = useContext(Context);\n if (currentConfig) throw new Error(\"`EntryKitProvider` can only be used once.\");\n\n // TODO: move chain-based lookups to function so we can reuse here and in passkeyConnector\n\n const chains = useChains();\n const chain = chains.find(({ id }) => id === config.chainId);\n if (!chain) throw new Error(`Could not find configured chain for chain ID ${config.chainId}.`);\n\n const paymasterAddress = getPaymasterAddress(chain);\n\n return (\n <RainbowKitProvider\n // Prevent RainbowKit/Wagmi trying to switch chains after connection\n // https://github.com/rainbow-me/rainbowkit/blob/d76bb28a67609d9855b8045e5f5f4641dff1e032/packages/rainbowkit/src/wallets/useWalletConnectors.ts#L58-L67\n // https://github.com/wevm/wagmi/blob/cb58b1ea3ad40e77210f24eb598f9d2306db998c/packages/core/src/connectors/injected.ts#L176-L184\n initialChain={0}\n appInfo={{\n appName: config.appName,\n // TODO: learn more and disclaimer\n }}\n theme={\n config.theme === \"light\"\n ? lightTheme({ borderRadius: \"none\" })\n : config.theme === \"dark\"\n ? midnightTheme({ borderRadius: \"none\" })\n : {\n lightMode: lightTheme({ borderRadius: \"none\" }),\n darkMode: midnightTheme({ borderRadius: \"none\" }),\n }\n }\n >\n <Context.Provider value={{ ...config, chain, paymasterAddress }}>{children}</Context.Provider>\n </RainbowKitProvider>\n );\n}\n\nexport function useEntryKitConfig(): ContextValue {\n const config = useContext(Context);\n if (!config) throw new Error(\"`useEntryKitConfig` can only be used within a `EntryKitProvider`.\");\n return config;\n}\n","import { Chain, getChainContractAddress } from \"viem\";\n\nexport function getPaymasterAddress(chain: Chain) {\n return getChainContractAddress({ chain, contract: \"quarryPaymaster\" });\n}\n","import { useCallback, useMemo } from \"react\";\nimport { useStore } from \"zustand\";\nimport { createStore } from \"zustand/vanilla\";\n\nconst store = createStore(() => ({ open: false }));\n\nexport type UseAccountModalResult = {\n readonly accountModalOpen: boolean;\n readonly openAccountModal: () => void;\n readonly closeAccountModal: () => void;\n readonly toggleAccountModal: (open: boolean) => void;\n};\n\nexport function useAccountModal(): UseAccountModalResult {\n const accountModalOpen = useStore(store, (state) => state.open);\n\n const openAccountModal = useCallback(() => {\n store.setState({ open: true });\n }, []);\n\n const closeAccountModal = useCallback(() => {\n store.setState({ open: false });\n }, []);\n\n const toggleAccountModal = useCallback((open: boolean) => {\n store.setState({ open: open });\n }, []);\n\n return useMemo(\n () => ({\n accountModalOpen,\n openAccountModal,\n closeAccountModal,\n toggleAccountModal,\n }),\n [accountModalOpen, openAccountModal, closeAccountModal, toggleAccountModal],\n );\n}\n","import { Modal } from \"./ui/Modal\";\nimport { useAccountModal } from \"./useAccountModal\";\nimport { twMerge } from \"tailwind-merge\";\nimport { AccountModalContent } from \"./AccountModalContent\";\nimport { AccountModalErrorBoundary } from \"./AccountModalErrorBoundary\";\nimport { DialogClose, DialogTitle } from \"@radix-ui/react-dialog\";\nimport { CloseIcon } from \"./icons/CloseIcon\";\nimport { Logo } from \"./icons/Logo\";\n\nexport function AccountModal() {\n const { accountModalOpen, toggleAccountModal } = useAccountModal();\n return (\n <Modal open={accountModalOpen} onOpenChange={toggleAccountModal}>\n {/* TODO: move this into `<Modal>` props? */}\n <DialogTitle className=\"sr-only\">Connect with EntryKit</DialogTitle>\n {accountModalOpen ? (\n <div\n className={twMerge(\n \"relative py-2 ring-1\",\n \"bg-neutral-900 text-neutral-400 ring-neutral-700/50 divide-neutral-700\",\n \"links:font-medium links:underline links:underline-offset-4\",\n \"links:text-white\",\n \"links:decoration-neutral-500 hover:links:decoration-orange-500\",\n )}\n >\n <AccountModalErrorBoundary>\n <AccountModalContent />\n </AccountModalErrorBoundary>\n\n <a\n href=\"https://mud.dev\"\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n className=\"group self-center p-3 flex items-center justify-center gap-2 links-unset text-sm font-mono transition text-neutral-400 hover:text-white\"\n >\n <span className=\"block w-4 h-4\">\n <Logo className=\"w-full h-full text-orange-500 group-hover:rotate-90 transition duration-300\" />\n </span>\n <span>Powered by MUD</span>\n </a>\n\n <div className=\"absolute top-0 right-0\">\n <DialogClose\n className={twMerge(\n \"pointer-events-auto leading-none p-2 transition\",\n \"text-neutral-700 hover:text-neutral-500\",\n )}\n title=\"Close\"\n >\n <CloseIcon className=\"m-0\" />\n </DialogClose>\n </div>\n </div>\n ) : null}\n </Modal>\n );\n}\n","import { useAccount, useConnectorClient } from \"wagmi\";\nimport { ConnectWallet } from \"./ConnectWallet\";\nimport { ConnectedSteps } from \"./onboarding/ConnectedSteps\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useRef } from \"react\";\n\nexport function AccountModalContent() {\n const { chainId } = useEntryKitConfig();\n const userClient = useConnectorClient({ chainId });\n const { address: userAddress } = useAccount();\n const initialUserAddress = useRef(userAddress);\n\n if (userClient.status !== \"success\") {\n return <ConnectWallet />;\n }\n\n return <ConnectedSteps userClient={userClient.data} initialUserAddress={initialUserAddress.current} />;\n}\n","import { useAccount } from \"wagmi\";\nimport { Button } from \"./ui/Button\";\nimport { useAccountModal } from \"./useAccountModal\";\nimport { useConnectModal } from \"@rainbow-me/rainbowkit\";\nimport { useMutation } from \"@tanstack/react-query\";\nimport { usePasskeyConnector } from \"./usePasskeyConnector\";\nimport { AppInfo } from \"./AppInfo\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function ConnectWallet() {\n const userAccount = useAccount();\n const { accountModalOpen } = useAccountModal();\n const { openConnectModal, connectModalOpen } = useConnectModal();\n\n // TODO: show error states\n // TODO: fix passkey issue where pending state disappears but we don't transition right away\n\n const passkeyConnector = usePasskeyConnector();\n const createPasskey = useMutation({\n onError: (error) => console.error(error),\n mutationKey: [\"createPasskey\", passkeyConnector.id, accountModalOpen, connectModalOpen, userAccount.status],\n mutationFn: () => passkeyConnector.createPasskey(),\n });\n const reusePasskey = useMutation({\n onError: (error) => console.error(error),\n mutationKey: [\"reusePasskey\", passkeyConnector.id, accountModalOpen, connectModalOpen, userAccount.status],\n mutationFn: () => passkeyConnector.reusePasskey(),\n });\n\n const hasPasskey = passkeyConnector.hasPasskey();\n\n const buttons = [\n <Button\n key=\"create\"\n variant={hasPasskey ? \"tertiary\" : \"secondary\"}\n className=\"self-auto flex justify-center\"\n pending={createPasskey.status === \"pending\" || createPasskey.status === \"success\"}\n onClick={() => createPasskey.mutate()}\n autoFocus={!hasPasskey}\n >\n Create account\n </Button>,\n <Button\n key=\"signin\"\n variant={hasPasskey ? \"secondary\" : \"tertiary\"}\n className=\"self-auto flex justify-center\"\n pending={reusePasskey.status === \"pending\" || reusePasskey.status === \"success\"}\n onClick={() => reusePasskey.mutate()}\n autoFocus={hasPasskey}\n >\n Sign in\n </Button>,\n ];\n\n if (hasPasskey) {\n buttons.reverse();\n }\n\n return (\n <div\n className={twMerge(\"flex flex-col gap-6 p-6\", \"animate-in animate-duration-300 fade-in slide-in-from-bottom-8\")}\n >\n <div className=\"p-4\">\n {/* TODO: render appImage if available? */}\n <AppInfo />\n </div>\n <div className=\"self-center flex flex-col gap-2 w-60\">\n {buttons}\n <button\n className=\"text-sm self-center transition text-neutral-500 hover:text-white p-2\"\n disabled={userAccount.status === \"connecting\"}\n // TODO: figure out how to prevent this from switching chains after connecting\n onClick={openConnectModal}\n >\n Already have a wallet?\n </button>\n </div>\n </div>\n );\n}\n","/* eslint-disable max-len */\nimport { ButtonHTMLAttributes, DetailedHTMLProps } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { PendingIcon } from \"../icons/PendingIcon\";\n\n// TODO: add support for async onClick, where pending is enabled automatically\n// TODO: add error state with popover/tooltip\n\ntype ButtonClassNameOptions = {\n variant?: \"primary\" | \"secondary\" | \"tertiary\";\n pending?: boolean;\n};\n\nconst buttonClassName = ({ variant = \"secondary\" }: ButtonClassNameOptions = {}) =>\n twMerge(\n \"group/button self-center leading-none outline-none border-4 border-transparent\",\n \"transition hover:brightness-125 active:brightness-150\",\n \"focus:border-orange-500\",\n \"aria-disabled:pointer-events-none aria-busy:pointer-events-none\",\n // TODO: better disabled state\n \"aria-disabled:opacity-50\",\n \"p-[.75em] font-medium\",\n {\n primary: twMerge(\"bg-orange-600 text-white focus:border-yellow-400\"),\n secondary: twMerge(\"bg-neutral-700 text-white focus:border-orange-500\"),\n tertiary: twMerge(\"bg-neutral-800 text-white focus:border-orange-500\"),\n }[variant],\n );\n\nexport type ButtonProps = {\n pending?: boolean;\n variant?: ButtonClassNameOptions[\"variant\"];\n};\n\nexport type Props = ButtonProps & DetailedHTMLProps<ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>;\n\nexport const Button = ({ pending, variant, type, className, children, disabled, ...props }: Props) => {\n return (\n <button\n type={type || \"button\"}\n className={twMerge(buttonClassName({ variant, pending }), className)}\n aria-busy={pending}\n aria-disabled={disabled}\n disabled={disabled || pending}\n {...props}\n >\n <span className=\"grid grid-cols-[1fr_auto_1fr] gap-2\">\n <span className=\"flex items-center justify-end text-[.75em]\">\n <span className=\"transition opacity-0 translate-x-2 group-aria-busy/button:opacity-100 group-aria-busy/button:translate-x-0 duration-100 group-aria-busy/button:duration-300\">\n <PendingIcon />\n </span>\n </span>\n <span>{children}</span>\n </span>\n </button>\n );\n};\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function PendingIcon({ className, ...props }: Props) {\n return (\n <svg\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em] animate-spin\", className)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n {...props}\n >\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\" />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"\n />\n </svg>\n );\n}\n","import { useConnectors } from \"wagmi\";\nimport { PasskeyConnector, passkeyConnector } from \"./passkey/passkeyConnector\";\n\nexport function usePasskeyConnector(): PasskeyConnector {\n const connectors = useConnectors();\n const connector = connectors.find((c) => c.type === passkeyConnector.type);\n if (!connector) {\n // TODO: provide link to instructions\n throw new Error(\n \"Could not find passkey connector. Did you configure Wagmi with the EntryKit passkey connector or passkey wallet?\",\n );\n }\n return connector as never;\n}\n","import {\n createClient,\n custom,\n EIP1193RequestFn,\n EIP1474Methods,\n getAddress,\n numberToHex,\n SwitchChainError,\n Client,\n ProviderConnectInfo,\n} from \"viem\";\nimport { ChainNotConfiguredError, createConnector, CreateConnectorFn } from \"wagmi\";\nimport { cache } from \"./cache\";\nimport { smartAccountActions } from \"permissionless/clients\";\nimport { getAccount } from \"./getAccount\";\nimport { reusePasskey } from \"./reusePasskey\";\nimport { createPasskey } from \"./createPasskey\";\nimport { defaultClientConfig } from \"../common\";\nimport { createBundlerClient } from \"../createBundlerClient\";\nimport { observer } from \"@latticexyz/explorer/observer\";\nimport { getPaymasterAddress } from \"../getPaymasterAddress\";\nimport { getBundlerTransport } from \"../getBundlerTransport\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\n\nexport type PasskeyConnectorOptions = {\n // TODO: figure out what we wanna do across chains\n chainId: number;\n};\n\nexport type PasskeyProvider = {\n request: EIP1193RequestFn<EIP1474Methods>;\n};\n\nexport type PasskeyConnectorProperties = {\n createPasskey(): Promise<void>;\n reusePasskey(): Promise<void>;\n // TODO: does wagmi storage require this to be async?\n hasPasskey(): boolean;\n getClient(parameters?: { chainId?: number | undefined } | undefined): Promise<Client>;\n onConnect(connectInfo: ProviderConnectInfo): void;\n};\n\nexport type CreatePasskeyConnector = CreateConnectorFn<PasskeyProvider, PasskeyConnectorProperties, {}>;\nexport type PasskeyConnector = ReturnType<CreatePasskeyConnector>;\n\npasskeyConnector.type = \"passkey\" as const;\n\nexport function passkeyConnector({ chainId }: PasskeyConnectorOptions): CreatePasskeyConnector {\n return createConnector((config) => {\n // TODO: figure out how to use with config's `client` option?\n if (!config.transports) {\n throw new Error(`Wagmi must be configured with transports to use the passkey connector.`);\n }\n\n const chain = config.chains.find((c) => c.id === chainId);\n if (!chain) throw new Error(`Could not find configured chain for chain ID ${chainId}.`);\n\n // TODO: wrap transports in wiresaw\n // TODO: adapt wiresaw transport to check chain config and conditionally make its own transport from wiresaw chain config and swap out methods\n\n const configTransport = config.transports[chain.id];\n if (!configTransport) {\n throw new Error(`Could not find configured transport for chain ID ${chainId}.`);\n }\n const transport = wiresaw(configTransport);\n\n const paymasterAddress = getPaymasterAddress(chain);\n const bundlerTransport = getBundlerTransport(chain);\n\n const client = createClient({ ...defaultClientConfig, chain, transport });\n\n let connected = cache.getState().activeCredential != null;\n\n return {\n id: \"passkey\",\n type: passkeyConnector.type,\n name: \"Passkey\",\n // TODO: check that this works\n // supportsSimulation: true,\n\n async createPasskey() {\n const { credentialId } = await createPasskey(chain);\n const account = await getAccount(client, credentialId);\n this.onAccountsChanged([account.address]);\n this.onConnect?.({ chainId: numberToHex(chainId) });\n },\n async reusePasskey() {\n const { credentialId } = await reusePasskey(chain);\n const account = await getAccount(client, credentialId);\n this.onAccountsChanged([account.address]);\n this.onConnect?.({ chainId: numberToHex(chainId) });\n },\n hasPasskey() {\n return Object.keys(cache.getState().publicKeys).length > 0;\n },\n\n async connect(params) {\n console.log(\"connect\");\n // TODO: allow any chain?\n if (params?.chainId != null && params.chainId !== chainId) {\n throw new Error(`Can't connect to chain ${params.chainId}. Passkey connector is bound to chain ${chainId}.`);\n }\n\n // attempt to reuse credential if this is called directly\n // TODO: move this into wallet so it's only triggered via rainbowkit?\n if (!cache.getState().activeCredential && !params?.isReconnecting) {\n await reusePasskey(chain);\n }\n\n const accounts = await this.getAccounts();\n connected = accounts.length > 0;\n\n return { accounts, chainId };\n },\n async disconnect() {\n console.log(\"disconnect\");\n connected = false;\n cache.setState({ activeCredential: null });\n },\n async getAccounts() {\n console.log(\"getAccounts\");\n const id = cache.getState().activeCredential;\n if (!id) return [];\n\n try {\n console.log(\"getting account for credential\", id);\n const account = await getAccount(client, id);\n console.log(\"got account\", account);\n return [account.address];\n } catch (error) {\n console.log(\"could not get address for credential ID\", id);\n }\n\n return [];\n },\n async getChainId() {\n return chainId;\n },\n async isAuthorized() {\n console.log(\"isAuthorized\");\n if (!connected) return false;\n const accounts = await this.getAccounts();\n return accounts.length > 0;\n },\n async switchChain(params) {\n // TODO: allow any chain?\n if (params.chainId !== chainId) {\n throw new Error(`Can't connect to chain ${params.chainId}. Passkey connector is bound to chain ${chainId}.`);\n }\n\n const chain = config.chains.find((c) => c.id === params.chainId);\n if (!chain) throw new SwitchChainError(new ChainNotConfiguredError());\n return chain;\n },\n onAccountsChanged(accounts) {\n console.log(\"onAccountsChanged\");\n if (accounts.length > 0) {\n config.emitter.emit(\"change\", {\n accounts: accounts.map((a) => getAddress(a)),\n });\n } else {\n this.onDisconnect();\n }\n },\n onChainChanged(chainId) {\n console.log(\"onChainChanged\");\n config.emitter.emit(\"change\", { chainId: Number(chainId) });\n },\n async onConnect(_connectInfo) {\n console.log(\"onConnect\");\n const accounts = await this.getAccounts();\n config.emitter.emit(\"connect\", { accounts, chainId });\n },\n async onDisconnect(_error) {\n console.log(\"onDisconnect\");\n config.emitter.emit(\"disconnect\");\n connected = false;\n },\n\n // By default, connector clients are bound to a `json-rpc` account.\n // We provide our own `getClient` method here so that we can return\n // a `smart` account, which is necessary for using with Viem's\n // account abstraction actions (i.e. user ops).\n //\n // Although Wagmi recommends connectors be tree-shakable, we return\n // an extended client here so that this client works with native\n // Wagmi hooks. Otherwise the app needs to build its own client, then\n // wrap each call in its own react-query hooks.\n async getClient(params) {\n console.log(\"passkeyConnector.getClient\", params);\n\n const credentialId = cache.getState().activeCredential;\n if (!credentialId) throw new Error(\"Not connected.\");\n\n const account = await getAccount(client, credentialId);\n\n return createBundlerClient({\n paymasterAddress,\n transport: bundlerTransport,\n client,\n account,\n })\n .extend(smartAccountActions())\n .extend(observer());\n },\n\n async getProvider(_params) {\n // TODO: chain specific provider?\n // TODO: is turning off retryCount important? is wrapping in this way enough to turn off retries?\n return custom({ request: client.transport.request })({ retryCount: 0 });\n },\n };\n });\n}\n","import { createStore } from \"zustand/vanilla\";\nimport { persist } from \"zustand/middleware\";\nimport { P256Credential } from \"viem/account-abstraction\";\n\n// TODO: move this to wagmi storage?\n// when I tried, it blew up TS complexity and my IDE was impossible to work with\n\nexport type State = {\n readonly publicKeys: {\n readonly [key in P256Credential[\"id\"]]?: P256Credential[\"publicKey\"];\n };\n readonly activeCredential: P256Credential[\"id\"] | null;\n};\n\nexport const cache = createStore(\n persist<State>(\n () => ({\n publicKeys: {},\n activeCredential: null,\n }),\n { name: \"mud:id:cache\" },\n ),\n);\n\n// keep cache in sync across tabs/windows via storage event\nfunction listener(event: StorageEvent) {\n if (event.key === cache.persist.getOptions().name) {\n cache.persist.rehydrate();\n }\n}\nwindow.addEventListener(\"storage\", listener);\n","import { Chain, Client, Transport } from \"viem\";\nimport { cache } from \"./cache\";\nimport { P256Credential } from \"webauthn-p256\";\nimport { toCoinbaseSmartAccount, ToCoinbaseSmartAccountReturnType } from \"@latticexyz/common/accounts\";\nimport { toWebAuthnAccount } from \"./toWebAuthnAccount\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function getAccount(\n client: Client<Transport, Chain>,\n id: P256Credential[\"id\"],\n): Promise<ToCoinbaseSmartAccountReturnType> {\n const { publicKeys } = cache.getState();\n\n const publicKey = publicKeys[id];\n // TODO: should we prompt to recover key here?\n if (!publicKey) {\n throw new Error(\"No public key found for passkey credential.\");\n }\n\n const passkey = toWebAuthnAccount({ credential: { id, publicKey }, bridgeUrl: (client.chain as MUDChain).mudIdUrl });\n const owners = [passkey];\n\n return await toCoinbaseSmartAccount({ client, owners });\n}\n","import { ErrorType } from \"@ark/util\";\nimport { hashMessage, hashTypedData } from \"viem\";\nimport { WebAuthnAccount } from \"viem/account-abstraction\";\nimport { type P256Credential } from \"webauthn-p256\";\nimport { createBridge } from \"@latticexyz/id/internal\";\n\nexport type ToWebAuthnAccountParameters = {\n /**\n * The WebAuthn P256 credential to use.\n */\n credential: {\n id: P256Credential[\"id\"];\n publicKey: P256Credential[\"publicKey\"];\n };\n bridgeUrl?: string;\n};\n\nexport type ToWebAuthnAccountReturnType = WebAuthnAccount;\n\nexport type ToWebAuthnAccountErrorType = ErrorType;\n\n/**\n * @description Creates an Account from a WebAuthn Credential.\n *\n * @returns A WebAuthn Account.\n */\nexport function toWebAuthnAccount(parameters: ToWebAuthnAccountParameters): WebAuthnAccount {\n const { id, publicKey } = parameters.credential;\n return {\n publicKey,\n async sign({ hash }) {\n const bridge = await createBridge({ message: \"Requesting signature…\", url: parameters.bridgeUrl });\n try {\n const { signature, metadata: webauthn } = await bridge.request(\"sign\", { credentialId: id, challenge: hash });\n return {\n signature,\n webauthn,\n raw: { id } as never,\n };\n } finally {\n bridge.close();\n }\n },\n async signMessage({ message }) {\n return this.sign({ hash: hashMessage(message) });\n },\n async signTypedData(parameters) {\n return this.sign({ hash: hashTypedData(parameters) });\n },\n type: \"webAuthn\",\n };\n}\n","import { bytesToHex, hashMessage } from \"viem\";\nimport { cache } from \"./cache\";\nimport { getMessageHash } from \"./getMessageHash\";\nimport { findPublicKey } from \"./findPublicKey\";\nimport { PasskeyCredential, createBridge } from \"@latticexyz/id/internal\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function reusePasskey(chain: MUDChain): Promise<PasskeyCredential> {\n const bridge = await createBridge({ url: chain.mudIdUrl, message: \"Signing in…\" });\n try {\n const challenge = hashMessage(bytesToHex(crypto.getRandomValues(new Uint8Array(256))));\n const { credentialId, signature, metadata } = await bridge.request(\"sign\", { challenge });\n\n const publicKey = await (async () => {\n const cachedPublicKey = cache.getState().publicKeys[credentialId];\n if (cachedPublicKey) return cachedPublicKey;\n\n // TODO: look up account/public key by credential ID once we store it onchain\n\n const messageHash = await getMessageHash(metadata);\n const challenge2 = hashMessage(signature);\n const signature2 = await bridge.request(\"sign\", { credentialId, challenge: challenge2 });\n if (signature2.credentialId !== credentialId) {\n throw new Error(\"wrong credential\");\n }\n\n const publicKey = findPublicKey([\n { messageHash, signatureHex: signature },\n { messageHash: await getMessageHash(signature2.metadata), signatureHex: signature2.signature },\n ]);\n if (!publicKey) {\n throw new Error(\"recovery failed\");\n }\n\n cache.setState((state) => ({\n publicKeys: {\n ...state.publicKeys,\n [credentialId]: publicKey,\n },\n }));\n\n return publicKey;\n })();\n\n console.log(\"recovered passkey\", credentialId, publicKey);\n\n cache.setState(() => ({\n activeCredential: credentialId,\n }));\n\n return { credentialId, publicKey };\n } finally {\n bridge.close();\n }\n}\n","import { bytesToHex, Hex, hexToBytes, WebAuthnData } from \"webauthn-p256\";\nimport { concatBytes, utf8ToBytes } from \"@noble/curves/abstract/utils\";\n\n// lifted out of https://github.com/wevm/webauthn-p256/blob/main/src/verify.ts\n// TODO: submit a PR to lift this out as a function that can be exported\n\nexport async function getMessageHash(\n webauthn: Omit<WebAuthnData, \"typeIndex\" | \"challengeIndex\"> & {\n challengeIndex?: number;\n typeIndex?: number;\n },\n): Promise<Hex | never> {\n const {\n authenticatorData,\n challengeIndex: challengeIndexRaw,\n clientDataJSON,\n typeIndex: typeIndexRaw,\n userVerificationRequired,\n } = webauthn;\n\n const typeIndex = typeIndexRaw || clientDataJSON.indexOf('\"type\"');\n const challengeIndex = challengeIndexRaw || clientDataJSON.indexOf('\"challenge\"');\n\n const authenticatorDataBytes = hexToBytes(authenticatorData);\n\n // Check length of `authenticatorData`.\n if (authenticatorDataBytes.length < 37) throw new Error(\"Invalid authenticatorData\");\n\n const flag = authenticatorDataBytes[32]!;\n\n // Verify that the UP bit of the flags in authData is set.\n if ((flag & 0x01) !== 0x01) throw new Error(\"Invalid authenticatorData\");\n\n // If user verification was determined to be required, verify that\n // the UV bit of the flags in authData is set. Otherwise, ignore the\n // value of the UV flag.\n if (userVerificationRequired && (flag & 0x04) !== 0x04) throw new Error(\"Invalid authenticatorData\");\n\n // If the BE bit of the flags in authData is not set, verify that\n // the BS bit is not set.\n if ((flag & 0x08) !== 0x08 && (flag & 0x10) === 0x10) throw new Error(\"Invalid authenticatorData\");\n\n // Check that response is for an authentication assertion\n const type = '\"type\":\"webauthn.get\"';\n if (type !== clientDataJSON.slice(Number(typeIndex), type.length + 1)) throw new Error(\"Invalid clientDataJSON\");\n\n // Check that hash is in the clientDataJSON.\n const match = clientDataJSON.slice(Number(challengeIndex)).match(/^\"challenge\":\"(.*?)\"/);\n if (!match) throw new Error(\"Invalid clientDataJSON\");\n\n // TODO: switch to ox, then maybe don't need async/await here\n const clientDataJSONHash = new Uint8Array(await crypto.subtle.digest(\"SHA-256\", utf8ToBytes(clientDataJSON)));\n const messageHash = new Uint8Array(\n await crypto.subtle.digest(\"SHA-256\", concatBytes(hexToBytes(authenticatorData), clientDataJSONHash)),\n );\n\n return bytesToHex(messageHash);\n}\n","import { parseSignature, serializePublicKey } from \"webauthn-p256\";\nimport { SignatureAndMessage } from \"./common\";\nimport { secp256r1 } from \"@noble/curves/p256\";\n\nexport function getCandidatePublicKeys(input: SignatureAndMessage) {\n const { r, s } = parseSignature(input.signatureHex);\n\n const candidate1 = new secp256r1.Signature(r, s).addRecoveryBit(1).recoverPublicKey(input.messageHash.slice(2));\n const candidate2 = new secp256r1.Signature(r, s).addRecoveryBit(0).recoverPublicKey(input.messageHash.slice(2));\n\n return [serializePublicKey(candidate1), serializePublicKey(candidate2)];\n}\n","import { getCandidatePublicKeys } from \"./getCandidatePublicKeys\";\nimport { SignatureAndMessage } from \"./common\";\nimport { Hex } from \"viem\";\n\nexport function findPublicKey([input1, input2]: [SignatureAndMessage, SignatureAndMessage]): Hex | undefined {\n // Return the candidate public key that appears twice\n return firstDuplicate([...getCandidatePublicKeys(input1), ...getCandidatePublicKeys(input2)]);\n}\n\nfunction firstDuplicate<T>(arr: T[]): T | undefined {\n const seen = new Set<T>();\n for (const s of arr) {\n if (seen.has(s)) {\n return s;\n }\n seen.add(s);\n }\n return undefined;\n}\n","import { cache } from \"./cache\";\nimport { createBridge, PasskeyCredential } from \"@latticexyz/id/internal\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function createPasskey(chain: MUDChain): Promise<PasskeyCredential> {\n const bridge = await createBridge({ url: chain.mudIdUrl, message: \"Creating account…\" });\n try {\n const credential = await bridge.request(\"create\");\n console.log(\"created passkey\", credential);\n\n cache.setState((state) => ({\n activeCredential: credential.credentialId,\n publicKeys: {\n ...state.publicKeys,\n [credential.credentialId]: credential.publicKey,\n },\n }));\n\n return credential;\n } finally {\n bridge.close();\n }\n}\n","import { resourceToHex } from \"@latticexyz/common\";\nimport { Client, Chain, Transport, Account, parseAbi, ClientConfig, Address } from \"viem\";\nimport worldConfig from \"@latticexyz/world/mud.config\";\n\nexport type ConnectedClient<chain extends Chain = Chain> = Client<Transport, chain, Account>;\nexport type SessionClient<chain extends Chain = Chain> = ConnectedClient<chain> & { readonly userAddress: Address };\n\nexport const defaultClientConfig = {\n pollingInterval: 250,\n} as const satisfies Pick<ClientConfig, \"pollingInterval\">;\n\nexport const unlimitedDelegationControlId = resourceToHex({ type: \"system\", namespace: \"\", name: \"unlimited\" });\n\nexport const worldTables = worldConfig.namespaces.world.tables;\n\nexport const worldAbi = parseAbi([\n \"function registerDelegation(address delegatee, bytes32 delegationControlId, bytes initCallData)\",\n]);\n","import { Transport, Chain, Client, RpcSchema, Address } from \"viem\";\nimport {\n BundlerClient,\n BundlerClientConfig,\n SmartAccount,\n createBundlerClient as viem_createBundlerClient,\n} from \"viem/account-abstraction\";\nimport { defaultClientConfig } from \"./common\";\n\nconst knownChainFees = new Set([\n // anvil hardcodes fee returned by `eth_maxPriorityFeePerGas`\n // so we have to override it here\n // https://github.com/foundry-rs/foundry/pull/8081#issuecomment-2402002485\n 31337,\n // rhodolite\n 17420,\n // garnet\n 17069,\n // redstone\n 690,\n]);\n\nexport function createBundlerClient<\n transport extends Transport,\n chain extends Chain | undefined = undefined,\n account extends SmartAccount | undefined = undefined,\n client extends Client | undefined = undefined,\n rpcSchema extends RpcSchema | undefined = undefined,\n>({\n paymasterAddress,\n ...config\n}: BundlerClientConfig<transport, chain, account, client, rpcSchema> & { paymasterAddress: Address }): BundlerClient<\n transport,\n chain,\n account,\n client,\n rpcSchema\n> {\n const chain = config.chain ?? config.client?.chain;\n return viem_createBundlerClient({\n ...defaultClientConfig,\n paymaster: {\n getPaymasterData: async () => ({\n paymaster: paymasterAddress,\n paymasterData: \"0x\",\n }),\n },\n // TODO: figure out why viem isn't falling back to `chain.fees.estimateFeesPerGas` when this isn't set\n userOperation: {\n estimateFeesPerGas:\n // TODO: move this to gas estimator transport?\n chain && knownChainFees.has(chain.id)\n ? async () => ({\n maxFeePerGas: 100_000n,\n maxPriorityFeePerGas: 0n,\n })\n : undefined,\n },\n ...config,\n });\n}\n","import { transactionQueue } from \"@latticexyz/common/actions\";\nimport { Chain, createClient, fallback, http, webSocket } from \"viem\";\nimport { privateKeyToAccount, generatePrivateKey } from \"viem/accounts\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\nimport { userOpExecutor } from \"@latticexyz/paymaster/internal\";\n\nexport function getBundlerTransport(chain: Chain) {\n const bundlerHttpUrl = chain.rpcUrls.bundler?.http[0];\n // TODO: bundler websocket\n const bundlerTransport = bundlerHttpUrl\n ? wiresaw(http(bundlerHttpUrl))\n : chain.id === 31337\n ? userOpExecutor({\n executor: createClient({\n chain,\n transport: fallback([webSocket(), http()]),\n account: privateKeyToAccount(generatePrivateKey()),\n }).extend(transactionQueue()),\n })\n : null;\n if (!bundlerTransport) {\n throw new Error(`Chain ${chain.id} config did not include a bundler RPC URL.`);\n }\n return bundlerTransport;\n}\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function Logo({ className, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 8 8\"\n fill=\"currentColor\"\n shapeRendering=\"crispEdges\"\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em]\", className)}\n {...props}\n >\n {/* eslint-disable-next-line max-len */}\n <path d=\"M0 0h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm2-1h1v1H7zm0 1h1v1H7zM6 7h1v1H6zm1-2h1v1H7zm0-1h1v1H7zm0-1h1v1H7z\" />\n <path\n d=\"M2 2h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm1-3h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm0 1h1v1H5zm0 1h1v1H5zm0 1h1v1H5zM4 5h1v1H4zM3 5h1v1H3z\"\n opacity=\".5\"\n />\n <path d=\"M7 2h1v1H7zm0-1h1v1H7zM1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm1 0h1v1H6zm1 0h1v1H7z\" />\n </svg>\n );\n}\n","import { useQuery } from \"@tanstack/react-query\";\n\nexport function usePreloadImage(url: string | undefined) {\n return useQuery({\n enabled: !!url,\n retry: false,\n retryOnMount: false,\n refetchOnMount: false,\n refetchOnWindowFocus: false,\n queryKey: [\"preloadImage\", url],\n queryFn: () =>\n new Promise<InstanceType<typeof Image>>((resolve, reject) => {\n if (!url) throw new Error(\"usePreloadImage: Must provide `url` to preload image.\");\n const image = new Image();\n image.onload = () => resolve(image);\n image.onerror = () => reject(new Error(`usePreloadImage: Could not load image.\\n\\n\\tURL: ${url}`));\n image.src = url;\n }),\n });\n}\n","import { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { Logo } from \"./icons/Logo\";\nimport { usePreloadImage } from \"./usePreloadImage\";\n\nexport function AppInfo() {\n const { appName, appIcon } = useEntryKitConfig();\n const { data: hasAppIcon, isLoading: appIconLoading } = usePreloadImage(appIcon);\n\n return (\n <div className=\"flex-grow flex flex-col items-center justify-center gap-2\">\n <div className=\"w-16 h-16 m-2\">\n {!appIconLoading ? (\n hasAppIcon ? (\n <img src={appIcon} className=\"w-full h-full object-cover\" />\n ) : (\n // TODO: swap with favicon\n <Logo className=\"w-full h-full text-orange-500 dark:bg-neutral-800\" />\n )\n ) : null}\n </div>\n <div className=\"text-2xl text-white text-center\">{appName}</div>\n </div>\n );\n}\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { ConnectedClient } from \"../common\";\nimport { twMerge } from \"tailwind-merge\";\nimport { usePrerequisites } from \"./usePrerequisites\";\nimport { Wallet } from \"./Wallet\";\nimport { Allowance } from \"./Allowance\";\nimport { Session } from \"./Session\";\nimport { Step } from \"./common\";\nimport { Address } from \"viem\";\nimport { useAccountModal } from \"../useAccountModal\";\n\nexport type Props = {\n userClient: ConnectedClient;\n initialUserAddress: Address | undefined;\n};\n\nexport function ConnectedSteps({ userClient, initialUserAddress }: Props) {\n const userAddress = userClient.account.address;\n const { data: prerequisites } = usePrerequisites(userAddress);\n\n const { closeAccountModal } = useAccountModal();\n const isNewConnection = userAddress !== initialUserAddress;\n\n const initialPrerequisites = useRef(prerequisites);\n useEffect(() => {\n if (prerequisites == null) return;\n if (initialPrerequisites.current == null) {\n initialPrerequisites.current = prerequisites;\n }\n\n if (prerequisites.complete) {\n if (isNewConnection || !initialPrerequisites.current.complete) {\n closeAccountModal();\n }\n }\n }, [closeAccountModal, isNewConnection, prerequisites]);\n\n const { hasAllowance, isSpender, hasDelegation } = prerequisites ?? {};\n\n const steps = useMemo((): readonly Step[] => {\n if (!userAddress) {\n return [\n {\n id: \"wallet\",\n isComplete: false,\n content: () => null,\n },\n ];\n }\n\n return [\n {\n id: \"wallet\",\n isComplete: true,\n content: (props) => <Wallet {...props} userAddress={userAddress} />,\n },\n {\n id: \"allowance\",\n isComplete: !!hasAllowance,\n content: (props) => <Allowance {...props} userAddress={userAddress} />,\n },\n {\n id: \"session\",\n isComplete: !!isSpender && !!hasDelegation,\n content: (props) => (\n <Session\n {...props}\n userClient={userClient}\n registerSpender={!isSpender}\n registerDelegation={!hasDelegation}\n />\n ),\n },\n ];\n }, [hasAllowance, hasDelegation, isSpender, userAddress, userClient]);\n\n const [selectedStepId] = useState<null | string>(null);\n const nextStep = steps.find((step) => step.content != null && !step.isComplete);\n const completedSteps = steps.filter((step) => step.isComplete);\n const activeStep =\n (selectedStepId != null ? steps.find((step) => step.id === selectedStepId) : null) ??\n nextStep ??\n (completedSteps.length < steps.length ? completedSteps.at(-1) : null);\n const activeStepIndex = activeStep ? steps.indexOf(activeStep) : -1;\n\n return (\n <div\n className={twMerge(\n \"min-h-[26rem] px-8 flex flex-col divide-y divide-neutral-800\",\n \"animate-in animate-duration-300 fade-in slide-in-from-bottom-8\",\n )}\n >\n {steps.map((step, i) => {\n const isActive = step === activeStep;\n const isExpanded = isActive || completedSteps.length === steps.length;\n const isDisabled = !step.isComplete && activeStepIndex !== -1 && i > activeStepIndex;\n return (\n <div key={step.id} className={twMerge(\"py-8 flex flex-col justify-center\", isActive ? \"flex-grow\" : null)}>\n <div className={twMerge(\"flex flex-col\", isDisabled ? \"opacity-30 pointer-events-none\" : null)}>\n {step.content({ isActive, isExpanded })}\n </div>\n </div>\n );\n })}\n </div>\n );\n}\n","import { ReactNode } from \"react\";\nimport { parseEther } from \"viem\";\n\nexport type Step = {\n id: string;\n isComplete: boolean;\n content: (props: { isActive: boolean; isExpanded: boolean }) => ReactNode;\n};\n\nexport const minGasBalance = parseEther(\"0.01\");\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getAllowance } from \"./getAllowance\";\n\nexport function getAllowanceQueryOptions({\n client,\n paymasterAddress,\n userAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n paymasterAddress: Address;\n userAddress: Address | undefined;\n}) {\n const queryKey = [\"getAllowance\", client?.chain.id, paymasterAddress, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: () => getAllowance({ client, paymasterAddress, userAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useAllowance(userAddress: Address | undefined) {\n const { chainId, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getAllowanceQueryOptions({ client, paymasterAddress, userAddress }));\n}\n","import { defineStore } from \"@latticexyz/store\";\nimport { parseAbi } from \"viem\";\n\n// TODO: dedupe this (exists in cli and entrykit)\n\n// TODO: whole ABI\nexport const paymasterAbi = parseAbi([\n \"error SpenderSystem_AlreadyRegistered(address spender, address user)\",\n \"error SpenderSystem_HasOwnBalance(address spender)\",\n \"function registerSpender(address spender)\",\n]);\n\nexport const paymasterConfig = defineStore({\n namespaces: {\n root: {\n namespace: \"\",\n tables: {\n Allowance: {\n schema: {\n user: \"address\",\n allowance: \"uint256\",\n },\n key: [\"user\"],\n },\n Grantor: {\n schema: {\n grantor: \"address\",\n allowance: \"uint256\",\n },\n key: [\"grantor\"],\n },\n PassHolder: {\n schema: {\n user: \"address\",\n passId: \"bytes32\",\n lastRenewed: \"uint256\",\n lastClaimed: \"uint256\",\n },\n key: [\"user\", \"passId\"],\n },\n PassConfig: {\n schema: {\n passId: \"bytes32\",\n claimAmount: \"uint256\",\n claimInterval: \"uint256\",\n validityPeriod: \"uint256\",\n grantor: \"address\",\n },\n key: [\"passId\"],\n },\n Spender: {\n schema: {\n spender: \"address\",\n user: \"address\",\n },\n key: [\"spender\"],\n },\n SystemConfig: {\n schema: {\n entryPoint: \"address\",\n },\n key: [],\n },\n },\n },\n },\n});\n\nexport const paymasterTables = paymasterConfig.namespaces.root.tables;\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { paymasterTables } from \"../paymaster\";\nimport { getRecord } from \"@latticexyz/store/internal\";\n\n// TODO: dedupe this (exists in cli and entrykit)\n\nexport type GetAllowanceParams = {\n client: Client<Transport, Chain>;\n paymasterAddress: Address;\n userAddress: Address;\n};\n\nexport async function getAllowance({ client, paymasterAddress, userAddress }: GetAllowanceParams) {\n const record = await getRecord(client, {\n address: paymasterAddress,\n table: paymasterTables.Allowance,\n key: { user: userAddress },\n blockTag: \"pending\",\n });\n return record.allowance;\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSpender } from \"./getSpender\";\n\nexport function getSpenderQueryOptions({\n client,\n paymasterAddress,\n userAddress,\n sessionAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n paymasterAddress: Address;\n userAddress: Address | undefined;\n sessionAddress: Address | undefined;\n}) {\n const queryKey = [\"getSpender\", client?.chain.id, paymasterAddress, userAddress, sessionAddress];\n return queryOptions(\n client && userAddress && sessionAddress\n ? {\n queryKey,\n queryFn: () => getSpender({ client, paymasterAddress, userAddress, sessionAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSpender(userAddress: Address | undefined, sessionAddress: Address | undefined) {\n const { chainId, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getSpenderQueryOptions({ client, paymasterAddress, userAddress, sessionAddress }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { paymasterTables } from \"../paymaster\";\nimport { getRecord } from \"@latticexyz/store/internal\";\n\nexport type GetSpenderParams = {\n client: Client<Transport, Chain>;\n paymasterAddress: Address;\n userAddress: Address;\n sessionAddress: Address;\n};\n\nexport async function getSpender({ client, paymasterAddress, userAddress, sessionAddress }: GetSpenderParams) {\n const record = await getRecord(client, {\n address: paymasterAddress,\n table: paymasterTables.Spender,\n key: { spender: sessionAddress },\n blockTag: \"pending\",\n });\n return record.user.toLowerCase() === userAddress.toLowerCase();\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getDelegation } from \"./getDelegation\";\n\nexport function getDelegationQueryOptions({\n client,\n worldAddress,\n userAddress,\n sessionAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n worldAddress: Address;\n userAddress: Address | undefined;\n sessionAddress: Address | undefined;\n}) {\n const queryKey = [\"getDelegation\", client?.chain.id, worldAddress, userAddress, sessionAddress];\n return queryOptions(\n client && userAddress && sessionAddress\n ? {\n queryKey,\n queryFn: () => getDelegation({ client, worldAddress, userAddress, sessionAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useDelegation(userAddress: Address | undefined, sessionAddress: Address | undefined) {\n const { chainId, worldAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getDelegationQueryOptions({ client, worldAddress, userAddress, sessionAddress }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { getRecord } from \"@latticexyz/store/internal\";\nimport { unlimitedDelegationControlId, worldTables } from \"../common\";\n\nexport type GetDelegationParams = {\n client: Client<Transport, Chain>;\n worldAddress: Address;\n userAddress: Address;\n sessionAddress: Address;\n};\n\nexport async function getDelegation({ client, worldAddress, userAddress, sessionAddress }: GetDelegationParams) {\n const record = await getRecord(client, {\n address: worldAddress,\n table: worldTables.UserDelegationControl,\n key: { delegator: userAddress, delegatee: sessionAddress },\n blockTag: \"pending\",\n });\n return record.delegationControlId === unlimitedDelegationControlId;\n}\n","import { minGasBalance } from \"./common\";\nimport { getAllowanceQueryOptions } from \"./useAllowance\";\nimport { getSpenderQueryOptions } from \"./useSpender\";\nimport { getDelegationQueryOptions } from \"./useDelegation\";\nimport { QueryClient, queryOptions, useQuery, useQueryClient } from \"@tanstack/react-query\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { Address, Chain, Client, Transport } from \"viem\";\nimport { getSessionAccountQueryOptions } from \"../useSessionAccount\";\n\nexport function getPrequisitesQueryOptions({\n queryClient,\n client,\n userAddress,\n paymasterAddress,\n worldAddress,\n}: {\n queryClient: QueryClient;\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n paymasterAddress: Address;\n worldAddress: Address;\n}) {\n const queryKey = [\"getPrerequisites\", client?.chain.id, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: async () => {\n const { address: sessionAddress } = await queryClient.fetchQuery(\n getSessionAccountQueryOptions({ client, userAddress }),\n );\n const [allowance, isSpender, hasDelegation] = await Promise.all([\n queryClient.fetchQuery(getAllowanceQueryOptions({ client, paymasterAddress, userAddress })),\n queryClient.fetchQuery(getSpenderQueryOptions({ client, paymasterAddress, userAddress, sessionAddress })),\n queryClient.fetchQuery(getDelegationQueryOptions({ client, worldAddress, userAddress, sessionAddress })),\n ]);\n const hasAllowance = allowance >= minGasBalance;\n return {\n hasAllowance,\n isSpender,\n hasDelegation,\n complete: hasAllowance && isSpender && hasDelegation,\n };\n },\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function usePrerequisites(userAddress: Address | undefined) {\n const queryClient = useQueryClient();\n const { chainId, paymasterAddress, worldAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n\n // TODO: rework this so it uses other hooks so we avoid having to clear two caches when e.g. topping up\n\n const prereqs = useQuery(\n getPrequisitesQueryOptions({\n queryClient,\n client,\n userAddress,\n paymasterAddress,\n worldAddress,\n }),\n queryClient,\n );\n // console.log(\"prereqs\", prereqs.isFetching, prereqs.isRefetching, prereqs.isFetchedAfterMount);\n return prereqs;\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { UseQueryResult, queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSessionAccount } from \"./getSessionAccount\";\nimport { SmartAccount } from \"viem/account-abstraction\";\n\nexport function getSessionAccountQueryOptions({\n client,\n userAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n}) {\n const queryKey = [\"getSessionAccount\", client?.chain.id, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: () => getSessionAccount({ client, userAddress }),\n staleTime: Infinity,\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSessionAccount(userAddress: Address | undefined): UseQueryResult<SmartAccount> {\n const { chainId } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getSessionAccountQueryOptions({ userAddress, client }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { toCoinbaseSmartAccount } from \"@latticexyz/common/accounts\";\nimport { getSessionSigner } from \"./getSessionSigner\";\n\nexport async function getSessionAccount<chain extends Chain>({\n client,\n userAddress,\n}: {\n client: Client<Transport, chain>;\n userAddress: Address;\n}): Promise<SmartAccount> {\n const sessionSigner = getSessionSigner(userAddress);\n return await toCoinbaseSmartAccount({ client, owners: [sessionSigner] });\n}\n","import { createStore } from \"zustand/vanilla\";\nimport { persist } from \"zustand/middleware\";\nimport { Address, Hex } from \"viem\";\n\nexport type State = {\n readonly signers: {\n readonly [key in Address]?: Hex;\n };\n};\n\nexport const store = createStore(\n persist<State>(\n () => ({\n signers: {},\n }),\n {\n name: \"mud:entrykit\",\n partialize: ({ signers }) => ({ signers }),\n },\n ),\n);\n\n// keep store in sync across tabs/windows via storage event\nfunction listener(event: StorageEvent) {\n if (event.key === store.persist.getOptions().name) {\n store.persist.rehydrate();\n }\n}\nwindow.addEventListener(\"storage\", listener);\n","import { Address } from \"viem\";\nimport { store } from \"./store\";\nimport { generatePrivateKey, privateKeyToAccount } from \"viem/accounts\";\n\nexport function getSessionSigner(userAddress: Address) {\n const sessionSignerPrivateKey =\n store.getState().signers[userAddress] ??\n (() => {\n const privateKey = generatePrivateKey();\n store.setState((state) => ({\n signers: {\n ...state.signers,\n [userAddress]: privateKey,\n },\n }));\n return privateKey;\n })();\n\n return privateKeyToAccount(sessionSignerPrivateKey);\n}\n","import { useDisconnect } from \"wagmi\";\nimport { useENS } from \"../useENS\";\nimport { TruncatedHex } from \"../ui/TruncatedHex\";\nimport { Button } from \"../ui/Button\";\nimport { useAccountModal } from \"../useAccountModal\";\nimport { Hex } from \"viem\";\n\nexport type Props = {\n isActive: boolean;\n isExpanded: boolean;\n userAddress: Hex;\n};\n\nexport function Wallet({ isActive, isExpanded, userAddress }: Props) {\n const { data: ens } = useENS(userAddress);\n const { disconnect, isPending: disconnectIsPending } = useDisconnect();\n const { closeAccountModal } = useAccountModal();\n\n // TODO: render ENS avatar if available?\n // TODO: display disconnect error as popover near button?\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Account</div>\n <div className=\"font-mono text-white\">{ens?.name ?? <TruncatedHex hex={userAddress} />}</div>\n </div>\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive}\n pending={disconnectIsPending}\n onClick={() => {\n closeAccountModal();\n disconnect();\n }}\n >\n Sign out\n </Button>\n </div>\n {isExpanded ? (\n <p className=\"text-sm\">Each of your onchain actions in this app is associated with your account.</p>\n ) : null}\n </div>\n );\n}\n","import { Hex } from \"viem\";\nimport { useQuery } from \"@tanstack/react-query\";\n\nexport function useENS(address: Hex | undefined) {\n const normalizedAddress = address?.toLowerCase();\n return useQuery<{\n address: string | undefined;\n name: string | undefined;\n displayName: string | undefined;\n avatar: string | undefined;\n }>({\n enabled: !!normalizedAddress,\n queryKey: [\"ens\", normalizedAddress],\n\n queryFn: async () => {\n // TODO: typed response\n const data = await fetch(`https://api.ensideas.com/ens/resolve/${normalizedAddress}`).then((res) => res.json());\n return {\n address: data.address ?? undefined,\n name: data.name ?? undefined,\n displayName: data.displayName ?? undefined,\n avatar: data.avatar ?? undefined,\n };\n },\n });\n}\n","import { Hex } from \"viem\";\n\nexport type Props = {\n hex: Hex;\n};\n\nexport function TruncatedHex({ hex }: Props) {\n if (hex.length <= 10) {\n return <span title={hex}>{hex}</span>;\n }\n\n return (\n <span title={hex}>\n <span className=\"after:select-none after:content-['…']\">{hex.slice(0, 6)}</span>\n <span className=\"tracking-[-1ch] text-transparent\">{hex.slice(6, -4)}</span>\n {hex.slice(-4)}\n </span>\n );\n}\n","import { Address } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { claimGasPass } from \"@latticexyz/paymaster/internal\";\n\nexport function useClaimGasPass() {\n const queryClient = useQueryClient();\n const { chain } = useEntryKitConfig();\n\n const mutationKey = [\"claimGasPass\", chain.id];\n return useMutation({\n mutationKey,\n onError: (error) => console.error(error),\n mutationFn: async (userAddress: Address) => {\n // TODO: handle case where you already have a pass?\n // TODO: get returned tx hashes to check if success\n await claimGasPass({ chain, userAddress });\n\n await Promise.all([\n queryClient.invalidateQueries({ queryKey: [\"getAllowance\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getPrerequisites\"] }),\n ]);\n },\n retry: 0,\n });\n}\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function EthIcon({ className, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 263 428\"\n fill=\"currentColor\"\n className={twMerge(\"w-[0.6em] h-[1em]\", className)}\n {...props}\n >\n <path d=\"M132 321V428L263 243L132 321Z\" />\n <path d=\"M0 243L132 321V428\" fillOpacity=\"0.5\" />\n <path d=\"M132 0V296L263 218\" />\n <path d=\"M0 218L132 296V0L0 218Z\" fillOpacity=\"0.5\" />\n </svg>\n );\n}\n","import { formatEther } from \"viem\";\n\nexport function formatBalance(wei: bigint) {\n // TODO: should this support non-ether decimals?\n const formatted = formatEther(wei);\n const magnitude = Math.floor(parseFloat(formatted)).toString().length;\n return parseFloat(formatted).toLocaleString(\"en-US\", { maximumFractionDigits: Math.max(0, 6 - magnitude) });\n}\n","import { EthIcon } from \"../icons/EthIcon\";\nimport { formatBalance } from \"../formatBalance\";\n\ntype Props = {\n wei: bigint;\n};\n\nexport function Balance({ wei }: Props) {\n return (\n <span className=\"inline-flex items-center gap-1\">\n {formatBalance(wei)} <EthIcon />\n </span>\n );\n}\n","import { Hex } from \"viem\";\nimport { useAllowance } from \"./useAllowance\";\nimport { PendingIcon } from \"../icons/PendingIcon\";\nimport { useClaimGasPass } from \"./useClaimGasPass\";\nimport { Button } from \"../ui/Button\";\nimport { Balance } from \"../ui/Balance\";\nimport { useEffect } from \"react\";\nimport { minGasBalance } from \"./common\";\n\nexport type Props = {\n isExpanded: boolean;\n isActive: boolean;\n userAddress: Hex;\n};\n\nexport function Allowance({ isActive, isExpanded, userAddress }: Props) {\n const allowance = useAllowance(userAddress);\n const claimGasPass = useClaimGasPass();\n\n useEffect(() => {\n // There seems to be a tanstack-query bug(?) where multiple simultaneous renders loses\n // state between the two mutations. They're not treated as shared state but rather\n // individual mutations, even though the keys match. And the one we want the status of\n // seems to stay pending. This is sorta resolved by triggering this after a timeout.\n const timer = setTimeout(() => {\n if (isActive && claimGasPass.status === \"idle\" && allowance.isSuccess && allowance.data < minGasBalance) {\n claimGasPass.mutate(userAddress);\n }\n });\n return () => clearTimeout(timer);\n }, [allowance.data, allowance.isSuccess, claimGasPass, isActive, userAddress]);\n\n // TODO: show error if allowance fails to load\n // TODO: show claim error\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Allowance</div>\n <div className=\"font-mono text-white\">\n {allowance.data != null ? <Balance wei={allowance.data} /> : <PendingIcon className=\"text-sm\" />}\n </div>\n </div>\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive || isExpanded}\n pending={allowance.status === \"pending\" || claimGasPass.status === \"pending\"}\n onClick={() => claimGasPass.mutate(userAddress)}\n >\n Top up\n </Button>\n </div>\n {isExpanded ? <p className=\"text-sm\">Your allowance is used to pay for onchain computation.</p> : null}\n </div>\n );\n}\n","import { Hex, encodeFunctionData } from \"viem\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { getAction } from \"viem/utils\";\nimport { sendUserOperation, waitForUserOperationReceipt } from \"viem/account-abstraction\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { ConnectedClient, unlimitedDelegationControlId, worldAbi } from \"../common\";\nimport { paymasterAbi } from \"../paymaster\";\nimport { waitForTransactionReceipt } from \"viem/actions\";\nimport { defineCall } from \"../utils/defineCall\";\nimport { useClient } from \"wagmi\";\nimport { resourceToHex } from \"@latticexyz/common\";\nimport IBaseWorldAbi from \"@latticexyz/world/out/IBaseWorld.sol/IBaseWorld.abi.json\";\nimport { callWithSignature } from \"../utils/callWithSignature\";\n\nexport function useSetupSession({ userClient }: { userClient: ConnectedClient }) {\n const queryClient = useQueryClient();\n const { chainId, worldAddress, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n\n const mutationKey = [\"setupSession\", client?.chain.id, userClient.account.address];\n return useMutation({\n mutationKey,\n onError: (error) => console.error(error),\n mutationFn: async ({\n sessionClient,\n registerSpender,\n registerDelegation,\n }: {\n sessionClient: ConnectedClient;\n registerSpender: boolean;\n registerDelegation: boolean;\n }): Promise<void> => {\n if (!client) throw new Error(\"Client not ready.\");\n const sessionAddress = sessionClient.account.address;\n\n console.log(\"setting up session\");\n\n if (userClient.account.type !== \"smart\") {\n const txs: Hex[] = [];\n\n if (registerSpender) {\n console.log(\"registering spender\");\n const tx = await callWithSignature({\n client,\n userClient,\n sessionClient,\n worldAddress: paymasterAddress,\n systemId: resourceToHex({ type: \"system\", namespace: \"\", name: \"SpenderSystem\" }),\n callData: encodeFunctionData({\n abi: paymasterAbi,\n functionName: \"registerSpender\",\n args: [sessionAddress],\n }),\n });\n console.log(\"got spender tx\", tx);\n txs.push(tx);\n }\n\n if (registerDelegation) {\n console.log(\"registering delegation\");\n const tx = await callWithSignature({\n client,\n userClient,\n sessionClient,\n worldAddress,\n systemId: resourceToHex({ type: \"system\", namespace: \"\", name: \"Registration\" }),\n callData: encodeFunctionData({\n abi: IBaseWorldAbi,\n functionName: \"registerDelegation\",\n args: [sessionAddress, unlimitedDelegationControlId, \"0x\"],\n }),\n });\n console.log(\"got delegation tx\", tx);\n txs.push(tx);\n }\n\n if (!txs.length) return;\n\n console.log(\"waiting for\", txs.length, \"receipts\");\n for (const hash of txs) {\n const receipt = await getAction(client, waitForTransactionReceipt, \"waitForTransactionReceipt\")({ hash });\n console.log(\"got tx receipt\", receipt);\n if (receipt.status === \"reverted\") {\n console.error(\"tx reverted?\", receipt);\n }\n }\n } else {\n const calls = [];\n\n if (registerSpender) {\n console.log(\"registering spender\");\n calls.push(\n defineCall({\n to: paymasterAddress,\n abi: paymasterAbi,\n functionName: \"registerSpender\",\n args: [sessionAddress],\n }),\n );\n }\n\n if (registerDelegation) {\n console.log(\"registering delegation\");\n calls.push(\n defineCall({\n to: worldAddress,\n abi: worldAbi,\n functionName: \"registerDelegation\",\n args: [sessionAddress, unlimitedDelegationControlId, \"0x\"],\n }),\n );\n }\n\n if (!calls.length) return;\n\n // if (!(await userClient.account.isDeployed())) {\n // // send empty tx to create the smart account, otherwise the first tx may fail due to bad gas estimation\n // console.log(\"creating smart account at\", userClient.account.address);\n // const hash = await getAction(userClient, sendUserOperation, \"sendUserOperation\")({ calls: [] });\n // console.log(\"tx:\", hash);\n // const receipt = await getAction(userClient, waitForTransactionReceipt, \"waitForTransactionReceipt\")({ hash });\n // console.log(\"receipt:\", receipt.status);\n // }\n\n console.log(\"setting up account with\", calls, userClient);\n const hash = await getAction(userClient, sendUserOperation, \"sendUserOperation\")({ calls });\n console.log(\"got user op hash\", hash);\n\n const receipt = await getAction(\n userClient,\n waitForUserOperationReceipt,\n \"waitForUserOperationReceipt\",\n )({ hash });\n console.log(\"got user op receipt\", receipt);\n\n if (!receipt.success) {\n console.error(\"not successful?\", receipt);\n }\n }\n\n await Promise.all([\n queryClient.invalidateQueries({ queryKey: [\"getSpender\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getDelegation\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getPrerequisites\"] }),\n ]);\n },\n retry: 0,\n });\n}\n","import { Chain } from \"viem\";\nimport { writeContract as viem_writeContract } from \"viem/actions\";\nimport { getAction } from \"viem/utils\";\nimport { SignCallOptions, signCall } from \"./signCall\";\nimport CallWithSignatureAbi from \"@latticexyz/world-modules/out/Unstable_CallWithSignatureSystem.sol/Unstable_CallWithSignatureSystem.abi.json\";\nimport { ConnectedClient } from \"../common\";\n\n// TODO: move this to world package or similar\n\nexport type CallWithSignatureOptions<chain extends Chain = Chain> = SignCallOptions<chain> & {\n sessionClient: ConnectedClient;\n};\n\nexport async function callWithSignature<chain extends Chain = Chain>({\n sessionClient,\n ...opts\n}: CallWithSignatureOptions<chain>) {\n const signature = await signCall(opts);\n return getAction(\n sessionClient,\n viem_writeContract,\n \"writeContract\",\n )({\n address: opts.worldAddress,\n abi: CallWithSignatureAbi,\n functionName: \"callWithSignature\",\n args: [opts.userClient.account.address, opts.systemId, opts.callData, signature],\n } as never);\n}\n","import { Address, Chain, Client, Hex, OneOf, Transport, toHex } from \"viem\";\nimport { signTypedData } from \"viem/actions\";\nimport { callWithSignatureTypes } from \"@latticexyz/world/internal\";\nimport { getRecord } from \"@latticexyz/store/internal\";\nimport modulesConfig from \"@latticexyz/world-modules/internal/mud.config\";\nimport { hexToResource } from \"@latticexyz/common\";\nimport { getAction } from \"viem/utils\";\nimport { ConnectedClient } from \"../common\";\n\n// TODO: move this to world package or similar\n\nexport type SignCallOptions<chain extends Chain = Chain> = {\n userClient: ConnectedClient<chain>;\n worldAddress: Address;\n systemId: Hex;\n callData: Hex;\n} & OneOf<{ nonce: bigint } | { client: Client<Transport, chain> }>;\n\nexport async function signCall<chain extends Chain = Chain>({\n userClient,\n worldAddress,\n systemId,\n callData,\n nonce: initialNonce,\n client,\n}: SignCallOptions<chain>) {\n const nonce =\n initialNonce ??\n (client\n ? (\n await getRecord(client, {\n address: worldAddress,\n table: modulesConfig.tables.CallWithSignatureNonces,\n key: { signer: userClient.account.address },\n blockTag: \"pending\",\n })\n ).nonce\n : 0n);\n\n const { namespace: systemNamespace, name: systemName } = hexToResource(systemId);\n\n return await getAction(\n userClient,\n signTypedData,\n \"signTypedData\",\n )({\n account: userClient.account,\n domain: {\n verifyingContract: worldAddress,\n salt: toHex(userClient.chain.id, { size: 32 }),\n },\n types: callWithSignatureTypes,\n primaryType: \"Call\",\n message: {\n signer: userClient.account.address,\n systemNamespace,\n systemName,\n callData,\n nonce,\n },\n });\n}\n","import { Button } from \"../ui/Button\";\nimport { useSetupSession } from \"./useSetupSession\";\nimport { ConnectedClient } from \"../common\";\nimport { useEffect } from \"react\";\nimport { useSessionClient } from \"../useSessionClient\";\n\nexport type Props = {\n isActive: boolean;\n isExpanded: boolean;\n userClient: ConnectedClient;\n registerSpender: boolean;\n registerDelegation: boolean;\n};\n\nexport function Session({ isActive, isExpanded, userClient, registerSpender, registerDelegation }: Props) {\n const { data: sessionClient } = useSessionClient(userClient.account.address);\n const setup = useSetupSession({ userClient });\n const hasSession = !registerDelegation && !registerDelegation;\n\n useEffect(() => {\n // There seems to be a tanstack-query bug(?) where multiple simultaneous renders loses\n // state between the two mutations. They're not treated as shared state but rather\n // individual mutations, even though the keys match. And the one we want the status of\n // seems to stay pending. This is sorta resolved by triggering this after a timeout.\n const timer = setTimeout(() => {\n if (isActive && setup.status === \"idle\" && sessionClient && !hasSession) {\n setup.mutate({\n sessionClient,\n registerSpender,\n registerDelegation,\n });\n }\n });\n return () => clearTimeout(timer);\n }, [hasSession, isActive, registerDelegation, registerSpender, sessionClient, setup]);\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Session</div>\n <div className=\"font-mono text-white\">{hasSession ? \"Enabled\" : \"Set up\"}</div>\n </div>\n {hasSession ? (\n <Button variant=\"tertiary\" className=\"flex-shrink-0 text-sm p-1 w-28\" autoFocus={isActive} disabled>\n Enabled\n </Button>\n ) : (\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive}\n pending={!sessionClient || setup.status === \"pending\"}\n onClick={\n sessionClient\n ? () =>\n setup.mutate({\n sessionClient,\n registerSpender,\n registerDelegation,\n })\n : undefined\n }\n >\n Enable\n </Button>\n )}\n </div>\n {isExpanded ? (\n <p className=\"text-sm\">You can perform actions in this app without interruptions for approvals.</p>\n ) : null}\n </div>\n );\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { UseQueryResult, queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSessionClient } from \"./getSessionClient\";\nimport { SessionClient } from \"./common\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { useSessionAccount } from \"./useSessionAccount\";\n\nexport function getSessionClientQueryOptions({\n sessionAccount,\n client,\n userAddress,\n worldAddress,\n paymasterAddress,\n}: {\n sessionAccount: SmartAccount | undefined;\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n worldAddress: Address;\n paymasterAddress: Address;\n}) {\n const queryKey = [\"getSessionClient\", client?.uid, userAddress, sessionAccount?.address, worldAddress];\n return queryOptions(\n client && userAddress && sessionAccount\n ? {\n queryKey,\n queryFn: () =>\n getSessionClient({\n sessionAccount,\n client,\n userAddress,\n worldAddress,\n paymasterAddress,\n }),\n staleTime: Infinity,\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSessionClient(userAddress: Address | undefined): UseQueryResult<SessionClient> {\n const { chainId, worldAddress, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n const { data: sessionAccount } = useSessionAccount(userAddress);\n return useQuery(\n getSessionClientQueryOptions({\n sessionAccount,\n userAddress,\n client,\n worldAddress,\n paymasterAddress,\n }),\n );\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { smartAccountActions } from \"permissionless\";\nimport { callFrom } from \"@latticexyz/world/internal\";\nimport { createBundlerClient } from \"./createBundlerClient\";\nimport { observer } from \"@latticexyz/explorer/observer\";\nimport { SessionClient } from \"./common\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { getBundlerTransport } from \"./getBundlerTransport\";\n\nexport async function getSessionClient<chain extends Chain>({\n client,\n userAddress,\n sessionAccount,\n worldAddress,\n paymasterAddress,\n}: {\n client: Client<Transport, chain>;\n userAddress: Address;\n sessionAccount: SmartAccount;\n worldAddress: Address;\n paymasterAddress: Address;\n}): Promise<SessionClient<chain>> {\n const bundlerTransport = getBundlerTransport(client.chain);\n\n const sessionClient = createBundlerClient({\n paymasterAddress,\n transport: bundlerTransport,\n client,\n account: sessionAccount,\n })\n .extend(smartAccountActions())\n .extend(callFrom({ worldAddress, delegatorAddress: userAddress, publicClient: client }))\n .extend(observer())\n .extend(() => ({ userAddress }));\n\n return sessionClient;\n}\n","import { ReactNode, useState } from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\nimport { ErrorNotice } from \"./ErrorNotice\";\nimport { wait } from \"@latticexyz/common/utils\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useIsMounted } from \"usehooks-ts\";\nimport { PendingIcon } from \"./icons/PendingIcon\";\n\nexport type Props = {\n children: ReactNode;\n};\n\nexport function AccountModalErrorBoundary({ children }: Props) {\n const isMounted = useIsMounted();\n const [retries, setRetries] = useState(1);\n\n // TODO: invalidate query cache?\n\n return (\n <ErrorBoundary\n fallbackRender={({ error, resetErrorBoundary }) => (\n <div className={twMerge(\"flex-grow flex flex-col justify-center p-5 gap-2\")}>\n <ErrorNotice error={error instanceof Error ? error.stack ?? error.message : error} />\n {retries > 0 ? (\n <button\n type=\"button\"\n onClick={async (event) => {\n // fake pending state while we retry so that if the same error occurs,\n event.currentTarget.ariaBusy = \"true\";\n await wait(1000);\n resetErrorBoundary();\n if (isMounted()) {\n setRetries((value) => value - 1);\n event.currentTarget.ariaBusy = null;\n }\n }}\n className=\"group aria-busy:pointer-events-none self-end flex items-center gap-1\"\n >\n <PendingIcon className=\"transition opacity-0 group-aria-busy:opacity-100 text-xs text-neutral-500 dark:text-neutral-400\" />\n <span className=\"text-sm text-neutral-500 dark:text-neutral-400 group-hover:text-black dark:group-hover:text-white\">\n Retry?\n </span>\n </button>\n ) : null}\n </div>\n )}\n >\n {children}\n </ErrorBoundary>\n );\n}\n","import { twMerge } from \"tailwind-merge\";\nimport { BaseError, UserRejectedRequestError } from \"viem\";\n\nexport type Props = {\n title?: string;\n error?: unknown;\n};\n\nexport function ErrorNotice({ title: initialTitle, error }: Props) {\n if (!error) return null;\n // no need to let users know they rejected\n if (error instanceof BaseError && error.walk((e) => e instanceof UserRejectedRequestError) != null) {\n return null;\n }\n\n // TODO: extract title from error name or first line of error message?\n const title = initialTitle ?? \"Error\";\n\n // TODO: do something to protect against `[object Object]`\n const message =\n typeof error === \"string\" ? error : error instanceof Error ? String(error) : \"Something unexpected happened.\";\n\n // TODO: add \"report error\" link\n\n return (\n <div\n className={twMerge(\n \"text-sm border-l-4 border-red-500\",\n \"bg-red-100 text-red-900\",\n \"dark:bg-red-900 dark:text-red-50\",\n )}\n >\n <div className=\"p-3 font-semibold\">{title}</div>\n <div className=\"px-3 whitespace-break-spaces break-all max-h-32 overflow-y-scroll\">{message}</div>\n </div>\n );\n}\n","import { SVGProps } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = SVGProps<SVGSVGElement>;\n\nexport function IconSVG({ className, children, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em]\", className)}\n {...props}\n >\n {children}\n </svg>\n );\n}\n","import { IconSVG, Props } from \"./IconSVG\";\n\nexport function CloseIcon(props: Props) {\n return (\n <IconSVG strokeWidth=\"2\" stroke=\"currentColor\" {...props}>\n <path\n d=\"M6 18L18 6M6 6L18 18\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </IconSVG>\n );\n}\n","import { type ReactNode } from \"react\";\nimport { AccountModal } from \"./AccountModal\";\nimport { EntryKitConfig } from \"./config/output\";\nimport { EntryKitConfigProvider } from \"./EntryKitConfigProvider\";\n\n// We separate the config provider and wrap it here to always include the modal.\n// We could do this in EntryKitConfigProvider directly, but it mucks with hot\n// reloading in development and this approach lets us work around it more easily.\n\nexport type Props = {\n config: EntryKitConfig;\n children?: ReactNode;\n};\n\nexport function EntryKitProvider({ config, children }: Props) {\n return (\n <EntryKitConfigProvider config={config}>\n {children}\n <AccountModal />\n </EntryKitConfigProvider>\n );\n}\n","import { useAccountModal } from \"./useAccountModal\";\nimport { Shadow } from \"./ui/Shadow\";\nimport { Logo } from \"./icons/Logo\";\nimport { useAccount } from \"wagmi\";\nimport { twMerge } from \"tailwind-merge\";\nimport { PendingIcon } from \"./icons/PendingIcon\";\nimport { AccountName } from \"./AccountName\";\nimport { usePrerequisites } from \"./onboarding/usePrerequisites\";\nimport { useRef } from \"react\";\n\nconst containerClassNames = twMerge(\n \"w-48 p-3 inline-flex outline-none transition\",\n \"border border-transparent\",\n \"text-base leading-none\",\n);\n\nconst secondaryClassNames = twMerge(\n \"bg-neutral-100 border-neutral-300 text-black\",\n \"dark:bg-neutral-800 dark:border-neutral-700 dark:text-white\",\n);\nconst secondaryInteractiveClassNames = twMerge(\n \"cursor-pointer outline-none hover:bg-neutral-200 data-[highlighted]:bg-neutral-200 dark:hover:bg-neutral-700\",\n);\n\nexport function AccountButton() {\n const { openAccountModal, accountModalOpen } = useAccountModal();\n const { status, address: userAddress } = useAccount();\n const initialUserAddress = useRef(userAddress);\n\n const prereqs = usePrerequisites(userAddress);\n\n // TODO: fix flash of button state signed in but incomplete onboarding\n const isConnected = status === \"connected\" || (status === \"reconnecting\" && userAddress);\n const isNewConnection = userAddress !== initialUserAddress.current;\n const isSignedIn = prereqs.isSuccess ? prereqs.data.complete : isNewConnection ? false : isConnected;\n\n const buttonLabel = (() => {\n if (prereqs.isSuccess) {\n if (!prereqs.data.hasAllowance) return \"Top up\";\n if (!prereqs.data.hasDelegation || !prereqs.data.isSpender) return \"Set up\";\n }\n return \"Sign in\";\n })();\n\n return (\n <Shadow mode=\"child\">\n {isSignedIn ? (\n <button\n // key is used to avoid triggering transitions between connected/disconnected states\n key=\"connected\"\n type=\"button\"\n className={twMerge(containerClassNames, secondaryClassNames, secondaryInteractiveClassNames)}\n onClick={openAccountModal}\n >\n <span className=\"flex-grow inline-flex gap-2.5 items-center text-left font-medium\">\n {userAddress ? <AccountName address={userAddress} /> : null}\n </span>\n </button>\n ) : (\n <button\n // key is used to avoid triggering transitions between connected/disconnected states\n key=\"sign in\"\n type=\"button\"\n className={twMerge(\n containerClassNames,\n \"group\",\n \"items-center justify-center gap-2.5\",\n \"bg-orange-500 text-white font-medium\",\n \"hover:bg-orange-400\",\n \"active:bg-orange-600\",\n )}\n aria-busy={accountModalOpen}\n onClick={openAccountModal}\n >\n <span className=\"pointer-events-none inline-grid place-items-center -ml-3\">\n <span\n className={twMerge(\n \"col-start-1 row-start-1 leading-none\",\n \"scale-100 opacity-100 transition duration-300\",\n \"group-aria-busy:scale-125 group-aria-busy:opacity-0\",\n )}\n >\n <Logo />\n </span>\n <span\n aria-hidden\n className={twMerge(\n \"col-start-1 row-start-1\",\n \"scale-50 opacity-0 transition duration-300 delay-50\",\n \"group-aria-busy:scale-100 group-aria-busy:opacity-100\",\n )}\n >\n <PendingIcon />\n </span>\n </span>\n <span className=\"font-medium\">{buttonLabel}</span>\n </button>\n )}\n </Shadow>\n );\n}\n","import { Hex } from \"viem\";\nimport { useENS } from \"./useENS\";\nimport { Logo } from \"./icons/Logo\";\nimport { TruncatedHex } from \"./ui/TruncatedHex\";\nimport { usePreloadImage } from \"./usePreloadImage\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = {\n address: Hex;\n};\n\nexport function AccountName({ address }: Props) {\n const { data: ens } = useENS(address);\n const avatar = usePreloadImage(ens?.avatar);\n\n return (\n <>\n <span className=\"flex-shrink-0 w-6 h-6 -my-1 -mx-0.5 grid place-items-center\">\n <img\n src={ens?.avatar && avatar.isSuccess ? ens.avatar : undefined}\n className={twMerge(\n \"col-start-1 row-start-1\",\n \"inline-flex w-full h-full rounded-full bg-black/10 dark:bg-white/10 bg-cover bg-no-repeat bg-center\",\n \"transtion duration-300\",\n avatar.isSuccess ? \"opacity-100\" : \"opacity-0\",\n )}\n />\n <Logo\n className={twMerge(\n \"col-start-1 row-start-1 text-orange-500\",\n \"transition duration-300\",\n ens && (!ens.avatar || avatar.isError) ? \"opacity-100\" : \"opacity-0\",\n )}\n />\n </span>\n <span className=\"flex-grow\">{ens?.name ?? <TruncatedHex hex={address} />}</span>\n </>\n );\n}\n","// Exported `useSessionClient` variant and only provides the session client once all prerequisites are met.\n\nimport { useConnectorClient } from \"wagmi\";\nimport { useSessionClient } from \"./useSessionClient\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { usePrerequisites } from \"./onboarding/usePrerequisites\";\nimport { UseQueryResult } from \"@tanstack/react-query\";\nimport { SessionClient } from \"./common\";\n\nexport function useSessionClientReady(): UseQueryResult<SessionClient | undefined> {\n const { chainId } = useEntryKitConfig();\n const userClient = useConnectorClient({ chainId });\n if (userClient.error) console.error(\"Error retrieving user client\", userClient.error);\n\n const userAddress = userClient.data?.account.address;\n const prerequisites = usePrerequisites(userAddress);\n const sessionClient = useSessionClient(userAddress);\n\n if (!userClient.isSuccess) return { ...userClient, data: undefined } as never;\n if (!prerequisites.isSuccess || !prerequisites.data.complete) return { ...prerequisites, data: undefined } as never;\n return sessionClient;\n}\n","import { Chain, Transport } from \"viem\";\nimport { WalletList, connectorsForWallets, getDefaultWallets } from \"@rainbow-me/rainbowkit\";\nimport { Config, CreateConfigParameters, createConfig } from \"wagmi\";\nimport { passkeyWallet } from \"./passkey/passkeyWallet\";\nimport { mapObject } from \"@latticexyz/common/utils\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\n\nexport type CreateWagmiConfigOptions<\n chains extends readonly [Chain, ...Chain[]] = readonly [Chain, ...Chain[]],\n transports extends Record<chains[number][\"id\"], Transport> = Record<chains[number][\"id\"], Transport>,\n> = {\n readonly chainId: number;\n readonly chains: chains;\n readonly transports: transports;\n /**\n * WalletConnect project ID, obtained from your WalletConnect dashboard.\n */\n // TODO: make optional and hide wallet options if so?\n readonly walletConnectProjectId: string;\n readonly appName: string;\n} & Pick<CreateConfigParameters<chains, transports>, \"pollingInterval\">;\n\nexport function createWagmiConfig<\n const chains extends readonly [Chain, ...Chain[]],\n transports extends Record<chains[number][\"id\"], Transport>,\n>(config: CreateWagmiConfigOptions<chains, transports>): Config<chains, transports> {\n const { wallets: defaultWallets } = getDefaultWallets();\n const wallets: WalletList = [\n {\n groupName: \"Recommended\",\n wallets: [\n passkeyWallet({\n // TODO: allow any chain ID\n chainId: config.chainId,\n }),\n ],\n },\n ...defaultWallets,\n ];\n\n const connectors = connectorsForWallets(wallets, {\n appName: config.appName,\n projectId: config.walletConnectProjectId,\n });\n\n return createConfig({\n connectors,\n chains: config.chains,\n transports: mapObject(config.transports, (transport) => wiresaw(transport)),\n pollingInterval: config.pollingInterval,\n }) as never;\n}\n","import { Wallet } from \"@rainbow-me/rainbowkit\";\nimport { PasskeyConnectorOptions, passkeyConnector } from \"./passkeyConnector\";\n\nconst iconUrl = `data:image/svg+xml;base64,${btoa(\n // eslint-disable-next-line max-len\n '<svg xmlns=\"http://www.w3.org/2000/svg\" shape-rendering=\"geometricPrecision\" text-rendering=\"geometricPrecision\" image-rendering=\"optimizeQuality\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" width=\"512\" height=\"512\" viewBox=\"-64 -32 608 512\"><path d=\"M6.206 425.469A6.202 6.202 0 010 419.263c0-1.771.235-3.517.663-5.245 9.95-78.847 57.22-96.006 100.964-107.256 21.008-5.412 62.901-26.489 57.822-53.668-10.596-9.819-21.113-23.39-22.946-43.63l-1.274.026c-2.932-.044-5.778-.716-8.422-2.217-5.848-3.325-9.051-9.697-10.596-16.958-3.238-22.186-4.058-33.515 7.768-38.464l.096-.035c-1.467-27.37 3.159-67.64-24.944-76.141C154.622 7.1 218.597-30.203 266.627 30.805c53.519 2.801 77.389 78.611 44.154 121.046h-1.405c11.826 4.949 10.045 17.674 7.767 38.464-1.544 7.261-4.747 13.633-10.595 16.958-2.645 1.501-5.481 2.173-8.422 2.217l-1.275-.026c-1.833 20.24-12.376 33.811-22.972 43.63-4.459 23.871 27.275 43.011 49.33 50.997a139.442 139.442 0 004.268 5.525c-7.2 9.941-8.771 22.797-4.564 34.038-17.002 8.763-24.255 29.334-16.479 46.86-11.966 7.55-18.258 21.305-16.609 34.955H6.206zm419.058-105.362a86.778 86.778 0 0019.446-1.641c29.36-5.822 53.152-27.467 62.657-55.823 3.596-10.544 5.071-21.663 4.521-33.341-1.179-23.46-12.193-46.633-29.631-62.369-17.107-15.361-38.342-23.574-61.383-23.042-22.841.507-45.359 11.216-60.187 28.593-14.977 17.551-22.003 39.144-20.921 62.133.585 11.661 3.482 23.016 8.737 34.074 7.741 16.303 19.934 29.735 35.391 39.048l-22.457 20.711 13.232 27.86-29.413 13.973 13.991 29.456-26.769 12.717 16.81 35.374 35.601-16.915 40.375-110.808zm15.239-129.364c13.685 4.869 20.824 19.908 15.954 33.593-4.87 13.685-19.908 20.833-33.593 15.963-13.685-4.87-20.834-19.917-15.963-33.602 4.87-13.685 19.917-20.825 33.602-15.954z\"/></svg>',\n)}`;\n\nexport type PasskeyWalletOptions = PasskeyConnectorOptions;\n\nexport const passkeyWallet = (opts: PasskeyWalletOptions) => (): Wallet => ({\n id: \"passkey\",\n name: \"Passkey\",\n iconUrl,\n iconBackground: \"#fec\",\n createConnector: (walletDetails) => (config) => ({\n ...passkeyConnector(opts)(config),\n ...walletDetails,\n }),\n});\n","import { WalletList, connectorsForWallets } from \"@rainbow-me/rainbowkit\";\nimport { getWallets } from \"./getWallets\";\nimport { CreateConnectorFn } from \"wagmi\";\n\nexport function getConnectors({\n wallets,\n ...config\n}: {\n readonly chainId: number;\n /**\n * WalletConnect project ID, obtained from your WalletConnect dashboard.\n */\n // TODO: make optional and hide wallet options if so?\n readonly walletConnectProjectId: string;\n readonly appName: string;\n} & { readonly wallets?: WalletList }): CreateConnectorFn[] {\n return connectorsForWallets(wallets ?? getWallets(config), {\n appName: config.appName,\n projectId: config.walletConnectProjectId,\n });\n}\n","import { WalletList, getDefaultWallets } from \"@rainbow-me/rainbowkit\";\nimport { passkeyWallet } from \"./passkey/passkeyWallet\";\n\nexport function getWallets(config: { readonly chainId: number }): WalletList {\n const { wallets: defaultWallets } = getDefaultWallets();\n return [\n {\n groupName: \"Recommended\",\n wallets: [\n passkeyWallet({\n // TODO: allow any chain ID\n chainId: config.chainId,\n }),\n ],\n },\n ...defaultWallets,\n ];\n}\n"],"mappings":"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","names":["defineConfig","input","DialogRoot","DialogPortal","DialogContent","forwardRef","useEffect","useRef","useState","ReactDOM","useResizeObserver","mergeRefs","createContext","useContext","jsx","Context","FrameProvider","frame","children","useMediaQuery","createContext","useContext","RainbowKitProvider","lightTheme","midnightTheme","useChains","getChainContractAddress","getPaymasterAddress","chain","jsx","Context","createContext","EntryKitConfigProvider","config","children","useContext","chain","useChains","id","paymasterAddress","getPaymasterAddress","RainbowKitProvider","lightTheme","midnightTheme","useEntryKitConfig","useTheme","initialTheme","useEntryKitConfig","darkMode","useMediaQuery","jsx","jsxs","Resizer","onSize","props","ref","useRef","useResizeObserver","Shadow","forwardRef","mode","children","forwardedRef","frameRef","loaded","setLoaded","useState","frame","frameSize","setFrameSize","frameDocument","theme","useTheme","useEffect","frameStyle","mergeRefs","ReactDOM","FrameProvider","tailwind_default","twMerge","jsx","jsxs","Modal","open","onOpenChange","children","DialogRoot","DialogPortal","Shadow","DialogContent","event","useCallback","useMemo","useStore","createStore","store","useAccountModal","accountModalOpen","state","openAccountModal","closeAccountModal","toggleAccountModal","open","twMerge","useAccount","useConnectorClient","useAccount","twMerge","twMerge","jsx","jsxs","PendingIcon","className","props","jsx","jsxs","buttonClassName","variant","twMerge","Button","pending","type","className","children","disabled","props","PendingIcon","useConnectModal","useMutation","useConnectors","createClient","custom","getAddress","numberToHex","SwitchChainError","ChainNotConfiguredError","createConnector","createStore","persist","cache","listener","event","smartAccountActions","toCoinbaseSmartAccount","hashMessage","hashTypedData","createBridge","toWebAuthnAccount","parameters","id","publicKey","hash","bridge","signature","webauthn","message","getAccount","client","id","publicKeys","cache","publicKey","owners","toWebAuthnAccount","toCoinbaseSmartAccount","bytesToHex","hashMessage","bytesToHex","hexToBytes","concatBytes","utf8ToBytes","getMessageHash","webauthn","authenticatorData","challengeIndexRaw","clientDataJSON","typeIndexRaw","userVerificationRequired","typeIndex","challengeIndex","authenticatorDataBytes","flag","type","clientDataJSONHash","messageHash","parseSignature","serializePublicKey","secp256r1","getCandidatePublicKeys","input","r","s","candidate1","candidate2","findPublicKey","input1","input2","firstDuplicate","getCandidatePublicKeys","arr","seen","s","createBridge","reusePasskey","chain","bridge","challenge","hashMessage","bytesToHex","credentialId","signature","metadata","publicKey","cachedPublicKey","cache","messageHash","getMessageHash","challenge2","signature2","findPublicKey","state","createBridge","createPasskey","chain","bridge","credential","cache","state","resourceToHex","parseAbi","worldConfig","defaultClientConfig","unlimitedDelegationControlId","worldTables","worldAbi","viem_createBundlerClient","knownChainFees","createBundlerClient","paymasterAddress","config","chain","viem_createBundlerClient","defaultClientConfig","observer","transactionQueue","createClient","fallback","http","webSocket","privateKeyToAccount","generatePrivateKey","wiresaw","userOpExecutor","getBundlerTransport","chain","bundlerHttpUrl","bundlerTransport","wiresaw","passkeyConnector","chainId","createConnector","config","chain","c","configTransport","transport","paymasterAddress","getPaymasterAddress","bundlerTransport","getBundlerTransport","client","createClient","defaultClientConfig","connected","cache","credentialId","createPasskey","account","getAccount","numberToHex","reusePasskey","params","accounts","id","SwitchChainError","ChainNotConfiguredError","a","getAddress","_connectInfo","_error","createBundlerClient","smartAccountActions","observer","_params","custom","usePasskeyConnector","connector","useConnectors","c","passkeyConnector","twMerge","jsx","jsxs","Logo","className","props","useQuery","usePreloadImage","url","resolve","reject","image","jsx","jsxs","AppInfo","appName","appIcon","useEntryKitConfig","hasAppIcon","appIconLoading","usePreloadImage","Logo","twMerge","jsx","jsxs","ConnectWallet","userAccount","useAccount","accountModalOpen","useAccountModal","openConnectModal","connectModalOpen","useConnectModal","passkeyConnector","usePasskeyConnector","createPasskey","useMutation","error","reusePasskey","hasPasskey","buttons","Button","AppInfo","useEffect","useMemo","useRef","useState","twMerge","parseEther","minGasBalance","useClient","queryOptions","useQuery","defineStore","parseAbi","paymasterAbi","paymasterConfig","paymasterTables","getRecord","getAllowance","client","paymasterAddress","userAddress","paymasterTables","getAllowanceQueryOptions","client","paymasterAddress","userAddress","queryKey","queryOptions","getAllowance","useAllowance","chainId","useEntryKitConfig","useClient","useQuery","useClient","queryOptions","useQuery","getRecord","getSpender","client","paymasterAddress","userAddress","sessionAddress","paymasterTables","getSpenderQueryOptions","client","paymasterAddress","userAddress","sessionAddress","queryKey","queryOptions","getSpender","useClient","queryOptions","useQuery","getRecord","getDelegation","client","worldAddress","userAddress","sessionAddress","getRecord","worldTables","unlimitedDelegationControlId","getDelegationQueryOptions","client","worldAddress","userAddress","sessionAddress","queryKey","queryOptions","getDelegation","queryOptions","useQuery","useQueryClient","useClient","useClient","queryOptions","useQuery","toCoinbaseSmartAccount","createStore","persist","store","signers","listener","event","generatePrivateKey","privateKeyToAccount","getSessionSigner","userAddress","sessionSignerPrivateKey","store","privateKey","state","getSessionAccount","client","userAddress","sessionSigner","getSessionSigner","toCoinbaseSmartAccount","getSessionAccountQueryOptions","client","userAddress","queryKey","queryOptions","getSessionAccount","useSessionAccount","chainId","useEntryKitConfig","useClient","useQuery","getPrequisitesQueryOptions","queryClient","client","userAddress","paymasterAddress","worldAddress","queryKey","queryOptions","sessionAddress","getSessionAccountQueryOptions","allowance","isSpender","hasDelegation","getAllowanceQueryOptions","getSpenderQueryOptions","getDelegationQueryOptions","hasAllowance","minGasBalance","usePrerequisites","useQueryClient","chainId","useEntryKitConfig","useClient","useQuery","useDisconnect","useQuery","useENS","address","normalizedAddress","data","res","jsx","jsxs","TruncatedHex","hex","jsx","jsxs","Wallet","isActive","isExpanded","userAddress","ens","useENS","disconnect","disconnectIsPending","useDisconnect","closeAccountModal","useAccountModal","TruncatedHex","Button","useMutation","useQueryClient","claimGasPass","useClaimGasPass","queryClient","chain","useEntryKitConfig","mutationKey","error","userAddress","twMerge","jsx","jsxs","EthIcon","className","props","formatEther","formatBalance","wei","formatted","magnitude","jsx","jsxs","Balance","wei","formatBalance","EthIcon","useEffect","jsx","jsxs","Allowance","isActive","isExpanded","userAddress","allowance","useAllowance","claimGasPass","useClaimGasPass","useEffect","timer","minGasBalance","Balance","PendingIcon","Button","encodeFunctionData","useMutation","useQueryClient","getAction","sendUserOperation","waitForUserOperationReceipt","waitForTransactionReceipt","useClient","resourceToHex","IBaseWorldAbi","viem_writeContract","getAction","toHex","signTypedData","callWithSignatureTypes","getRecord","modulesConfig","hexToResource","getAction","signCall","userClient","worldAddress","systemId","callData","initialNonce","client","nonce","systemNamespace","systemName","CallWithSignatureAbi","callWithSignature","sessionClient","opts","signature","signCall","getAction","viem_writeContract","useSetupSession","userClient","queryClient","useQueryClient","chainId","worldAddress","paymasterAddress","useEntryKitConfig","client","useClient","mutationKey","useMutation","error","sessionClient","registerSpender","registerDelegation","sessionAddress","txs","tx","callWithSignature","resourceToHex","encodeFunctionData","paymasterAbi","IBaseWorldAbi","unlimitedDelegationControlId","hash","receipt","getAction","waitForTransactionReceipt","calls","worldAbi","sendUserOperation","waitForUserOperationReceipt","useEffect","useClient","queryOptions","useQuery","smartAccountActions","callFrom","observer","getSessionClient","client","userAddress","sessionAccount","worldAddress","paymasterAddress","bundlerTransport","getBundlerTransport","createBundlerClient","smartAccountActions","callFrom","observer","getSessionClientQueryOptions","sessionAccount","client","userAddress","worldAddress","paymasterAddress","queryKey","queryOptions","getSessionClient","useSessionClient","chainId","useEntryKitConfig","useClient","useSessionAccount","useQuery","jsx","jsxs","Session","isActive","isExpanded","userClient","registerSpender","registerDelegation","sessionClient","useSessionClient","setup","useSetupSession","hasSession","useEffect","timer","Button","jsx","ConnectedSteps","userClient","initialUserAddress","userAddress","prerequisites","usePrerequisites","closeAccountModal","useAccountModal","isNewConnection","initialPrerequisites","useRef","useEffect","hasAllowance","isSpender","hasDelegation","steps","useMemo","props","Wallet","Allowance","Session","selectedStepId","useState","nextStep","step","completedSteps","activeStep","activeStepIndex","twMerge","i","isActive","isExpanded","isDisabled","useRef","jsx","AccountModalContent","chainId","useEntryKitConfig","userClient","useConnectorClient","userAddress","useAccount","initialUserAddress","ConnectWallet","ConnectedSteps","useState","ErrorBoundary","twMerge","BaseError","UserRejectedRequestError","jsx","jsxs","ErrorNotice","initialTitle","error","e","title","message","wait","twMerge","useIsMounted","jsx","jsxs","AccountModalErrorBoundary","children","isMounted","useIsMounted","retries","setRetries","useState","ErrorBoundary","error","resetErrorBoundary","twMerge","ErrorNotice","event","wait","value","PendingIcon","DialogClose","DialogTitle","twMerge","jsx","IconSVG","className","children","props","jsx","CloseIcon","props","IconSVG","jsx","jsxs","AccountModal","accountModalOpen","toggleAccountModal","useAccountModal","Modal","DialogTitle","twMerge","AccountModalErrorBoundary","AccountModalContent","Logo","DialogClose","CloseIcon","jsx","jsxs","EntryKitProvider","config","children","EntryKitConfigProvider","AccountModal","useAccount","twMerge","twMerge","Fragment","jsx","jsxs","AccountName","address","ens","useENS","avatar","usePreloadImage","Logo","TruncatedHex","useRef","jsx","jsxs","containerClassNames","twMerge","secondaryClassNames","secondaryInteractiveClassNames","AccountButton","openAccountModal","accountModalOpen","useAccountModal","status","userAddress","useAccount","initialUserAddress","prereqs","usePrerequisites","isConnected","isNewConnection","isSignedIn","buttonLabel","Shadow","AccountName","Logo","PendingIcon","useConnectorClient","useSessionClientReady","chainId","useEntryKitConfig","userClient","useConnectorClient","userAddress","prerequisites","usePrerequisites","sessionClient","useSessionClient","connectorsForWallets","getDefaultWallets","createConfig","iconUrl","passkeyWallet","opts","walletDetails","config","passkeyConnector","mapObject","wiresaw","createWagmiConfig","config","defaultWallets","getDefaultWallets","wallets","passkeyWallet","connectors","connectorsForWallets","createConfig","transport","connectorsForWallets","getDefaultWallets","getWallets","config","defaultWallets","getDefaultWallets","passkeyWallet","getConnectors","wallets","config","connectorsForWallets","getWallets"]}
1
+ {"version":3,"sources":["../../src/config/defineConfig.ts","../../src/ui/Modal.tsx","../../src/ui/Shadow.tsx","../../src/ui/FrameProvider.tsx","../../src/useTheme.ts","../../src/EntryKitConfigProvider.tsx","../../src/getPaymasterAddress.ts","../../src/useAccountModal.ts","../../src/AccountModal.tsx","../../src/AccountModalContent.tsx","../../src/ConnectWallet.tsx","../../src/ui/Button.tsx","../../src/icons/PendingIcon.tsx","../../src/usePasskeyConnector.ts","../../src/passkey/passkeyConnector.ts","../../src/passkey/cache.ts","../../src/passkey/getAccount.ts","../../src/passkey/toWebAuthnAccount.ts","../../src/passkey/reusePasskey.ts","../../src/passkey/getMessageHash.ts","../../src/passkey/getCandidatePublicKeys.ts","../../src/passkey/findPublicKey.ts","../../src/passkey/createPasskey.ts","../../src/common.ts","../../src/createBundlerClient.ts","../../src/getBundlerTransport.ts","../../src/icons/Logo.tsx","../../src/usePreloadImage.tsx","../../src/AppInfo.tsx","../../src/onboarding/ConnectedSteps.tsx","../../src/onboarding/common.ts","../../src/onboarding/useAllowance.ts","../../src/paymaster.ts","../../src/onboarding/getAllowance.ts","../../src/onboarding/useSpender.ts","../../src/onboarding/getSpender.ts","../../src/onboarding/useDelegation.ts","../../src/onboarding/getDelegation.ts","../../src/onboarding/usePrerequisites.ts","../../src/useSessionAccount.ts","../../src/getSessionAccount.ts","../../src/store.ts","../../src/getSessionSigner.ts","../../src/onboarding/Wallet.tsx","../../src/useENS.ts","../../src/ui/TruncatedHex.tsx","../../src/onboarding/useClaimGasPass.ts","../../src/icons/EthIcon.tsx","../../src/formatBalance.ts","../../src/ui/Balance.tsx","../../src/onboarding/Allowance.tsx","../../src/onboarding/useSetupSession.ts","../../src/utils/callWithSignature.ts","../../src/utils/signCall.tsx","../../src/onboarding/Session.tsx","../../src/useSessionClient.ts","../../src/getSessionClient.ts","../../src/AccountModalErrorBoundary.tsx","../../src/ErrorNotice.tsx","../../src/icons/IconSVG.tsx","../../src/icons/CloseIcon.tsx","../../src/EntryKitProvider.tsx","../../src/AccountButton.tsx","../../src/AccountName.tsx","../../src/useSessionClientReady.ts","../../src/createWagmiConfig.ts","../../src/passkey/passkeyWallet.ts","../../src/getConnectors.ts","../../src/getWallets.ts"],"sourcesContent":["import { EntryKitConfigInput } from \"./input\";\nimport { EntryKitConfig } from \"./output\";\n\nexport function defineConfig(input: EntryKitConfigInput): EntryKitConfig {\n return {\n ...input,\n appName: input.appName ?? document.title,\n appIcon: input.appIcon ?? document.querySelector(\"link[rel~='icon']\")?.getAttribute(\"href\") ?? \"/favico.ico\",\n };\n}\n","import { ReactNode } from \"react\";\nimport { Root as DialogRoot, DialogPortal, DialogContent } from \"@radix-ui/react-dialog\";\nimport { Shadow } from \"./Shadow\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = {\n open?: boolean;\n onOpenChange?: (open: boolean) => void;\n children: ReactNode;\n};\n\nexport function Modal({ open, onOpenChange, children }: Props) {\n return (\n <DialogRoot open={open} onOpenChange={onOpenChange}>\n {/* This intentionally does not use `<DialogTrigger>` because it doesn't play nicely with `<Shadow>` trigger (our primary use case). */}\n <DialogPortal>\n <Shadow mode=\"modal\">\n {/**\n * This intentionally does not use `<DialogOverlay>` due to an issue it causes with scrolling the modal contents.\n * See https://github.com/radix-ui/primitives/issues/1159#issuecomment-1105320294\n */}\n <div className={twMerge(\"fixed inset-0\", \"bg-neutral-800/85\", \"animate-in animate-duration-300 fade-in\")} />\n <div\n className={twMerge(\n \"fixed inset-0\",\n \"grid items-end sm:items-center\",\n \"animate-in animate-duration-300 fade-in slide-in-from-bottom-16\",\n )}\n >\n <div>\n <DialogContent\n className=\"outline-none w-full max-w-[26rem] mx-auto\"\n // TODO description\n aria-describedby={undefined}\n onOpenAutoFocus={(event) => {\n event.preventDefault();\n }}\n >\n {children}\n </DialogContent>\n </div>\n </div>\n </Shadow>\n </DialogPortal>\n </DialogRoot>\n );\n}\n","import { CSSProperties, HTMLProps, ReactNode, forwardRef, useEffect, useRef, useState } from \"react\";\nimport ReactDOM from \"react-dom\";\nimport css from \"tailwindcss/tailwind.css?inline\";\nimport { useResizeObserver } from \"usehooks-ts\";\nimport { mergeRefs } from \"react-merge-refs\";\nimport { FrameProvider } from \"./FrameProvider\";\nimport { useTheme } from \"../useTheme\";\n\nexport type Props = {\n mode: \"modal\" | \"child\";\n children: ReactNode;\n};\n\nfunction Resizer({\n onSize,\n ...props\n}: {\n onSize: (size: { width: number | undefined; height: number | undefined }) => void;\n} & HTMLProps<HTMLDivElement>) {\n const ref = useRef<HTMLDivElement | null>(null);\n useResizeObserver({ ref, onResize: onSize });\n return <div ref={ref} {...props} style={{ ...props.style, display: \"inline-grid\" }} />;\n}\n\n// TODO: make a container inside the iframe that is at least the size of the window, render content into that so we can correctly measure size relative to window\n// otherwise as the iframe shrinks, the measurement will be based on that shrunk value and it'll never get bigger, only smaller\n\nexport const Shadow = forwardRef<HTMLIFrameElement, Props>(function Shadow({ mode, children }, forwardedRef) {\n const frameRef = useRef<HTMLIFrameElement | null>(null);\n const [loaded, setLoaded] = useState(false);\n const frame = loaded ? frameRef.current : null;\n\n const [frameSize, setFrameSize] = useState<{ width: number | undefined; height: number | undefined }>({\n width: undefined,\n height: undefined,\n });\n\n const frameDocument = frame?.contentDocument;\n const theme = useTheme();\n useEffect(() => {\n if (frameDocument) {\n frameDocument.body.setAttribute(\"data-theme\", theme);\n }\n }, [frameDocument, theme]);\n\n const frameStyle: CSSProperties =\n mode === \"modal\"\n ? {\n all: \"unset\",\n display: \"block\",\n position: \"fixed\",\n inset: \"0\",\n width: \"100%\",\n height: \"100%\",\n zIndex: \"2147483646\",\n }\n : frameSize.width && frameSize.height\n ? {\n all: \"unset\",\n display: \"inline-grid\",\n width: `${frameSize.width}px`,\n height: `${frameSize.height}px`,\n }\n : {\n all: \"unset\",\n display: \"block\",\n position: \"fixed\",\n inset: \"0\",\n width: \"100%\",\n height: \"100%\",\n opacity: 0,\n pointerEvents: \"none\",\n };\n\n return (\n <iframe\n ref={mergeRefs([forwardedRef, frameRef])}\n style={frameStyle}\n onLoad={() => setLoaded(true)}\n srcDoc=\"<!doctype html><title>…</title>\"\n >\n {frameDocument\n ? ReactDOM.createPortal(\n <FrameProvider frame={frame}>\n {/*\n * TODO: make this the size of the outer window so that any container-based resizing in iframe\n * is done from that rather than the potentially-small size of this iframe\n */}\n <div>{mode === \"modal\" ? children : <Resizer onSize={setFrameSize}>{children}</Resizer>}</div>\n <style dangerouslySetInnerHTML={{ __html: css }} />\n </FrameProvider>,\n frameDocument.body,\n )\n : null}\n </iframe>\n );\n});\n","import { createContext, useContext, type ReactNode } from \"react\";\n\ntype ContextValue = {\n readonly frame: HTMLIFrameElement;\n};\n\n/** @internal */\nconst Context = createContext<ContextValue | null>(null);\n\nexport type Props = {\n frame: HTMLIFrameElement;\n children?: ReactNode;\n};\n\nexport function FrameProvider({ frame, children }: Props) {\n const value = useContext(Context);\n if (value) throw new Error(\"`FrameProvider` can only be used once.\");\n return <Context.Provider value={{ frame }}>{children}</Context.Provider>;\n}\n\nexport function useFrame(): ContextValue {\n const value = useContext(Context);\n if (!value) throw new Error(\"`useFrame` can only be used within a `FrameProvider`.\");\n return value;\n}\n","import { useMediaQuery } from \"usehooks-ts\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\n\nexport function useTheme() {\n const { theme: initialTheme } = useEntryKitConfig();\n const darkMode = useMediaQuery(\"(prefers-color-scheme: dark)\");\n const theme = initialTheme ?? (darkMode ? \"dark\" : \"light\");\n return theme;\n}\n","import \"@rainbow-me/rainbowkit/styles.css\";\nimport { createContext, useContext, type ReactNode } from \"react\";\nimport { RainbowKitProvider, lightTheme, midnightTheme } from \"@rainbow-me/rainbowkit\";\nimport { EntryKitConfig } from \"./config/output\";\nimport { Address, Chain } from \"viem\";\nimport { useChains } from \"wagmi\";\nimport { getPaymasterAddress } from \"./getPaymasterAddress\";\n\ntype ContextValue = EntryKitConfig & {\n chain: Chain;\n paymasterAddress: Address;\n};\n\n/** @internal */\nconst Context = createContext<ContextValue | null>(null);\n\nexport type Props = {\n config: EntryKitConfig;\n children?: ReactNode;\n};\n\nexport function EntryKitConfigProvider({ config, children }: Props) {\n const currentConfig = useContext(Context);\n if (currentConfig) throw new Error(\"`EntryKitProvider` can only be used once.\");\n\n // TODO: move chain-based lookups to function so we can reuse here and in passkeyConnector\n\n const chains = useChains();\n const chain = chains.find(({ id }) => id === config.chainId);\n if (!chain) throw new Error(`Could not find configured chain for chain ID ${config.chainId}.`);\n\n const paymasterAddress = getPaymasterAddress(chain);\n\n return (\n <RainbowKitProvider\n // Prevent RainbowKit/Wagmi trying to switch chains after connection\n // https://github.com/rainbow-me/rainbowkit/blob/d76bb28a67609d9855b8045e5f5f4641dff1e032/packages/rainbowkit/src/wallets/useWalletConnectors.ts#L58-L67\n // https://github.com/wevm/wagmi/blob/cb58b1ea3ad40e77210f24eb598f9d2306db998c/packages/core/src/connectors/injected.ts#L176-L184\n initialChain={0}\n appInfo={{\n appName: config.appName,\n // TODO: learn more and disclaimer\n }}\n theme={\n config.theme === \"light\"\n ? lightTheme({ borderRadius: \"none\" })\n : config.theme === \"dark\"\n ? midnightTheme({ borderRadius: \"none\" })\n : {\n lightMode: lightTheme({ borderRadius: \"none\" }),\n darkMode: midnightTheme({ borderRadius: \"none\" }),\n }\n }\n >\n <Context.Provider value={{ ...config, chain, paymasterAddress }}>{children}</Context.Provider>\n </RainbowKitProvider>\n );\n}\n\nexport function useEntryKitConfig(): ContextValue {\n const config = useContext(Context);\n if (!config) throw new Error(\"`useEntryKitConfig` can only be used within a `EntryKitProvider`.\");\n return config;\n}\n","import { Chain, getChainContractAddress } from \"viem\";\n\nexport function getPaymasterAddress(chain: Chain) {\n return getChainContractAddress({ chain, contract: \"quarryPaymaster\" });\n}\n","import { useCallback, useMemo } from \"react\";\nimport { useStore } from \"zustand\";\nimport { createStore } from \"zustand/vanilla\";\n\nconst store = createStore(() => ({ open: false }));\n\nexport type UseAccountModalResult = {\n readonly accountModalOpen: boolean;\n readonly openAccountModal: () => void;\n readonly closeAccountModal: () => void;\n readonly toggleAccountModal: (open: boolean) => void;\n};\n\nexport function useAccountModal(): UseAccountModalResult {\n const accountModalOpen = useStore(store, (state) => state.open);\n\n const openAccountModal = useCallback(() => {\n store.setState({ open: true });\n }, []);\n\n const closeAccountModal = useCallback(() => {\n store.setState({ open: false });\n }, []);\n\n const toggleAccountModal = useCallback((open: boolean) => {\n store.setState({ open: open });\n }, []);\n\n return useMemo(\n () => ({\n accountModalOpen,\n openAccountModal,\n closeAccountModal,\n toggleAccountModal,\n }),\n [accountModalOpen, openAccountModal, closeAccountModal, toggleAccountModal],\n );\n}\n","import { Modal } from \"./ui/Modal\";\nimport { useAccountModal } from \"./useAccountModal\";\nimport { twMerge } from \"tailwind-merge\";\nimport { AccountModalContent } from \"./AccountModalContent\";\nimport { AccountModalErrorBoundary } from \"./AccountModalErrorBoundary\";\nimport { DialogClose, DialogTitle } from \"@radix-ui/react-dialog\";\nimport { CloseIcon } from \"./icons/CloseIcon\";\nimport { Logo } from \"./icons/Logo\";\n\nexport function AccountModal() {\n const { accountModalOpen, toggleAccountModal } = useAccountModal();\n return (\n <Modal open={accountModalOpen} onOpenChange={toggleAccountModal}>\n {/* TODO: move this into `<Modal>` props? */}\n <DialogTitle className=\"sr-only\">Connect with EntryKit</DialogTitle>\n {accountModalOpen ? (\n <div\n className={twMerge(\n \"relative py-2 ring-1\",\n \"bg-neutral-900 text-neutral-400 ring-neutral-700/50 divide-neutral-700\",\n \"links:font-medium links:underline links:underline-offset-4\",\n \"links:text-white\",\n \"links:decoration-neutral-500 hover:links:decoration-orange-500\",\n )}\n >\n <AccountModalErrorBoundary>\n <AccountModalContent />\n </AccountModalErrorBoundary>\n\n <a\n href=\"https://mud.dev\"\n target=\"_blank\"\n rel=\"noreferrer noopener\"\n className=\"group self-center p-3 flex items-center justify-center gap-2 links-unset text-sm font-mono transition text-neutral-400 hover:text-white\"\n >\n <span className=\"block w-4 h-4\">\n <Logo className=\"w-full h-full text-orange-500 group-hover:rotate-90 transition duration-300\" />\n </span>\n <span>Powered by MUD</span>\n </a>\n\n <div className=\"absolute top-0 right-0\">\n <DialogClose\n className={twMerge(\n \"pointer-events-auto leading-none p-2 transition\",\n \"text-neutral-700 hover:text-neutral-500\",\n )}\n title=\"Close\"\n >\n <CloseIcon className=\"m-0\" />\n </DialogClose>\n </div>\n </div>\n ) : null}\n </Modal>\n );\n}\n","import { useAccount, useConnectorClient } from \"wagmi\";\nimport { ConnectWallet } from \"./ConnectWallet\";\nimport { ConnectedSteps } from \"./onboarding/ConnectedSteps\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useRef } from \"react\";\n\nexport function AccountModalContent() {\n const { chainId } = useEntryKitConfig();\n const userClient = useConnectorClient({ chainId });\n const { address: userAddress } = useAccount();\n const initialUserAddress = useRef(userAddress);\n\n if (userClient.status !== \"success\") {\n return <ConnectWallet />;\n }\n\n return <ConnectedSteps userClient={userClient.data} initialUserAddress={initialUserAddress.current} />;\n}\n","import { useAccount } from \"wagmi\";\nimport { Button } from \"./ui/Button\";\nimport { useAccountModal } from \"./useAccountModal\";\nimport { useConnectModal } from \"@rainbow-me/rainbowkit\";\nimport { useMutation } from \"@tanstack/react-query\";\nimport { usePasskeyConnector } from \"./usePasskeyConnector\";\nimport { AppInfo } from \"./AppInfo\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport function ConnectWallet() {\n const userAccount = useAccount();\n const { accountModalOpen } = useAccountModal();\n const { openConnectModal, connectModalOpen } = useConnectModal();\n\n // TODO: show error states\n // TODO: fix passkey issue where pending state disappears but we don't transition right away\n\n const passkeyConnector = usePasskeyConnector();\n const createPasskey = useMutation({\n onError: (error) => console.error(error),\n mutationKey: [\"createPasskey\", passkeyConnector.id, accountModalOpen, connectModalOpen, userAccount.status],\n mutationFn: () => passkeyConnector.createPasskey(),\n });\n const reusePasskey = useMutation({\n onError: (error) => console.error(error),\n mutationKey: [\"reusePasskey\", passkeyConnector.id, accountModalOpen, connectModalOpen, userAccount.status],\n mutationFn: () => passkeyConnector.reusePasskey(),\n });\n\n const hasPasskey = passkeyConnector.hasPasskey();\n\n const buttons = [\n <Button\n key=\"create\"\n variant={hasPasskey ? \"tertiary\" : \"secondary\"}\n className=\"self-auto flex justify-center\"\n pending={createPasskey.status === \"pending\" || createPasskey.status === \"success\"}\n onClick={() => createPasskey.mutate()}\n autoFocus={!hasPasskey}\n >\n Create account\n </Button>,\n <Button\n key=\"signin\"\n variant={hasPasskey ? \"secondary\" : \"tertiary\"}\n className=\"self-auto flex justify-center\"\n pending={reusePasskey.status === \"pending\" || reusePasskey.status === \"success\"}\n onClick={() => reusePasskey.mutate()}\n autoFocus={hasPasskey}\n >\n Sign in\n </Button>,\n ];\n\n if (hasPasskey) {\n buttons.reverse();\n }\n\n return (\n <div\n className={twMerge(\"flex flex-col gap-6 p-6\", \"animate-in animate-duration-300 fade-in slide-in-from-bottom-8\")}\n >\n <div className=\"p-4\">\n {/* TODO: render appImage if available? */}\n <AppInfo />\n </div>\n <div className=\"self-center flex flex-col gap-2 w-60\">\n {buttons}\n <button\n className=\"text-sm self-center transition text-neutral-500 hover:text-white p-2\"\n disabled={userAccount.status === \"connecting\"}\n // TODO: figure out how to prevent this from switching chains after connecting\n onClick={openConnectModal}\n >\n Already have a wallet?\n </button>\n </div>\n </div>\n );\n}\n","/* eslint-disable max-len */\nimport { ButtonHTMLAttributes, DetailedHTMLProps } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\nimport { PendingIcon } from \"../icons/PendingIcon\";\n\n// TODO: add support for async onClick, where pending is enabled automatically\n// TODO: add error state with popover/tooltip\n\ntype ButtonClassNameOptions = {\n variant?: \"primary\" | \"secondary\" | \"tertiary\";\n pending?: boolean;\n};\n\nconst buttonClassName = ({ variant = \"secondary\" }: ButtonClassNameOptions = {}) =>\n twMerge(\n \"group/button self-center leading-none outline-none border-4 border-transparent\",\n \"transition hover:brightness-125 active:brightness-150\",\n \"focus:border-orange-500\",\n \"aria-disabled:pointer-events-none aria-busy:pointer-events-none\",\n // TODO: better disabled state\n \"aria-disabled:opacity-50\",\n \"p-[.75em] font-medium\",\n {\n primary: twMerge(\"bg-orange-600 text-white focus:border-yellow-400\"),\n secondary: twMerge(\"bg-neutral-700 text-white focus:border-orange-500\"),\n tertiary: twMerge(\"bg-neutral-800 text-white focus:border-orange-500\"),\n }[variant],\n );\n\nexport type ButtonProps = {\n pending?: boolean;\n variant?: ButtonClassNameOptions[\"variant\"];\n};\n\nexport type Props = ButtonProps & DetailedHTMLProps<ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>;\n\nexport const Button = ({ pending, variant, type, className, children, disabled, ...props }: Props) => {\n return (\n <button\n type={type || \"button\"}\n className={twMerge(buttonClassName({ variant, pending }), className)}\n aria-busy={pending}\n aria-disabled={disabled}\n disabled={disabled || pending}\n {...props}\n >\n <span className=\"grid grid-cols-[1fr_auto_1fr] gap-2\">\n <span className=\"flex items-center justify-end text-[.75em]\">\n <span className=\"transition opacity-0 translate-x-2 group-aria-busy/button:opacity-100 group-aria-busy/button:translate-x-0 duration-100 group-aria-busy/button:duration-300\">\n <PendingIcon />\n </span>\n </span>\n <span>{children}</span>\n </span>\n </button>\n );\n};\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function PendingIcon({ className, ...props }: Props) {\n return (\n <svg\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em] animate-spin\", className)}\n xmlns=\"http://www.w3.org/2000/svg\"\n fill=\"none\"\n viewBox=\"0 0 24 24\"\n {...props}\n >\n <circle className=\"opacity-25\" cx=\"12\" cy=\"12\" r=\"10\" stroke=\"currentColor\" strokeWidth=\"4\" />\n <path\n className=\"opacity-75\"\n fill=\"currentColor\"\n d=\"M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z\"\n />\n </svg>\n );\n}\n","import { useConnectors } from \"wagmi\";\nimport { PasskeyConnector, passkeyConnector } from \"./passkey/passkeyConnector\";\n\nexport function usePasskeyConnector(): PasskeyConnector {\n const connectors = useConnectors();\n const connector = connectors.find((c) => c.type === passkeyConnector.type);\n if (!connector) {\n // TODO: provide link to instructions\n throw new Error(\n \"Could not find passkey connector. Did you configure Wagmi with the EntryKit passkey connector or passkey wallet?\",\n );\n }\n return connector as never;\n}\n","import {\n createClient,\n custom,\n EIP1193RequestFn,\n EIP1474Methods,\n getAddress,\n numberToHex,\n SwitchChainError,\n Client,\n ProviderConnectInfo,\n} from \"viem\";\nimport { ChainNotConfiguredError, createConnector, CreateConnectorFn } from \"wagmi\";\nimport { cache } from \"./cache\";\nimport { smartAccountActions } from \"permissionless/clients\";\nimport { getAccount } from \"./getAccount\";\nimport { reusePasskey } from \"./reusePasskey\";\nimport { createPasskey } from \"./createPasskey\";\nimport { defaultClientConfig } from \"../common\";\nimport { createBundlerClient } from \"../createBundlerClient\";\nimport { observer } from \"@latticexyz/explorer/observer\";\nimport { getPaymasterAddress } from \"../getPaymasterAddress\";\nimport { getBundlerTransport } from \"../getBundlerTransport\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\n\nexport type PasskeyConnectorOptions = {\n // TODO: figure out what we wanna do across chains\n chainId: number;\n};\n\nexport type PasskeyProvider = {\n request: EIP1193RequestFn<EIP1474Methods>;\n};\n\nexport type PasskeyConnectorProperties = {\n createPasskey(): Promise<void>;\n reusePasskey(): Promise<void>;\n // TODO: does wagmi storage require this to be async?\n hasPasskey(): boolean;\n getClient(parameters?: { chainId?: number | undefined } | undefined): Promise<Client>;\n onConnect(connectInfo: ProviderConnectInfo): void;\n};\n\nexport type CreatePasskeyConnector = CreateConnectorFn<PasskeyProvider, PasskeyConnectorProperties, {}>;\nexport type PasskeyConnector = ReturnType<CreatePasskeyConnector>;\n\npasskeyConnector.type = \"passkey\" as const;\n\nexport function passkeyConnector({ chainId }: PasskeyConnectorOptions): CreatePasskeyConnector {\n return createConnector((config) => {\n // TODO: figure out how to use with config's `client` option?\n if (!config.transports) {\n throw new Error(`Wagmi must be configured with transports to use the passkey connector.`);\n }\n\n const chain = config.chains.find((c) => c.id === chainId);\n if (!chain) throw new Error(`Could not find configured chain for chain ID ${chainId}.`);\n\n // TODO: wrap transports in wiresaw\n // TODO: adapt wiresaw transport to check chain config and conditionally make its own transport from wiresaw chain config and swap out methods\n\n const configTransport = config.transports[chain.id];\n if (!configTransport) {\n throw new Error(`Could not find configured transport for chain ID ${chainId}.`);\n }\n const transport = wiresaw(configTransport);\n\n const paymasterAddress = getPaymasterAddress(chain);\n const bundlerTransport = getBundlerTransport(chain);\n\n const client = createClient({ ...defaultClientConfig, chain, transport });\n\n let connected = cache.getState().activeCredential != null;\n\n return {\n id: \"passkey\",\n type: passkeyConnector.type,\n name: \"Passkey\",\n // TODO: check that this works\n // supportsSimulation: true,\n\n async createPasskey() {\n const { credentialId } = await createPasskey(chain);\n const account = await getAccount(client, credentialId);\n this.onAccountsChanged([account.address]);\n this.onConnect?.({ chainId: numberToHex(chainId) });\n },\n async reusePasskey() {\n const { credentialId } = await reusePasskey(chain);\n const account = await getAccount(client, credentialId);\n this.onAccountsChanged([account.address]);\n this.onConnect?.({ chainId: numberToHex(chainId) });\n },\n hasPasskey() {\n return Object.keys(cache.getState().publicKeys).length > 0;\n },\n\n async connect(params) {\n console.log(\"connect\");\n // TODO: allow any chain?\n if (params?.chainId != null && params.chainId !== chainId) {\n throw new Error(`Can't connect to chain ${params.chainId}. Passkey connector is bound to chain ${chainId}.`);\n }\n\n // attempt to reuse credential if this is called directly\n // TODO: move this into wallet so it's only triggered via rainbowkit?\n if (!cache.getState().activeCredential && !params?.isReconnecting) {\n await reusePasskey(chain);\n }\n\n const accounts = await this.getAccounts();\n connected = accounts.length > 0;\n\n return { accounts, chainId };\n },\n async disconnect() {\n console.log(\"disconnect\");\n connected = false;\n cache.setState({ activeCredential: null });\n },\n async getAccounts() {\n console.log(\"getAccounts\");\n const id = cache.getState().activeCredential;\n if (!id) return [];\n\n try {\n console.log(\"getting account for credential\", id);\n const account = await getAccount(client, id);\n console.log(\"got account\", account);\n return [account.address];\n } catch (error) {\n console.log(\"could not get address for credential ID\", id);\n }\n\n return [];\n },\n async getChainId() {\n return chainId;\n },\n async isAuthorized() {\n console.log(\"isAuthorized\");\n if (!connected) return false;\n const accounts = await this.getAccounts();\n return accounts.length > 0;\n },\n async switchChain(params) {\n // TODO: allow any chain?\n if (params.chainId !== chainId) {\n throw new Error(`Can't connect to chain ${params.chainId}. Passkey connector is bound to chain ${chainId}.`);\n }\n\n const chain = config.chains.find((c) => c.id === params.chainId);\n if (!chain) throw new SwitchChainError(new ChainNotConfiguredError());\n return chain;\n },\n onAccountsChanged(accounts) {\n console.log(\"onAccountsChanged\");\n if (accounts.length > 0) {\n config.emitter.emit(\"change\", {\n accounts: accounts.map((a) => getAddress(a)),\n });\n } else {\n this.onDisconnect();\n }\n },\n onChainChanged(chainId) {\n console.log(\"onChainChanged\");\n config.emitter.emit(\"change\", { chainId: Number(chainId) });\n },\n async onConnect(_connectInfo) {\n console.log(\"onConnect\");\n const accounts = await this.getAccounts();\n config.emitter.emit(\"connect\", { accounts, chainId });\n },\n async onDisconnect(_error) {\n console.log(\"onDisconnect\");\n config.emitter.emit(\"disconnect\");\n connected = false;\n },\n\n // By default, connector clients are bound to a `json-rpc` account.\n // We provide our own `getClient` method here so that we can return\n // a `smart` account, which is necessary for using with Viem's\n // account abstraction actions (i.e. user ops).\n //\n // Although Wagmi recommends connectors be tree-shakable, we return\n // an extended client here so that this client works with native\n // Wagmi hooks. Otherwise the app needs to build its own client, then\n // wrap each call in its own react-query hooks.\n async getClient(params) {\n console.log(\"passkeyConnector.getClient\", params);\n\n const credentialId = cache.getState().activeCredential;\n if (!credentialId) throw new Error(\"Not connected.\");\n\n const account = await getAccount(client, credentialId);\n\n return createBundlerClient({\n paymasterAddress,\n transport: bundlerTransport,\n client,\n account,\n })\n .extend(smartAccountActions())\n .extend(observer());\n },\n\n async getProvider(_params) {\n // TODO: chain specific provider?\n // TODO: is turning off retryCount important? is wrapping in this way enough to turn off retries?\n return custom({ request: client.transport.request })({ retryCount: 0 });\n },\n };\n });\n}\n","import { createStore } from \"zustand/vanilla\";\nimport { persist } from \"zustand/middleware\";\nimport { P256Credential } from \"viem/account-abstraction\";\n\n// TODO: move this to wagmi storage?\n// when I tried, it blew up TS complexity and my IDE was impossible to work with\n\nexport type State = {\n readonly publicKeys: {\n readonly [key in P256Credential[\"id\"]]?: P256Credential[\"publicKey\"];\n };\n readonly activeCredential: P256Credential[\"id\"] | null;\n};\n\nexport const cache = createStore(\n persist<State>(\n () => ({\n publicKeys: {},\n activeCredential: null,\n }),\n { name: \"mud:id:cache\" },\n ),\n);\n\n// keep cache in sync across tabs/windows via storage event\nfunction listener(event: StorageEvent) {\n if (event.key === cache.persist.getOptions().name) {\n cache.persist.rehydrate();\n }\n}\nwindow.addEventListener(\"storage\", listener);\n","import { Chain, Client, Transport } from \"viem\";\nimport { cache } from \"./cache\";\nimport { P256Credential } from \"webauthn-p256\";\nimport { toCoinbaseSmartAccount, ToCoinbaseSmartAccountReturnType } from \"@latticexyz/common/accounts\";\nimport { toWebAuthnAccount } from \"./toWebAuthnAccount\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function getAccount(\n client: Client<Transport, Chain>,\n id: P256Credential[\"id\"],\n): Promise<ToCoinbaseSmartAccountReturnType> {\n const { publicKeys } = cache.getState();\n\n const publicKey = publicKeys[id];\n // TODO: should we prompt to recover key here?\n if (!publicKey) {\n throw new Error(\"No public key found for passkey credential.\");\n }\n\n const passkey = toWebAuthnAccount({ credential: { id, publicKey }, bridgeUrl: (client.chain as MUDChain).mudIdUrl });\n const owners = [passkey];\n\n return await toCoinbaseSmartAccount({ client, owners });\n}\n","import { ErrorType } from \"@ark/util\";\nimport { hashMessage, hashTypedData } from \"viem\";\nimport { WebAuthnAccount } from \"viem/account-abstraction\";\nimport { type P256Credential } from \"webauthn-p256\";\nimport { createBridge } from \"@latticexyz/id/internal\";\n\nexport type ToWebAuthnAccountParameters = {\n /**\n * The WebAuthn P256 credential to use.\n */\n credential: {\n id: P256Credential[\"id\"];\n publicKey: P256Credential[\"publicKey\"];\n };\n bridgeUrl?: string;\n};\n\nexport type ToWebAuthnAccountReturnType = WebAuthnAccount;\n\nexport type ToWebAuthnAccountErrorType = ErrorType;\n\n/**\n * @description Creates an Account from a WebAuthn Credential.\n *\n * @returns A WebAuthn Account.\n */\nexport function toWebAuthnAccount(parameters: ToWebAuthnAccountParameters): WebAuthnAccount {\n const { id, publicKey } = parameters.credential;\n return {\n publicKey,\n async sign({ hash }) {\n const bridge = await createBridge({ message: \"Requesting signature…\", url: parameters.bridgeUrl });\n try {\n const { signature, metadata: webauthn } = await bridge.request(\"sign\", { credentialId: id, challenge: hash });\n return {\n signature,\n webauthn,\n raw: { id } as never,\n };\n } finally {\n bridge.close();\n }\n },\n async signMessage({ message }) {\n return this.sign({ hash: hashMessage(message) });\n },\n async signTypedData(parameters) {\n return this.sign({ hash: hashTypedData(parameters) });\n },\n type: \"webAuthn\",\n };\n}\n","import { bytesToHex, hashMessage } from \"viem\";\nimport { cache } from \"./cache\";\nimport { getMessageHash } from \"./getMessageHash\";\nimport { findPublicKey } from \"./findPublicKey\";\nimport { PasskeyCredential, createBridge } from \"@latticexyz/id/internal\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function reusePasskey(chain: MUDChain): Promise<PasskeyCredential> {\n const bridge = await createBridge({ url: chain.mudIdUrl, message: \"Signing in…\" });\n try {\n const challenge = hashMessage(bytesToHex(crypto.getRandomValues(new Uint8Array(256))));\n const { credentialId, signature, metadata } = await bridge.request(\"sign\", { challenge });\n\n const publicKey = await (async () => {\n const cachedPublicKey = cache.getState().publicKeys[credentialId];\n if (cachedPublicKey) return cachedPublicKey;\n\n // TODO: look up account/public key by credential ID once we store it onchain\n\n const messageHash = await getMessageHash(metadata);\n const challenge2 = hashMessage(signature);\n const signature2 = await bridge.request(\"sign\", { credentialId, challenge: challenge2 });\n if (signature2.credentialId !== credentialId) {\n throw new Error(\"wrong credential\");\n }\n\n const publicKey = findPublicKey([\n { messageHash, signatureHex: signature },\n { messageHash: await getMessageHash(signature2.metadata), signatureHex: signature2.signature },\n ]);\n if (!publicKey) {\n throw new Error(\"recovery failed\");\n }\n\n cache.setState((state) => ({\n publicKeys: {\n ...state.publicKeys,\n [credentialId]: publicKey,\n },\n }));\n\n return publicKey;\n })();\n\n console.log(\"recovered passkey\", credentialId, publicKey);\n\n cache.setState(() => ({\n activeCredential: credentialId,\n }));\n\n return { credentialId, publicKey };\n } finally {\n bridge.close();\n }\n}\n","import { bytesToHex, Hex, hexToBytes, WebAuthnData } from \"webauthn-p256\";\nimport { concatBytes, utf8ToBytes } from \"@noble/curves/abstract/utils\";\n\n// lifted out of https://github.com/wevm/webauthn-p256/blob/main/src/verify.ts\n// TODO: submit a PR to lift this out as a function that can be exported\n\nexport async function getMessageHash(\n webauthn: Omit<WebAuthnData, \"typeIndex\" | \"challengeIndex\"> & {\n challengeIndex?: number;\n typeIndex?: number;\n },\n): Promise<Hex | never> {\n const {\n authenticatorData,\n challengeIndex: challengeIndexRaw,\n clientDataJSON,\n typeIndex: typeIndexRaw,\n userVerificationRequired,\n } = webauthn;\n\n const typeIndex = typeIndexRaw || clientDataJSON.indexOf('\"type\"');\n const challengeIndex = challengeIndexRaw || clientDataJSON.indexOf('\"challenge\"');\n\n const authenticatorDataBytes = hexToBytes(authenticatorData);\n\n // Check length of `authenticatorData`.\n if (authenticatorDataBytes.length < 37) throw new Error(\"Invalid authenticatorData\");\n\n const flag = authenticatorDataBytes[32]!;\n\n // Verify that the UP bit of the flags in authData is set.\n if ((flag & 0x01) !== 0x01) throw new Error(\"Invalid authenticatorData\");\n\n // If user verification was determined to be required, verify that\n // the UV bit of the flags in authData is set. Otherwise, ignore the\n // value of the UV flag.\n if (userVerificationRequired && (flag & 0x04) !== 0x04) throw new Error(\"Invalid authenticatorData\");\n\n // If the BE bit of the flags in authData is not set, verify that\n // the BS bit is not set.\n if ((flag & 0x08) !== 0x08 && (flag & 0x10) === 0x10) throw new Error(\"Invalid authenticatorData\");\n\n // Check that response is for an authentication assertion\n const type = '\"type\":\"webauthn.get\"';\n if (type !== clientDataJSON.slice(Number(typeIndex), type.length + 1)) throw new Error(\"Invalid clientDataJSON\");\n\n // Check that hash is in the clientDataJSON.\n const match = clientDataJSON.slice(Number(challengeIndex)).match(/^\"challenge\":\"(.*?)\"/);\n if (!match) throw new Error(\"Invalid clientDataJSON\");\n\n // TODO: switch to ox, then maybe don't need async/await here\n const clientDataJSONHash = new Uint8Array(await crypto.subtle.digest(\"SHA-256\", utf8ToBytes(clientDataJSON)));\n const messageHash = new Uint8Array(\n await crypto.subtle.digest(\"SHA-256\", concatBytes(hexToBytes(authenticatorData), clientDataJSONHash)),\n );\n\n return bytesToHex(messageHash);\n}\n","import { parseSignature, serializePublicKey } from \"webauthn-p256\";\nimport { SignatureAndMessage } from \"./common\";\nimport { secp256r1 } from \"@noble/curves/p256\";\n\nexport function getCandidatePublicKeys(input: SignatureAndMessage) {\n const { r, s } = parseSignature(input.signatureHex);\n\n const candidate1 = new secp256r1.Signature(r, s).addRecoveryBit(1).recoverPublicKey(input.messageHash.slice(2));\n const candidate2 = new secp256r1.Signature(r, s).addRecoveryBit(0).recoverPublicKey(input.messageHash.slice(2));\n\n return [serializePublicKey(candidate1), serializePublicKey(candidate2)];\n}\n","import { getCandidatePublicKeys } from \"./getCandidatePublicKeys\";\nimport { SignatureAndMessage } from \"./common\";\nimport { Hex } from \"viem\";\n\nexport function findPublicKey([input1, input2]: [SignatureAndMessage, SignatureAndMessage]): Hex | undefined {\n // Return the candidate public key that appears twice\n return firstDuplicate([...getCandidatePublicKeys(input1), ...getCandidatePublicKeys(input2)]);\n}\n\nfunction firstDuplicate<T>(arr: T[]): T | undefined {\n const seen = new Set<T>();\n for (const s of arr) {\n if (seen.has(s)) {\n return s;\n }\n seen.add(s);\n }\n return undefined;\n}\n","import { cache } from \"./cache\";\nimport { createBridge, PasskeyCredential } from \"@latticexyz/id/internal\";\nimport { MUDChain } from \"@latticexyz/common/chains\";\n\nexport async function createPasskey(chain: MUDChain): Promise<PasskeyCredential> {\n const bridge = await createBridge({ url: chain.mudIdUrl, message: \"Creating account…\" });\n try {\n const credential = await bridge.request(\"create\");\n console.log(\"created passkey\", credential);\n\n cache.setState((state) => ({\n activeCredential: credential.credentialId,\n publicKeys: {\n ...state.publicKeys,\n [credential.credentialId]: credential.publicKey,\n },\n }));\n\n return credential;\n } finally {\n bridge.close();\n }\n}\n","import { resourceToHex } from \"@latticexyz/common\";\nimport { Client, Chain, Transport, Account, parseAbi, ClientConfig, Address } from \"viem\";\nimport worldConfig from \"@latticexyz/world/mud.config\";\n\nexport type ConnectedClient<chain extends Chain = Chain> = Client<Transport, chain, Account>;\nexport type SessionClient<chain extends Chain = Chain> = ConnectedClient<chain> & { readonly userAddress: Address };\n\nexport const defaultClientConfig = {\n pollingInterval: 250,\n} as const satisfies Pick<ClientConfig, \"pollingInterval\">;\n\nexport const unlimitedDelegationControlId = resourceToHex({ type: \"system\", namespace: \"\", name: \"unlimited\" });\n\nexport const worldTables = worldConfig.namespaces.world.tables;\n\nexport const worldAbi = parseAbi([\n \"function registerDelegation(address delegatee, bytes32 delegationControlId, bytes initCallData)\",\n]);\n","import { Transport, Chain, Client, RpcSchema, Address } from \"viem\";\nimport {\n BundlerClient,\n BundlerClientConfig,\n SmartAccount,\n createBundlerClient as viem_createBundlerClient,\n} from \"viem/account-abstraction\";\nimport { defaultClientConfig } from \"./common\";\n\nconst knownChainFees = new Set([\n // anvil hardcodes fee returned by `eth_maxPriorityFeePerGas`\n // so we have to override it here\n // https://github.com/foundry-rs/foundry/pull/8081#issuecomment-2402002485\n 31337,\n // rhodolite\n 17420,\n // garnet\n 17069,\n // redstone\n 690,\n]);\n\nexport function createBundlerClient<\n transport extends Transport,\n chain extends Chain | undefined = undefined,\n account extends SmartAccount | undefined = undefined,\n client extends Client | undefined = undefined,\n rpcSchema extends RpcSchema | undefined = undefined,\n>({\n paymasterAddress,\n ...config\n}: BundlerClientConfig<transport, chain, account, client, rpcSchema> & { paymasterAddress: Address }): BundlerClient<\n transport,\n chain,\n account,\n client,\n rpcSchema\n> {\n const chain = config.chain ?? config.client?.chain;\n return viem_createBundlerClient({\n ...defaultClientConfig,\n paymaster: {\n getPaymasterData: async () => ({\n paymaster: paymasterAddress,\n paymasterData: \"0x\",\n }),\n },\n // TODO: figure out why viem isn't falling back to `chain.fees.estimateFeesPerGas` when this isn't set\n userOperation: {\n estimateFeesPerGas:\n // TODO: move this to gas estimator transport?\n chain && knownChainFees.has(chain.id)\n ? async () => ({\n maxFeePerGas: 100_000n,\n maxPriorityFeePerGas: 0n,\n })\n : undefined,\n },\n ...config,\n });\n}\n","import { transactionQueue } from \"@latticexyz/common/actions\";\nimport { Chain, createClient, fallback, http, webSocket } from \"viem\";\nimport { privateKeyToAccount, generatePrivateKey } from \"viem/accounts\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\nimport { gasEstimator, userOpExecutor } from \"@latticexyz/paymaster/internal\";\n\nexport function getBundlerTransport(chain: Chain) {\n const bundlerHttpUrl = chain.rpcUrls.bundler?.http[0];\n // TODO: bundler websocket\n const bundlerTransport = bundlerHttpUrl\n ? gasEstimator(wiresaw(http(bundlerHttpUrl)))\n : chain.id === 31337\n ? userOpExecutor({\n executor: createClient({\n chain,\n transport: fallback([webSocket(), http()]),\n account: privateKeyToAccount(generatePrivateKey()),\n }).extend(transactionQueue()),\n })\n : null;\n if (!bundlerTransport) {\n throw new Error(`Chain ${chain.id} config did not include a bundler RPC URL.`);\n }\n return bundlerTransport;\n}\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function Logo({ className, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 8 8\"\n fill=\"currentColor\"\n shapeRendering=\"crispEdges\"\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em]\", className)}\n {...props}\n >\n {/* eslint-disable-next-line max-len */}\n <path d=\"M0 0h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm0 1h1v1H0zm1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm2-1h1v1H7zm0 1h1v1H7zM6 7h1v1H6zm1-2h1v1H7zm0-1h1v1H7zm0-1h1v1H7z\" />\n <path\n d=\"M2 2h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm0 1h1v1H2zm1-3h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm0 1h1v1H5zm0 1h1v1H5zm0 1h1v1H5zM4 5h1v1H4zM3 5h1v1H3z\"\n opacity=\".5\"\n />\n <path d=\"M7 2h1v1H7zm0-1h1v1H7zM1 0h1v1H1zm1 0h1v1H2zm1 0h1v1H3zm1 0h1v1H4zm1 0h1v1H5zm1 0h1v1H6zm1 0h1v1H7z\" />\n </svg>\n );\n}\n","import { useQuery } from \"@tanstack/react-query\";\n\nexport function usePreloadImage(url: string | undefined) {\n return useQuery({\n enabled: !!url,\n retry: false,\n retryOnMount: false,\n refetchOnMount: false,\n refetchOnWindowFocus: false,\n queryKey: [\"preloadImage\", url],\n queryFn: () =>\n new Promise<InstanceType<typeof Image>>((resolve, reject) => {\n if (!url) throw new Error(\"usePreloadImage: Must provide `url` to preload image.\");\n const image = new Image();\n image.onload = () => resolve(image);\n image.onerror = () => reject(new Error(`usePreloadImage: Could not load image.\\n\\n\\tURL: ${url}`));\n image.src = url;\n }),\n });\n}\n","import { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { Logo } from \"./icons/Logo\";\nimport { usePreloadImage } from \"./usePreloadImage\";\n\nexport function AppInfo() {\n const { appName, appIcon } = useEntryKitConfig();\n const { data: hasAppIcon, isLoading: appIconLoading } = usePreloadImage(appIcon);\n\n return (\n <div className=\"flex-grow flex flex-col items-center justify-center gap-2\">\n <div className=\"w-16 h-16 m-2\">\n {!appIconLoading ? (\n hasAppIcon ? (\n <img src={appIcon} className=\"w-full h-full object-cover\" />\n ) : (\n // TODO: swap with favicon\n <Logo className=\"w-full h-full text-orange-500 dark:bg-neutral-800\" />\n )\n ) : null}\n </div>\n <div className=\"text-2xl text-white text-center\">{appName}</div>\n </div>\n );\n}\n","import { useEffect, useMemo, useRef, useState } from \"react\";\nimport { ConnectedClient } from \"../common\";\nimport { twMerge } from \"tailwind-merge\";\nimport { usePrerequisites } from \"./usePrerequisites\";\nimport { Wallet } from \"./Wallet\";\nimport { Allowance } from \"./Allowance\";\nimport { Session } from \"./Session\";\nimport { Step } from \"./common\";\nimport { Address } from \"viem\";\nimport { useAccountModal } from \"../useAccountModal\";\n\nexport type Props = {\n userClient: ConnectedClient;\n initialUserAddress: Address | undefined;\n};\n\nexport function ConnectedSteps({ userClient, initialUserAddress }: Props) {\n const userAddress = userClient.account.address;\n const { data: prerequisites } = usePrerequisites(userAddress);\n\n const { closeAccountModal } = useAccountModal();\n const isNewConnection = userAddress !== initialUserAddress;\n\n const initialPrerequisites = useRef(prerequisites);\n useEffect(() => {\n if (prerequisites == null) return;\n if (initialPrerequisites.current == null) {\n initialPrerequisites.current = prerequisites;\n }\n\n if (prerequisites.complete) {\n if (isNewConnection || !initialPrerequisites.current.complete) {\n closeAccountModal();\n }\n }\n }, [closeAccountModal, isNewConnection, prerequisites]);\n\n const { hasAllowance, isSpender, hasDelegation } = prerequisites ?? {};\n\n const steps = useMemo((): readonly Step[] => {\n if (!userAddress) {\n return [\n {\n id: \"wallet\",\n isComplete: false,\n content: () => null,\n },\n ];\n }\n\n return [\n {\n id: \"wallet\",\n isComplete: true,\n content: (props) => <Wallet {...props} userAddress={userAddress} />,\n },\n {\n id: \"allowance\",\n isComplete: !!hasAllowance,\n content: (props) => <Allowance {...props} userAddress={userAddress} />,\n },\n {\n id: \"session\",\n isComplete: !!isSpender && !!hasDelegation,\n content: (props) => (\n <Session\n {...props}\n userClient={userClient}\n registerSpender={!isSpender}\n registerDelegation={!hasDelegation}\n />\n ),\n },\n ];\n }, [hasAllowance, hasDelegation, isSpender, userAddress, userClient]);\n\n const [selectedStepId] = useState<null | string>(null);\n const nextStep = steps.find((step) => step.content != null && !step.isComplete);\n const completedSteps = steps.filter((step) => step.isComplete);\n const activeStep =\n (selectedStepId != null ? steps.find((step) => step.id === selectedStepId) : null) ??\n nextStep ??\n (completedSteps.length < steps.length ? completedSteps.at(-1) : null);\n const activeStepIndex = activeStep ? steps.indexOf(activeStep) : -1;\n\n return (\n <div\n className={twMerge(\n \"min-h-[26rem] px-8 flex flex-col divide-y divide-neutral-800\",\n \"animate-in animate-duration-300 fade-in slide-in-from-bottom-8\",\n )}\n >\n {steps.map((step, i) => {\n const isActive = step === activeStep;\n const isExpanded = isActive || completedSteps.length === steps.length;\n const isDisabled = !step.isComplete && activeStepIndex !== -1 && i > activeStepIndex;\n return (\n <div key={step.id} className={twMerge(\"py-8 flex flex-col justify-center\", isActive ? \"flex-grow\" : null)}>\n <div className={twMerge(\"flex flex-col\", isDisabled ? \"opacity-30 pointer-events-none\" : null)}>\n {step.content({ isActive, isExpanded })}\n </div>\n </div>\n );\n })}\n </div>\n );\n}\n","import { ReactNode } from \"react\";\nimport { parseEther } from \"viem\";\n\nexport type Step = {\n id: string;\n isComplete: boolean;\n content: (props: { isActive: boolean; isExpanded: boolean }) => ReactNode;\n};\n\nexport const minGasBalance = parseEther(\"0.01\");\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getAllowance } from \"./getAllowance\";\n\nexport function getAllowanceQueryOptions({\n client,\n paymasterAddress,\n userAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n paymasterAddress: Address;\n userAddress: Address | undefined;\n}) {\n const queryKey = [\"getAllowance\", client?.chain.id, paymasterAddress, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: () => getAllowance({ client, paymasterAddress, userAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useAllowance(userAddress: Address | undefined) {\n const { chainId, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getAllowanceQueryOptions({ client, paymasterAddress, userAddress }));\n}\n","import { defineStore } from \"@latticexyz/store\";\nimport { parseAbi } from \"viem\";\n\n// TODO: dedupe this (exists in cli and entrykit)\n\n// TODO: whole ABI\nexport const paymasterAbi = parseAbi([\n \"error SpenderSystem_AlreadyRegistered(address spender, address user)\",\n \"error SpenderSystem_HasOwnBalance(address spender)\",\n \"function registerSpender(address spender)\",\n]);\n\nexport const paymasterConfig = defineStore({\n namespaces: {\n root: {\n namespace: \"\",\n tables: {\n Allowance: {\n schema: {\n user: \"address\",\n allowance: \"uint256\",\n },\n key: [\"user\"],\n },\n Grantor: {\n schema: {\n grantor: \"address\",\n allowance: \"uint256\",\n },\n key: [\"grantor\"],\n },\n PassHolder: {\n schema: {\n user: \"address\",\n passId: \"bytes32\",\n lastRenewed: \"uint256\",\n lastClaimed: \"uint256\",\n },\n key: [\"user\", \"passId\"],\n },\n PassConfig: {\n schema: {\n passId: \"bytes32\",\n claimAmount: \"uint256\",\n claimInterval: \"uint256\",\n validityPeriod: \"uint256\",\n grantor: \"address\",\n },\n key: [\"passId\"],\n },\n Spender: {\n schema: {\n spender: \"address\",\n user: \"address\",\n },\n key: [\"spender\"],\n },\n SystemConfig: {\n schema: {\n entryPoint: \"address\",\n },\n key: [],\n },\n },\n },\n },\n});\n\nexport const paymasterTables = paymasterConfig.namespaces.root.tables;\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { paymasterTables } from \"../paymaster\";\nimport { getRecord } from \"@latticexyz/store/internal\";\n\n// TODO: dedupe this (exists in cli and entrykit)\n\nexport type GetAllowanceParams = {\n client: Client<Transport, Chain>;\n paymasterAddress: Address;\n userAddress: Address;\n};\n\nexport async function getAllowance({ client, paymasterAddress, userAddress }: GetAllowanceParams) {\n const record = await getRecord(client, {\n address: paymasterAddress,\n table: paymasterTables.Allowance,\n key: { user: userAddress },\n blockTag: \"pending\",\n });\n return record.allowance;\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSpender } from \"./getSpender\";\n\nexport function getSpenderQueryOptions({\n client,\n paymasterAddress,\n userAddress,\n sessionAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n paymasterAddress: Address;\n userAddress: Address | undefined;\n sessionAddress: Address | undefined;\n}) {\n const queryKey = [\"getSpender\", client?.chain.id, paymasterAddress, userAddress, sessionAddress];\n return queryOptions(\n client && userAddress && sessionAddress\n ? {\n queryKey,\n queryFn: () => getSpender({ client, paymasterAddress, userAddress, sessionAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSpender(userAddress: Address | undefined, sessionAddress: Address | undefined) {\n const { chainId, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getSpenderQueryOptions({ client, paymasterAddress, userAddress, sessionAddress }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { paymasterTables } from \"../paymaster\";\nimport { getRecord } from \"@latticexyz/store/internal\";\n\nexport type GetSpenderParams = {\n client: Client<Transport, Chain>;\n paymasterAddress: Address;\n userAddress: Address;\n sessionAddress: Address;\n};\n\nexport async function getSpender({ client, paymasterAddress, userAddress, sessionAddress }: GetSpenderParams) {\n const record = await getRecord(client, {\n address: paymasterAddress,\n table: paymasterTables.Spender,\n key: { spender: sessionAddress },\n blockTag: \"pending\",\n });\n return record.user.toLowerCase() === userAddress.toLowerCase();\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getDelegation } from \"./getDelegation\";\n\nexport function getDelegationQueryOptions({\n client,\n worldAddress,\n userAddress,\n sessionAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n worldAddress: Address;\n userAddress: Address | undefined;\n sessionAddress: Address | undefined;\n}) {\n const queryKey = [\"getDelegation\", client?.chain.id, worldAddress, userAddress, sessionAddress];\n return queryOptions(\n client && userAddress && sessionAddress\n ? {\n queryKey,\n queryFn: () => getDelegation({ client, worldAddress, userAddress, sessionAddress }),\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useDelegation(userAddress: Address | undefined, sessionAddress: Address | undefined) {\n const { chainId, worldAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getDelegationQueryOptions({ client, worldAddress, userAddress, sessionAddress }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { getRecord } from \"@latticexyz/store/internal\";\nimport { unlimitedDelegationControlId, worldTables } from \"../common\";\n\nexport type GetDelegationParams = {\n client: Client<Transport, Chain>;\n worldAddress: Address;\n userAddress: Address;\n sessionAddress: Address;\n};\n\nexport async function getDelegation({ client, worldAddress, userAddress, sessionAddress }: GetDelegationParams) {\n const record = await getRecord(client, {\n address: worldAddress,\n table: worldTables.UserDelegationControl,\n key: { delegator: userAddress, delegatee: sessionAddress },\n blockTag: \"pending\",\n });\n return record.delegationControlId === unlimitedDelegationControlId;\n}\n","import { minGasBalance } from \"./common\";\nimport { getAllowanceQueryOptions } from \"./useAllowance\";\nimport { getSpenderQueryOptions } from \"./useSpender\";\nimport { getDelegationQueryOptions } from \"./useDelegation\";\nimport { QueryClient, queryOptions, useQuery, useQueryClient } from \"@tanstack/react-query\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { Address, Chain, Client, Transport } from \"viem\";\nimport { getSessionAccountQueryOptions } from \"../useSessionAccount\";\n\nexport function getPrequisitesQueryOptions({\n queryClient,\n client,\n userAddress,\n paymasterAddress,\n worldAddress,\n}: {\n queryClient: QueryClient;\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n paymasterAddress: Address;\n worldAddress: Address;\n}) {\n const queryKey = [\"getPrerequisites\", client?.chain.id, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: async () => {\n const { address: sessionAddress } = await queryClient.fetchQuery(\n getSessionAccountQueryOptions({ client, userAddress }),\n );\n const [allowance, isSpender, hasDelegation] = await Promise.all([\n queryClient.fetchQuery(getAllowanceQueryOptions({ client, paymasterAddress, userAddress })),\n queryClient.fetchQuery(getSpenderQueryOptions({ client, paymasterAddress, userAddress, sessionAddress })),\n queryClient.fetchQuery(getDelegationQueryOptions({ client, worldAddress, userAddress, sessionAddress })),\n ]);\n const hasAllowance = allowance >= minGasBalance;\n return {\n hasAllowance,\n isSpender,\n hasDelegation,\n complete: hasAllowance && isSpender && hasDelegation,\n };\n },\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function usePrerequisites(userAddress: Address | undefined) {\n const queryClient = useQueryClient();\n const { chainId, paymasterAddress, worldAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n\n // TODO: rework this so it uses other hooks so we avoid having to clear two caches when e.g. topping up\n\n const prereqs = useQuery(\n getPrequisitesQueryOptions({\n queryClient,\n client,\n userAddress,\n paymasterAddress,\n worldAddress,\n }),\n queryClient,\n );\n // console.log(\"prereqs\", prereqs.isFetching, prereqs.isRefetching, prereqs.isFetchedAfterMount);\n return prereqs;\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { UseQueryResult, queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSessionAccount } from \"./getSessionAccount\";\nimport { SmartAccount } from \"viem/account-abstraction\";\n\nexport function getSessionAccountQueryOptions({\n client,\n userAddress,\n}: {\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n}) {\n const queryKey = [\"getSessionAccount\", client?.chain.id, userAddress];\n return queryOptions(\n client && userAddress\n ? {\n queryKey,\n queryFn: () => getSessionAccount({ client, userAddress }),\n staleTime: Infinity,\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSessionAccount(userAddress: Address | undefined): UseQueryResult<SmartAccount> {\n const { chainId } = useEntryKitConfig();\n const client = useClient({ chainId });\n return useQuery(getSessionAccountQueryOptions({ userAddress, client }));\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { toCoinbaseSmartAccount } from \"@latticexyz/common/accounts\";\nimport { getSessionSigner } from \"./getSessionSigner\";\n\nexport async function getSessionAccount<chain extends Chain>({\n client,\n userAddress,\n}: {\n client: Client<Transport, chain>;\n userAddress: Address;\n}): Promise<SmartAccount> {\n const sessionSigner = getSessionSigner(userAddress);\n return await toCoinbaseSmartAccount({ client, owners: [sessionSigner] });\n}\n","import { createStore } from \"zustand/vanilla\";\nimport { persist } from \"zustand/middleware\";\nimport { Address, Hex } from \"viem\";\n\nexport type State = {\n readonly signers: {\n readonly [key in Address]?: Hex;\n };\n};\n\nexport const store = createStore(\n persist<State>(\n () => ({\n signers: {},\n }),\n {\n name: \"mud:entrykit\",\n partialize: ({ signers }) => ({ signers }),\n },\n ),\n);\n\n// keep store in sync across tabs/windows via storage event\nfunction listener(event: StorageEvent) {\n if (event.key === store.persist.getOptions().name) {\n store.persist.rehydrate();\n }\n}\nwindow.addEventListener(\"storage\", listener);\n","import { Address } from \"viem\";\nimport { store } from \"./store\";\nimport { generatePrivateKey, privateKeyToAccount } from \"viem/accounts\";\n\nexport function getSessionSigner(userAddress: Address) {\n const sessionSignerPrivateKey =\n store.getState().signers[userAddress] ??\n (() => {\n const privateKey = generatePrivateKey();\n store.setState((state) => ({\n signers: {\n ...state.signers,\n [userAddress]: privateKey,\n },\n }));\n return privateKey;\n })();\n\n return privateKeyToAccount(sessionSignerPrivateKey);\n}\n","import { useDisconnect } from \"wagmi\";\nimport { useENS } from \"../useENS\";\nimport { TruncatedHex } from \"../ui/TruncatedHex\";\nimport { Button } from \"../ui/Button\";\nimport { useAccountModal } from \"../useAccountModal\";\nimport { Hex } from \"viem\";\n\nexport type Props = {\n isActive: boolean;\n isExpanded: boolean;\n userAddress: Hex;\n};\n\nexport function Wallet({ isActive, isExpanded, userAddress }: Props) {\n const { data: ens } = useENS(userAddress);\n const { disconnect, isPending: disconnectIsPending } = useDisconnect();\n const { closeAccountModal } = useAccountModal();\n\n // TODO: render ENS avatar if available?\n // TODO: display disconnect error as popover near button?\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Account</div>\n <div className=\"font-mono text-white\">{ens?.name ?? <TruncatedHex hex={userAddress} />}</div>\n </div>\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive}\n pending={disconnectIsPending}\n onClick={() => {\n closeAccountModal();\n disconnect();\n }}\n >\n Sign out\n </Button>\n </div>\n {isExpanded ? (\n <p className=\"text-sm\">Each of your onchain actions in this app is associated with your account.</p>\n ) : null}\n </div>\n );\n}\n","import { Hex } from \"viem\";\nimport { useQuery } from \"@tanstack/react-query\";\n\nexport function useENS(address: Hex | undefined) {\n const normalizedAddress = address?.toLowerCase();\n return useQuery<{\n address: string | undefined;\n name: string | undefined;\n displayName: string | undefined;\n avatar: string | undefined;\n }>({\n enabled: !!normalizedAddress,\n queryKey: [\"ens\", normalizedAddress],\n\n queryFn: async () => {\n // TODO: typed response\n const data = await fetch(`https://api.ensideas.com/ens/resolve/${normalizedAddress}`).then((res) => res.json());\n return {\n address: data.address ?? undefined,\n name: data.name ?? undefined,\n displayName: data.displayName ?? undefined,\n avatar: data.avatar ?? undefined,\n };\n },\n });\n}\n","import { Hex } from \"viem\";\n\nexport type Props = {\n hex: Hex;\n};\n\nexport function TruncatedHex({ hex }: Props) {\n if (hex.length <= 10) {\n return <span title={hex}>{hex}</span>;\n }\n\n return (\n <span title={hex}>\n <span className=\"after:select-none after:content-['…']\">{hex.slice(0, 6)}</span>\n <span className=\"tracking-[-1ch] text-transparent\">{hex.slice(6, -4)}</span>\n {hex.slice(-4)}\n </span>\n );\n}\n","import { Address } from \"viem\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { claimGasPass } from \"@latticexyz/paymaster/internal\";\n\nexport function useClaimGasPass() {\n const queryClient = useQueryClient();\n const { chain } = useEntryKitConfig();\n\n const mutationKey = [\"claimGasPass\", chain.id];\n return useMutation({\n mutationKey,\n onError: (error) => console.error(error),\n mutationFn: async (userAddress: Address) => {\n // TODO: handle case where you already have a pass?\n // TODO: get returned tx hashes to check if success\n await claimGasPass({ chain, userAddress });\n\n await Promise.all([\n queryClient.invalidateQueries({ queryKey: [\"getAllowance\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getPrerequisites\"] }),\n ]);\n },\n retry: 0,\n });\n}\n","import { DetailedHTMLProps, SVGAttributes } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = DetailedHTMLProps<SVGAttributes<SVGSVGElement>, SVGSVGElement>;\n\nexport function EthIcon({ className, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 263 428\"\n fill=\"currentColor\"\n className={twMerge(\"w-[0.6em] h-[1em]\", className)}\n {...props}\n >\n <path d=\"M132 321V428L263 243L132 321Z\" />\n <path d=\"M0 243L132 321V428\" fillOpacity=\"0.5\" />\n <path d=\"M132 0V296L263 218\" />\n <path d=\"M0 218L132 296V0L0 218Z\" fillOpacity=\"0.5\" />\n </svg>\n );\n}\n","import { formatEther } from \"viem\";\n\nexport function formatBalance(wei: bigint) {\n // TODO: should this support non-ether decimals?\n const formatted = formatEther(wei);\n const magnitude = Math.floor(parseFloat(formatted)).toString().length;\n return parseFloat(formatted).toLocaleString(\"en-US\", { maximumFractionDigits: Math.max(0, 6 - magnitude) });\n}\n","import { EthIcon } from \"../icons/EthIcon\";\nimport { formatBalance } from \"../formatBalance\";\n\ntype Props = {\n wei: bigint;\n};\n\nexport function Balance({ wei }: Props) {\n return (\n <span className=\"inline-flex items-center gap-1\">\n {formatBalance(wei)} <EthIcon />\n </span>\n );\n}\n","import { Hex } from \"viem\";\nimport { useAllowance } from \"./useAllowance\";\nimport { PendingIcon } from \"../icons/PendingIcon\";\nimport { useClaimGasPass } from \"./useClaimGasPass\";\nimport { Button } from \"../ui/Button\";\nimport { Balance } from \"../ui/Balance\";\nimport { useEffect } from \"react\";\nimport { minGasBalance } from \"./common\";\n\nexport type Props = {\n isExpanded: boolean;\n isActive: boolean;\n userAddress: Hex;\n};\n\nexport function Allowance({ isActive, isExpanded, userAddress }: Props) {\n const allowance = useAllowance(userAddress);\n const claimGasPass = useClaimGasPass();\n\n useEffect(() => {\n // There seems to be a tanstack-query bug(?) where multiple simultaneous renders loses\n // state between the two mutations. They're not treated as shared state but rather\n // individual mutations, even though the keys match. And the one we want the status of\n // seems to stay pending. This is sorta resolved by triggering this after a timeout.\n const timer = setTimeout(() => {\n if (isActive && claimGasPass.status === \"idle\" && allowance.isSuccess && allowance.data < minGasBalance) {\n claimGasPass.mutate(userAddress);\n }\n });\n return () => clearTimeout(timer);\n }, [allowance.data, allowance.isSuccess, claimGasPass, isActive, userAddress]);\n\n // TODO: show error if allowance fails to load\n // TODO: show claim error\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Allowance</div>\n <div className=\"font-mono text-white\">\n {allowance.data != null ? <Balance wei={allowance.data} /> : <PendingIcon className=\"text-sm\" />}\n </div>\n </div>\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive || isExpanded}\n pending={allowance.status === \"pending\" || claimGasPass.status === \"pending\"}\n onClick={() => claimGasPass.mutate(userAddress)}\n >\n Top up\n </Button>\n </div>\n {isExpanded ? <p className=\"text-sm\">Your allowance is used to pay for onchain computation.</p> : null}\n </div>\n );\n}\n","import { Hex, encodeFunctionData } from \"viem\";\nimport { useMutation, useQueryClient } from \"@tanstack/react-query\";\nimport { getAction } from \"viem/utils\";\nimport { sendUserOperation, waitForUserOperationReceipt } from \"viem/account-abstraction\";\nimport { useEntryKitConfig } from \"../EntryKitConfigProvider\";\nimport { ConnectedClient, unlimitedDelegationControlId, worldAbi } from \"../common\";\nimport { paymasterAbi } from \"../paymaster\";\nimport { waitForTransactionReceipt } from \"viem/actions\";\nimport { defineCall } from \"../utils/defineCall\";\nimport { useClient } from \"wagmi\";\nimport { resourceToHex } from \"@latticexyz/common\";\nimport IBaseWorldAbi from \"@latticexyz/world/out/IBaseWorld.sol/IBaseWorld.abi.json\";\nimport { callWithSignature } from \"../utils/callWithSignature\";\n\nexport function useSetupSession({ userClient }: { userClient: ConnectedClient }) {\n const queryClient = useQueryClient();\n const { chainId, worldAddress, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n\n const mutationKey = [\"setupSession\", client?.chain.id, userClient.account.address];\n return useMutation({\n mutationKey,\n onError: (error) => console.error(error),\n mutationFn: async ({\n sessionClient,\n registerSpender,\n registerDelegation,\n }: {\n sessionClient: ConnectedClient;\n registerSpender: boolean;\n registerDelegation: boolean;\n }): Promise<void> => {\n if (!client) throw new Error(\"Client not ready.\");\n const sessionAddress = sessionClient.account.address;\n\n console.log(\"setting up session\");\n\n if (userClient.account.type !== \"smart\") {\n const txs: Hex[] = [];\n\n if (registerSpender) {\n console.log(\"registering spender\");\n const tx = await callWithSignature({\n client,\n userClient,\n sessionClient,\n worldAddress: paymasterAddress,\n systemId: resourceToHex({ type: \"system\", namespace: \"\", name: \"SpenderSystem\" }),\n callData: encodeFunctionData({\n abi: paymasterAbi,\n functionName: \"registerSpender\",\n args: [sessionAddress],\n }),\n });\n console.log(\"got spender tx\", tx);\n txs.push(tx);\n }\n\n if (registerDelegation) {\n console.log(\"registering delegation\");\n const tx = await callWithSignature({\n client,\n userClient,\n sessionClient,\n worldAddress,\n systemId: resourceToHex({ type: \"system\", namespace: \"\", name: \"Registration\" }),\n callData: encodeFunctionData({\n abi: IBaseWorldAbi,\n functionName: \"registerDelegation\",\n args: [sessionAddress, unlimitedDelegationControlId, \"0x\"],\n }),\n });\n console.log(\"got delegation tx\", tx);\n txs.push(tx);\n }\n\n if (!txs.length) return;\n\n console.log(\"waiting for\", txs.length, \"receipts\");\n for (const hash of txs) {\n const receipt = await getAction(client, waitForTransactionReceipt, \"waitForTransactionReceipt\")({ hash });\n console.log(\"got tx receipt\", receipt);\n if (receipt.status === \"reverted\") {\n console.error(\"tx reverted?\", receipt);\n }\n }\n } else {\n const calls = [];\n\n if (registerSpender) {\n console.log(\"registering spender\");\n calls.push(\n defineCall({\n to: paymasterAddress,\n abi: paymasterAbi,\n functionName: \"registerSpender\",\n args: [sessionAddress],\n }),\n );\n }\n\n if (registerDelegation) {\n console.log(\"registering delegation\");\n calls.push(\n defineCall({\n to: worldAddress,\n abi: worldAbi,\n functionName: \"registerDelegation\",\n args: [sessionAddress, unlimitedDelegationControlId, \"0x\"],\n }),\n );\n }\n\n if (!calls.length) return;\n\n console.log(\"setting up account with\", calls, userClient);\n const hash = await getAction(userClient, sendUserOperation, \"sendUserOperation\")({ calls });\n console.log(\"got user op hash\", hash);\n\n const receipt = await getAction(\n userClient,\n waitForUserOperationReceipt,\n \"waitForUserOperationReceipt\",\n )({ hash });\n console.log(\"got user op receipt\", receipt);\n\n if (!receipt.success) {\n console.error(\"not successful?\", receipt);\n }\n }\n\n await Promise.all([\n queryClient.invalidateQueries({ queryKey: [\"getSpender\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getDelegation\"] }),\n queryClient.invalidateQueries({ queryKey: [\"getPrerequisites\"] }),\n ]);\n },\n retry: 0,\n });\n}\n","import { Chain } from \"viem\";\nimport { writeContract as viem_writeContract } from \"viem/actions\";\nimport { getAction } from \"viem/utils\";\nimport { SignCallOptions, signCall } from \"./signCall\";\nimport CallWithSignatureAbi from \"@latticexyz/world-modules/out/Unstable_CallWithSignatureSystem.sol/Unstable_CallWithSignatureSystem.abi.json\";\nimport { ConnectedClient } from \"../common\";\n\n// TODO: move this to world package or similar\n\nexport type CallWithSignatureOptions<chain extends Chain = Chain> = SignCallOptions<chain> & {\n sessionClient: ConnectedClient;\n};\n\nexport async function callWithSignature<chain extends Chain = Chain>({\n sessionClient,\n ...opts\n}: CallWithSignatureOptions<chain>) {\n const signature = await signCall(opts);\n return getAction(\n sessionClient,\n viem_writeContract,\n \"writeContract\",\n )({\n address: opts.worldAddress,\n abi: CallWithSignatureAbi,\n functionName: \"callWithSignature\",\n args: [opts.userClient.account.address, opts.systemId, opts.callData, signature],\n } as never);\n}\n","import { Address, Chain, Client, Hex, OneOf, Transport, toHex } from \"viem\";\nimport { signTypedData } from \"viem/actions\";\nimport { callWithSignatureTypes } from \"@latticexyz/world/internal\";\nimport { getRecord } from \"@latticexyz/store/internal\";\nimport modulesConfig from \"@latticexyz/world-modules/internal/mud.config\";\nimport { hexToResource } from \"@latticexyz/common\";\nimport { getAction } from \"viem/utils\";\nimport { ConnectedClient } from \"../common\";\n\n// TODO: move this to world package or similar\n\nexport type SignCallOptions<chain extends Chain = Chain> = {\n userClient: ConnectedClient<chain>;\n worldAddress: Address;\n systemId: Hex;\n callData: Hex;\n} & OneOf<{ nonce: bigint } | { client: Client<Transport, chain> }>;\n\nexport async function signCall<chain extends Chain = Chain>({\n userClient,\n worldAddress,\n systemId,\n callData,\n nonce: initialNonce,\n client,\n}: SignCallOptions<chain>) {\n const nonce =\n initialNonce ??\n (client\n ? (\n await getRecord(client, {\n address: worldAddress,\n table: modulesConfig.tables.CallWithSignatureNonces,\n key: { signer: userClient.account.address },\n blockTag: \"pending\",\n })\n ).nonce\n : 0n);\n\n const { namespace: systemNamespace, name: systemName } = hexToResource(systemId);\n\n return await getAction(\n userClient,\n signTypedData,\n \"signTypedData\",\n )({\n account: userClient.account,\n domain: {\n verifyingContract: worldAddress,\n salt: toHex(userClient.chain.id, { size: 32 }),\n },\n types: callWithSignatureTypes,\n primaryType: \"Call\",\n message: {\n signer: userClient.account.address,\n systemNamespace,\n systemName,\n callData,\n nonce,\n },\n });\n}\n","import { Button } from \"../ui/Button\";\nimport { useSetupSession } from \"./useSetupSession\";\nimport { ConnectedClient } from \"../common\";\nimport { useEffect } from \"react\";\nimport { useSessionClient } from \"../useSessionClient\";\n\nexport type Props = {\n isActive: boolean;\n isExpanded: boolean;\n userClient: ConnectedClient;\n registerSpender: boolean;\n registerDelegation: boolean;\n};\n\nexport function Session({ isActive, isExpanded, userClient, registerSpender, registerDelegation }: Props) {\n const { data: sessionClient } = useSessionClient(userClient.account.address);\n const setup = useSetupSession({ userClient });\n const hasSession = !registerDelegation && !registerDelegation;\n\n useEffect(() => {\n // There seems to be a tanstack-query bug(?) where multiple simultaneous renders loses\n // state between the two mutations. They're not treated as shared state but rather\n // individual mutations, even though the keys match. And the one we want the status of\n // seems to stay pending. This is sorta resolved by triggering this after a timeout.\n const timer = setTimeout(() => {\n if (isActive && setup.status === \"idle\" && sessionClient && !hasSession) {\n setup.mutate({\n sessionClient,\n registerSpender,\n registerDelegation,\n });\n }\n });\n return () => clearTimeout(timer);\n }, [hasSession, isActive, registerDelegation, registerSpender, sessionClient, setup]);\n\n return (\n <div className=\"flex flex-col gap-4\">\n <div className=\"flex justify-between gap-4\">\n <div>\n <div>Session</div>\n <div className=\"font-mono text-white\">{hasSession ? \"Enabled\" : \"Set up\"}</div>\n </div>\n {hasSession ? (\n <Button variant=\"tertiary\" className=\"flex-shrink-0 text-sm p-1 w-28\" autoFocus={isActive} disabled>\n Enabled\n </Button>\n ) : (\n <Button\n variant={isActive ? \"primary\" : \"tertiary\"}\n className=\"flex-shrink-0 text-sm p-1 w-28\"\n autoFocus={isActive}\n pending={!sessionClient || setup.status === \"pending\"}\n onClick={\n sessionClient\n ? () =>\n setup.mutate({\n sessionClient,\n registerSpender,\n registerDelegation,\n })\n : undefined\n }\n >\n Enable\n </Button>\n )}\n </div>\n {isExpanded ? (\n <p className=\"text-sm\">You can perform actions in this app without interruptions for approvals.</p>\n ) : null}\n </div>\n );\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { useClient } from \"wagmi\";\nimport { UseQueryResult, queryOptions, useQuery } from \"@tanstack/react-query\";\nimport { getSessionClient } from \"./getSessionClient\";\nimport { SessionClient } from \"./common\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { useSessionAccount } from \"./useSessionAccount\";\n\nexport function getSessionClientQueryOptions({\n sessionAccount,\n client,\n userAddress,\n worldAddress,\n paymasterAddress,\n}: {\n sessionAccount: SmartAccount | undefined;\n client: Client<Transport, Chain> | undefined;\n userAddress: Address | undefined;\n worldAddress: Address;\n paymasterAddress: Address;\n}) {\n const queryKey = [\"getSessionClient\", client?.uid, userAddress, sessionAccount?.address, worldAddress];\n return queryOptions(\n client && userAddress && sessionAccount\n ? {\n queryKey,\n queryFn: () =>\n getSessionClient({\n sessionAccount,\n client,\n userAddress,\n worldAddress,\n paymasterAddress,\n }),\n staleTime: Infinity,\n }\n : { queryKey, enabled: false },\n );\n}\n\nexport function useSessionClient(userAddress: Address | undefined): UseQueryResult<SessionClient> {\n const { chainId, worldAddress, paymasterAddress } = useEntryKitConfig();\n const client = useClient({ chainId });\n const { data: sessionAccount } = useSessionAccount(userAddress);\n return useQuery(\n getSessionClientQueryOptions({\n sessionAccount,\n userAddress,\n client,\n worldAddress,\n paymasterAddress,\n }),\n );\n}\n","import { Address, Chain, Client, Transport } from \"viem\";\nimport { smartAccountActions } from \"permissionless\";\nimport { callFrom } from \"@latticexyz/world/internal\";\nimport { createBundlerClient } from \"./createBundlerClient\";\nimport { observer } from \"@latticexyz/explorer/observer\";\nimport { SessionClient } from \"./common\";\nimport { SmartAccount } from \"viem/account-abstraction\";\nimport { getBundlerTransport } from \"./getBundlerTransport\";\n\nexport async function getSessionClient<chain extends Chain>({\n client,\n userAddress,\n sessionAccount,\n worldAddress,\n paymasterAddress,\n}: {\n client: Client<Transport, chain>;\n userAddress: Address;\n sessionAccount: SmartAccount;\n worldAddress: Address;\n paymasterAddress: Address;\n}): Promise<SessionClient<chain>> {\n const bundlerTransport = getBundlerTransport(client.chain);\n\n const sessionClient = createBundlerClient({\n paymasterAddress,\n transport: bundlerTransport,\n client,\n account: sessionAccount,\n })\n .extend(smartAccountActions())\n .extend(callFrom({ worldAddress, delegatorAddress: userAddress, publicClient: client }))\n .extend(observer())\n .extend(() => ({ userAddress }));\n\n return sessionClient;\n}\n","import { ReactNode, useState } from \"react\";\nimport { ErrorBoundary } from \"react-error-boundary\";\nimport { ErrorNotice } from \"./ErrorNotice\";\nimport { wait } from \"@latticexyz/common/utils\";\nimport { twMerge } from \"tailwind-merge\";\nimport { useIsMounted } from \"usehooks-ts\";\nimport { PendingIcon } from \"./icons/PendingIcon\";\n\nexport type Props = {\n children: ReactNode;\n};\n\nexport function AccountModalErrorBoundary({ children }: Props) {\n const isMounted = useIsMounted();\n const [retries, setRetries] = useState(1);\n\n // TODO: invalidate query cache?\n\n return (\n <ErrorBoundary\n fallbackRender={({ error, resetErrorBoundary }) => (\n <div className={twMerge(\"flex-grow flex flex-col justify-center p-5 gap-2\")}>\n <ErrorNotice error={error instanceof Error ? error.stack ?? error.message : error} />\n {retries > 0 ? (\n <button\n type=\"button\"\n onClick={async (event) => {\n // fake pending state while we retry so that if the same error occurs,\n event.currentTarget.ariaBusy = \"true\";\n await wait(1000);\n resetErrorBoundary();\n if (isMounted()) {\n setRetries((value) => value - 1);\n event.currentTarget.ariaBusy = null;\n }\n }}\n className=\"group aria-busy:pointer-events-none self-end flex items-center gap-1\"\n >\n <PendingIcon className=\"transition opacity-0 group-aria-busy:opacity-100 text-xs text-neutral-500 dark:text-neutral-400\" />\n <span className=\"text-sm text-neutral-500 dark:text-neutral-400 group-hover:text-black dark:group-hover:text-white\">\n Retry?\n </span>\n </button>\n ) : null}\n </div>\n )}\n >\n {children}\n </ErrorBoundary>\n );\n}\n","import { twMerge } from \"tailwind-merge\";\nimport { BaseError, UserRejectedRequestError } from \"viem\";\n\nexport type Props = {\n title?: string;\n error?: unknown;\n};\n\nexport function ErrorNotice({ title: initialTitle, error }: Props) {\n if (!error) return null;\n // no need to let users know they rejected\n if (error instanceof BaseError && error.walk((e) => e instanceof UserRejectedRequestError) != null) {\n return null;\n }\n\n // TODO: extract title from error name or first line of error message?\n const title = initialTitle ?? \"Error\";\n\n // TODO: do something to protect against `[object Object]`\n const message =\n typeof error === \"string\" ? error : error instanceof Error ? String(error) : \"Something unexpected happened.\";\n\n // TODO: add \"report error\" link\n\n return (\n <div\n className={twMerge(\n \"text-sm border-l-4 border-red-500\",\n \"bg-red-100 text-red-900\",\n \"dark:bg-red-900 dark:text-red-50\",\n )}\n >\n <div className=\"p-3 font-semibold\">{title}</div>\n <div className=\"px-3 whitespace-break-spaces break-all max-h-32 overflow-y-scroll\">{message}</div>\n </div>\n );\n}\n","import { SVGProps } from \"react\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = SVGProps<SVGSVGElement>;\n\nexport function IconSVG({ className, children, ...props }: Props) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 24 24\"\n fill=\"currentColor\"\n className={twMerge(\"-my-[0.125em] h-[1.25em] w-[1.25em]\", className)}\n {...props}\n >\n {children}\n </svg>\n );\n}\n","import { IconSVG, Props } from \"./IconSVG\";\n\nexport function CloseIcon(props: Props) {\n return (\n <IconSVG strokeWidth=\"2\" stroke=\"currentColor\" {...props}>\n <path\n d=\"M6 18L18 6M6 6L18 18\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n />\n </IconSVG>\n );\n}\n","import { type ReactNode } from \"react\";\nimport { AccountModal } from \"./AccountModal\";\nimport { EntryKitConfig } from \"./config/output\";\nimport { EntryKitConfigProvider } from \"./EntryKitConfigProvider\";\n\n// We separate the config provider and wrap it here to always include the modal.\n// We could do this in EntryKitConfigProvider directly, but it mucks with hot\n// reloading in development and this approach lets us work around it more easily.\n\nexport type Props = {\n config: EntryKitConfig;\n children?: ReactNode;\n};\n\nexport function EntryKitProvider({ config, children }: Props) {\n return (\n <EntryKitConfigProvider config={config}>\n {children}\n <AccountModal />\n </EntryKitConfigProvider>\n );\n}\n","import { useAccountModal } from \"./useAccountModal\";\nimport { Shadow } from \"./ui/Shadow\";\nimport { Logo } from \"./icons/Logo\";\nimport { useAccount } from \"wagmi\";\nimport { twMerge } from \"tailwind-merge\";\nimport { PendingIcon } from \"./icons/PendingIcon\";\nimport { AccountName } from \"./AccountName\";\nimport { usePrerequisites } from \"./onboarding/usePrerequisites\";\nimport { useRef } from \"react\";\n\nconst containerClassNames = twMerge(\n \"w-48 p-3 inline-flex outline-none transition\",\n \"border border-transparent\",\n \"text-base leading-none\",\n);\n\nconst secondaryClassNames = twMerge(\n \"bg-neutral-100 border-neutral-300 text-black\",\n \"dark:bg-neutral-800 dark:border-neutral-700 dark:text-white\",\n);\nconst secondaryInteractiveClassNames = twMerge(\n \"cursor-pointer outline-none hover:bg-neutral-200 data-[highlighted]:bg-neutral-200 dark:hover:bg-neutral-700\",\n);\n\nexport function AccountButton() {\n const { openAccountModal, accountModalOpen } = useAccountModal();\n const { status, address: userAddress } = useAccount();\n const initialUserAddress = useRef(userAddress);\n\n const prereqs = usePrerequisites(userAddress);\n\n // TODO: fix flash of button state signed in but incomplete onboarding\n const isConnected = status === \"connected\" || (status === \"reconnecting\" && userAddress);\n const isNewConnection = userAddress !== initialUserAddress.current;\n const isSignedIn = prereqs.isSuccess ? prereqs.data.complete : isNewConnection ? false : isConnected;\n\n const buttonLabel = (() => {\n if (prereqs.isSuccess) {\n if (!prereqs.data.hasAllowance) return \"Top up\";\n if (!prereqs.data.hasDelegation || !prereqs.data.isSpender) return \"Set up\";\n }\n return \"Sign in\";\n })();\n\n return (\n <Shadow mode=\"child\">\n {isSignedIn ? (\n <button\n // key is used to avoid triggering transitions between connected/disconnected states\n key=\"connected\"\n type=\"button\"\n className={twMerge(containerClassNames, secondaryClassNames, secondaryInteractiveClassNames)}\n onClick={openAccountModal}\n >\n <span className=\"flex-grow inline-flex gap-2.5 items-center text-left font-medium\">\n {userAddress ? <AccountName address={userAddress} /> : null}\n </span>\n </button>\n ) : (\n <button\n // key is used to avoid triggering transitions between connected/disconnected states\n key=\"sign in\"\n type=\"button\"\n className={twMerge(\n containerClassNames,\n \"group\",\n \"items-center justify-center gap-2.5\",\n \"bg-orange-500 text-white font-medium\",\n \"hover:bg-orange-400\",\n \"active:bg-orange-600\",\n )}\n aria-busy={accountModalOpen}\n onClick={openAccountModal}\n >\n <span className=\"pointer-events-none inline-grid place-items-center -ml-3\">\n <span\n className={twMerge(\n \"col-start-1 row-start-1 leading-none\",\n \"scale-100 opacity-100 transition duration-300\",\n \"group-aria-busy:scale-125 group-aria-busy:opacity-0\",\n )}\n >\n <Logo />\n </span>\n <span\n aria-hidden\n className={twMerge(\n \"col-start-1 row-start-1\",\n \"scale-50 opacity-0 transition duration-300 delay-50\",\n \"group-aria-busy:scale-100 group-aria-busy:opacity-100\",\n )}\n >\n <PendingIcon />\n </span>\n </span>\n <span className=\"font-medium\">{buttonLabel}</span>\n </button>\n )}\n </Shadow>\n );\n}\n","import { Hex } from \"viem\";\nimport { useENS } from \"./useENS\";\nimport { Logo } from \"./icons/Logo\";\nimport { TruncatedHex } from \"./ui/TruncatedHex\";\nimport { usePreloadImage } from \"./usePreloadImage\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport type Props = {\n address: Hex;\n};\n\nexport function AccountName({ address }: Props) {\n const { data: ens } = useENS(address);\n const avatar = usePreloadImage(ens?.avatar);\n\n return (\n <>\n <span className=\"flex-shrink-0 w-6 h-6 -my-1 -mx-0.5 grid place-items-center\">\n <img\n src={ens?.avatar && avatar.isSuccess ? ens.avatar : undefined}\n className={twMerge(\n \"col-start-1 row-start-1\",\n \"inline-flex w-full h-full rounded-full bg-black/10 dark:bg-white/10 bg-cover bg-no-repeat bg-center\",\n \"transtion duration-300\",\n avatar.isSuccess ? \"opacity-100\" : \"opacity-0\",\n )}\n />\n <Logo\n className={twMerge(\n \"col-start-1 row-start-1 text-orange-500\",\n \"transition duration-300\",\n ens && (!ens.avatar || avatar.isError) ? \"opacity-100\" : \"opacity-0\",\n )}\n />\n </span>\n <span className=\"flex-grow\">{ens?.name ?? <TruncatedHex hex={address} />}</span>\n </>\n );\n}\n","// Exported `useSessionClient` variant and only provides the session client once all prerequisites are met.\n\nimport { useConnectorClient } from \"wagmi\";\nimport { useSessionClient } from \"./useSessionClient\";\nimport { useEntryKitConfig } from \"./EntryKitConfigProvider\";\nimport { usePrerequisites } from \"./onboarding/usePrerequisites\";\nimport { UseQueryResult } from \"@tanstack/react-query\";\nimport { SessionClient } from \"./common\";\n\nexport function useSessionClientReady(): UseQueryResult<SessionClient | undefined> {\n const { chainId } = useEntryKitConfig();\n const userClient = useConnectorClient({ chainId });\n if (userClient.error) console.error(\"Error retrieving user client\", userClient.error);\n\n const userAddress = userClient.data?.account.address;\n const prerequisites = usePrerequisites(userAddress);\n const sessionClient = useSessionClient(userAddress);\n\n if (!userClient.isSuccess) return { ...userClient, data: undefined } as never;\n if (!prerequisites.isSuccess || !prerequisites.data.complete) return { ...prerequisites, data: undefined } as never;\n return sessionClient;\n}\n","import { Chain, Transport } from \"viem\";\nimport { WalletList, connectorsForWallets, getDefaultWallets } from \"@rainbow-me/rainbowkit\";\nimport { Config, CreateConfigParameters, createConfig } from \"wagmi\";\nimport { passkeyWallet } from \"./passkey/passkeyWallet\";\nimport { mapObject } from \"@latticexyz/common/utils\";\nimport { wiresaw } from \"@latticexyz/wiresaw/internal\";\n\nexport type CreateWagmiConfigOptions<\n chains extends readonly [Chain, ...Chain[]] = readonly [Chain, ...Chain[]],\n transports extends Record<chains[number][\"id\"], Transport> = Record<chains[number][\"id\"], Transport>,\n> = {\n readonly chainId: number;\n readonly chains: chains;\n readonly transports: transports;\n /**\n * WalletConnect project ID, obtained from your WalletConnect dashboard.\n */\n // TODO: make optional and hide wallet options if so?\n readonly walletConnectProjectId: string;\n readonly appName: string;\n} & Pick<CreateConfigParameters<chains, transports>, \"pollingInterval\">;\n\nexport function createWagmiConfig<\n const chains extends readonly [Chain, ...Chain[]],\n transports extends Record<chains[number][\"id\"], Transport>,\n>(config: CreateWagmiConfigOptions<chains, transports>): Config<chains, transports> {\n const { wallets: defaultWallets } = getDefaultWallets();\n const wallets: WalletList = [\n {\n groupName: \"Recommended\",\n wallets: [\n passkeyWallet({\n // TODO: allow any chain ID\n chainId: config.chainId,\n }),\n ],\n },\n ...defaultWallets,\n ];\n\n const connectors = connectorsForWallets(wallets, {\n appName: config.appName,\n projectId: config.walletConnectProjectId,\n });\n\n return createConfig({\n connectors,\n chains: config.chains,\n transports: mapObject(config.transports, (transport) => wiresaw(transport)),\n pollingInterval: config.pollingInterval,\n }) as never;\n}\n","import { Wallet } from \"@rainbow-me/rainbowkit\";\nimport { PasskeyConnectorOptions, passkeyConnector } from \"./passkeyConnector\";\n\nconst iconUrl = `data:image/svg+xml;base64,${btoa(\n // eslint-disable-next-line max-len\n '<svg xmlns=\"http://www.w3.org/2000/svg\" shape-rendering=\"geometricPrecision\" text-rendering=\"geometricPrecision\" image-rendering=\"optimizeQuality\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" width=\"512\" height=\"512\" viewBox=\"-64 -32 608 512\"><path d=\"M6.206 425.469A6.202 6.202 0 010 419.263c0-1.771.235-3.517.663-5.245 9.95-78.847 57.22-96.006 100.964-107.256 21.008-5.412 62.901-26.489 57.822-53.668-10.596-9.819-21.113-23.39-22.946-43.63l-1.274.026c-2.932-.044-5.778-.716-8.422-2.217-5.848-3.325-9.051-9.697-10.596-16.958-3.238-22.186-4.058-33.515 7.768-38.464l.096-.035c-1.467-27.37 3.159-67.64-24.944-76.141C154.622 7.1 218.597-30.203 266.627 30.805c53.519 2.801 77.389 78.611 44.154 121.046h-1.405c11.826 4.949 10.045 17.674 7.767 38.464-1.544 7.261-4.747 13.633-10.595 16.958-2.645 1.501-5.481 2.173-8.422 2.217l-1.275-.026c-1.833 20.24-12.376 33.811-22.972 43.63-4.459 23.871 27.275 43.011 49.33 50.997a139.442 139.442 0 004.268 5.525c-7.2 9.941-8.771 22.797-4.564 34.038-17.002 8.763-24.255 29.334-16.479 46.86-11.966 7.55-18.258 21.305-16.609 34.955H6.206zm419.058-105.362a86.778 86.778 0 0019.446-1.641c29.36-5.822 53.152-27.467 62.657-55.823 3.596-10.544 5.071-21.663 4.521-33.341-1.179-23.46-12.193-46.633-29.631-62.369-17.107-15.361-38.342-23.574-61.383-23.042-22.841.507-45.359 11.216-60.187 28.593-14.977 17.551-22.003 39.144-20.921 62.133.585 11.661 3.482 23.016 8.737 34.074 7.741 16.303 19.934 29.735 35.391 39.048l-22.457 20.711 13.232 27.86-29.413 13.973 13.991 29.456-26.769 12.717 16.81 35.374 35.601-16.915 40.375-110.808zm15.239-129.364c13.685 4.869 20.824 19.908 15.954 33.593-4.87 13.685-19.908 20.833-33.593 15.963-13.685-4.87-20.834-19.917-15.963-33.602 4.87-13.685 19.917-20.825 33.602-15.954z\"/></svg>',\n)}`;\n\nexport type PasskeyWalletOptions = PasskeyConnectorOptions;\n\nexport const passkeyWallet = (opts: PasskeyWalletOptions) => (): Wallet => ({\n id: \"passkey\",\n name: \"Passkey\",\n iconUrl,\n iconBackground: \"#fec\",\n createConnector: (walletDetails) => (config) => ({\n ...passkeyConnector(opts)(config),\n ...walletDetails,\n }),\n});\n","import { WalletList, connectorsForWallets } from \"@rainbow-me/rainbowkit\";\nimport { getWallets } from \"./getWallets\";\nimport { CreateConnectorFn } from \"wagmi\";\n\nexport function getConnectors({\n wallets,\n ...config\n}: {\n readonly chainId: number;\n /**\n * WalletConnect project ID, obtained from your WalletConnect dashboard.\n */\n // TODO: make optional and hide wallet options if so?\n readonly walletConnectProjectId: string;\n readonly appName: string;\n} & { readonly wallets?: WalletList }): CreateConnectorFn[] {\n return connectorsForWallets(wallets ?? getWallets(config), {\n appName: config.appName,\n projectId: config.walletConnectProjectId,\n });\n}\n","import { WalletList, getDefaultWallets } from \"@rainbow-me/rainbowkit\";\nimport { passkeyWallet } from \"./passkey/passkeyWallet\";\n\nexport function getWallets(config: { readonly chainId: number }): WalletList {\n const { wallets: defaultWallets } = getDefaultWallets();\n return [\n {\n groupName: \"Recommended\",\n wallets: [\n passkeyWallet({\n // TODO: allow any chain ID\n chainId: config.chainId,\n }),\n ],\n },\n ...defaultWallets,\n ];\n}\n"],"mappings":"AAGO,SAASA,GAAaC,EAA4C,CACvE,MAAO,CACL,GAAGA,EACH,QAASA,EAAM,SAAW,SAAS,MACnC,QAASA,EAAM,SAAW,SAAS,cAAc,mBAAmB,GAAG,aAAa,MAAM,GAAK,aACjG,CACF,CCRA,OAAS,QAAQC,GAAY,gBAAAC,GAAc,iBAAAC,OAAqB,yBCDhE,OAA8C,cAAAC,GAAY,aAAAC,GAAW,UAAAC,GAAQ,YAAAC,OAAgB,QAC7F,OAAOC,OAAc;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAErB,OAAS,qBAAAC,OAAyB,cAClC,OAAS,aAAAC,OAAiB,mBCJ1B,OAAS,iBAAAC,GAAe,cAAAC,OAAkC,QAiBjD,cAAAC,OAAA,oBAVT,IAAMC,GAAUH,GAAmC,IAAI,EAOhD,SAASI,GAAc,CAAE,MAAAC,EAAO,SAAAC,CAAS,EAAU,CAExD,GADcL,GAAWE,EAAO,EACrB,MAAM,IAAI,MAAM,wCAAwC,EACnE,OAAOD,GAACC,GAAQ,SAAR,CAAiB,MAAO,CAAE,MAAAE,CAAM,EAAI,SAAAC,EAAS,CACvD,CClBA,OAAS,iBAAAC,OAAqB,cCA9B,MAAO,oCACP,OAAS,iBAAAC,GAAe,cAAAC,OAAkC,QAC1D,OAAS,sBAAAC,GAAoB,cAAAC,GAAY,iBAAAC,OAAqB,yBAG9D,OAAS,aAAAC,OAAiB,QCL1B,OAAgB,2BAAAC,OAA+B,OAExC,SAASC,EAAoBC,EAAc,CAChD,OAAOF,GAAwB,CAAE,MAAAE,EAAO,SAAU,iBAAkB,CAAC,CACvE,CDkDM,cAAAC,OAAA,oBAxCN,IAAMC,GAAUC,GAAmC,IAAI,EAOhD,SAASC,GAAuB,CAAE,OAAAC,EAAQ,SAAAC,CAAS,EAAU,CAElE,GADsBC,GAAWL,EAAO,EACrB,MAAM,IAAI,MAAM,2CAA2C,EAK9E,IAAMM,EADSC,GAAU,EACJ,KAAK,CAAC,CAAE,GAAAC,CAAG,IAAMA,IAAOL,EAAO,OAAO,EAC3D,GAAI,CAACG,EAAO,MAAM,IAAI,MAAM,gDAAgDH,EAAO,UAAU,EAE7F,IAAMM,EAAmBC,EAAoBJ,CAAK,EAElD,OACEP,GAACY,GAAA,CAIC,aAAc,EACd,QAAS,CACP,QAASR,EAAO,OAElB,EACA,MACEA,EAAO,QAAU,QACbS,GAAW,CAAE,aAAc,MAAO,CAAC,EACnCT,EAAO,QAAU,OACfU,GAAc,CAAE,aAAc,MAAO,CAAC,EACtC,CACE,UAAWD,GAAW,CAAE,aAAc,MAAO,CAAC,EAC9C,SAAUC,GAAc,CAAE,aAAc,MAAO,CAAC,CAClD,EAGR,SAAAd,GAACC,GAAQ,SAAR,CAAiB,MAAO,CAAE,GAAGG,EAAQ,MAAAG,EAAO,iBAAAG,CAAiB,EAAI,SAAAL,EAAS,EAC7E,CAEJ,CAEO,SAASU,GAAkC,CAChD,IAAMX,EAASE,GAAWL,EAAO,EACjC,GAAI,CAACG,EAAQ,MAAM,IAAI,MAAM,mEAAmE,EAChG,OAAOA,CACT,CD5DO,SAASY,IAAW,CACzB,GAAM,CAAE,MAAOC,CAAa,EAAIC,EAAkB,EAC5CC,EAAWC,GAAc,8BAA8B,EAE7D,OADcH,IAAiBE,EAAW,OAAS,QAErD,CFaS,cAAAE,EA8DG,QAAAC,OA9DH,oBART,SAASC,GAAQ,CACf,OAAAC,EACA,GAAGC,CACL,EAE+B,CAC7B,IAAMC,EAAMC,GAA8B,IAAI,EAC9C,OAAAC,GAAkB,CAAE,IAAAF,EAAK,SAAUF,CAAO,CAAC,EACpCH,EAAC,OAAI,IAAKK,EAAM,GAAGD,EAAO,MAAO,CAAE,GAAGA,EAAM,MAAO,QAAS,aAAc,EAAG,CACtF,CAKO,IAAMI,EAASC,GAAqC,SAAgB,CAAE,KAAAC,EAAM,SAAAC,CAAS,EAAGC,EAAc,CAC3G,IAAMC,EAAWP,GAAiC,IAAI,EAChD,CAACQ,EAAQC,CAAS,EAAIC,GAAS,EAAK,EACpCC,EAAQH,EAASD,EAAS,QAAU,KAEpC,CAACK,EAAWC,CAAY,EAAIH,GAAoE,CACpG,MAAO,OACP,OAAQ,MACV,CAAC,EAEKI,EAAgBH,GAAO,gBACvBI,EAAQC,GAAS,EACvBC,GAAU,IAAM,CACVH,GACFA,EAAc,KAAK,aAAa,aAAcC,CAAK,CAEvD,EAAG,CAACD,EAAeC,CAAK,CAAC,EAEzB,IAAMG,EACJd,IAAS,QACL,CACE,IAAK,QACL,QAAS,QACT,SAAU,QACV,MAAO,IACP,MAAO,OACP,OAAQ,OACR,OAAQ,YACV,EACAQ,EAAU,OAASA,EAAU,OAC3B,CACE,IAAK,QACL,QAAS,cACT,MAAO,GAAGA,EAAU,UACpB,OAAQ,GAAGA,EAAU,UACvB,EACA,CACE,IAAK,QACL,QAAS,QACT,SAAU,QACV,MAAO,IACP,MAAO,OACP,OAAQ,OACR,QAAS,EACT,cAAe,MACjB,EAER,OACElB,EAAC,UACC,IAAKyB,GAAU,CAACb,EAAcC,CAAQ,CAAC,EACvC,MAAOW,EACP,OAAQ,IAAMT,EAAU,EAAI,EAC5B,OAAO,uCAEN,SAAAK,EACGM,GAAS,aACPzB,GAAC0B,GAAA,CAAc,MAAOV,EAKpB,UAAAjB,EAAC,OAAK,SAAAU,IAAS,QAAUC,EAAWX,EAACE,GAAA,CAAQ,OAAQiB,EAAe,SAAAR,EAAS,EAAW,EACxFX,EAAC,SAAM,wBAAyB,CAAE,OAAQ4B,EAAI,EAAG,GACnD,EACAR,EAAc,IAChB,EACA,KACN,CAEJ,CAAC,ED7FD,OAAS,WAAAS,OAAe,iBAahB,OAKE,OAAAC,EALF,QAAAC,OAAA,oBALD,SAASC,GAAM,CAAE,KAAAC,EAAM,aAAAC,EAAc,SAAAC,CAAS,EAAU,CAC7D,OACEL,EAACM,GAAA,CAAW,KAAMH,EAAM,aAAcC,EAEpC,SAAAJ,EAACO,GAAA,CACC,SAAAN,GAACO,EAAA,CAAO,KAAK,QAKX,UAAAR,EAAC,OAAI,UAAWD,GAAQ,gBAAiB,oBAAqB,yCAAyC,EAAG,EAC1GC,EAAC,OACC,UAAWD,GACT,gBACA,iCACA,iEACF,EAEA,SAAAC,EAAC,OACC,SAAAA,EAACS,GAAA,CACC,UAAU,4CAEV,mBAAkB,OAClB,gBAAkBC,GAAU,CAC1BA,EAAM,eAAe,CACvB,EAEC,SAAAL,EACH,EACF,EACF,GACF,EACF,EACF,CAEJ,CM9CA,OAAS,eAAAM,GAAa,WAAAC,OAAe,QACrC,OAAS,YAAAC,OAAgB,UACzB,OAAS,eAAAC,OAAmB,kBAE5B,IAAMC,EAAQD,GAAY,KAAO,CAAE,KAAM,EAAM,EAAE,EAS1C,SAASE,GAAyC,CACvD,IAAMC,EAAmBJ,GAASE,EAAQG,GAAUA,EAAM,IAAI,EAExDC,EAAmBR,GAAY,IAAM,CACzCI,EAAM,SAAS,CAAE,KAAM,EAAK,CAAC,CAC/B,EAAG,CAAC,CAAC,EAECK,EAAoBT,GAAY,IAAM,CAC1CI,EAAM,SAAS,CAAE,KAAM,EAAM,CAAC,CAChC,EAAG,CAAC,CAAC,EAECM,EAAqBV,GAAaW,GAAkB,CACxDP,EAAM,SAAS,CAAE,KAAMO,CAAK,CAAC,CAC/B,EAAG,CAAC,CAAC,EAEL,OAAOV,GACL,KAAO,CACL,iBAAAK,EACA,iBAAAE,EACA,kBAAAC,EACA,mBAAAC,CACF,GACA,CAACJ,EAAkBE,EAAkBC,EAAmBC,CAAkB,CAC5E,CACF,CCnCA,OAAS,WAAAE,OAAe,iBCFxB,OAAS,cAAAC,GAAY,sBAAAC,OAA0B,QCA/C,OAAS,cAAAC,OAAkB,QCE3B,OAAS,WAAAC,MAAe,iBCDxB,OAAS,WAAAC,OAAe,iBAMpB,OAOE,OAAAC,GAPF,QAAAC,OAAA,oBAFG,SAASC,EAAY,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAU,CAC1D,OACEH,GAAC,OACC,UAAWF,GAAQ,mDAAoDI,CAAS,EAChF,MAAM,6BACN,KAAK,OACL,QAAQ,YACP,GAAGC,EAEJ,UAAAJ,GAAC,UAAO,UAAU,aAAa,GAAG,KAAK,GAAG,KAAK,EAAE,KAAK,OAAO,eAAe,YAAY,IAAI,EAC5FA,GAAC,QACC,UAAU,aACV,KAAK,eACL,EAAE,kHACJ,GACF,CAEJ,CDwBM,OAGM,OAAAK,EAHN,QAAAC,OAAA,oBAjCN,IAAMC,GAAkB,CAAC,CAAE,QAAAC,EAAU,WAAY,EAA4B,CAAC,IAC5EC,EACE,iFACA,wDACA,0BACA,kEAEA,2BACA,wBACA,CACE,QAASA,EAAQ,kDAAkD,EACnE,UAAWA,EAAQ,mDAAmD,EACtE,SAAUA,EAAQ,mDAAmD,CACvE,EAAED,CAAO,CACX,EASWE,EAAS,CAAC,CAAE,QAAAC,EAAS,QAAAH,EAAS,KAAAI,EAAM,UAAAC,EAAW,SAAAC,EAAU,SAAAC,EAAU,GAAGC,CAAM,IAErFX,EAAC,UACC,KAAMO,GAAQ,SACd,UAAWH,EAAQF,GAAgB,CAAE,QAAAC,EAAS,QAAAG,CAAQ,CAAC,EAAGE,CAAS,EACnE,YAAWF,EACX,gBAAeI,EACf,SAAUA,GAAYJ,EACrB,GAAGK,EAEJ,SAAAV,GAAC,QAAK,UAAU,sCACd,UAAAD,EAAC,QAAK,UAAU,6CACd,SAAAA,EAAC,QAAK,UAAU,8JACd,SAAAA,EAACY,EAAA,EAAY,EACf,EACF,EACAZ,EAAC,QAAM,SAAAS,EAAS,GAClB,EACF,EDnDJ,OAAS,mBAAAI,OAAuB,yBAChC,OAAS,eAAAC,OAAmB,wBGJ5B,OAAS,iBAAAC,OAAqB,QCA9B,OACE,gBAAAC,GACA,UAAAC,GAGA,cAAAC,GACA,eAAAC,GACA,oBAAAC,OAGK,OACP,OAAS,2BAAAC,GAAyB,mBAAAC,OAA0C,QCX5E,OAAS,eAAAC,OAAmB,kBAC5B,OAAS,WAAAC,OAAe,qBAajB,IAAMC,EAAQF,GACnBC,GACE,KAAO,CACL,WAAY,CAAC,EACb,iBAAkB,IACpB,GACA,CAAE,KAAM,cAAe,CACzB,CACF,EAGA,SAASE,GAASC,EAAqB,CACjCA,EAAM,MAAQF,EAAM,QAAQ,WAAW,EAAE,MAC3CA,EAAM,QAAQ,UAAU,CAE5B,CACA,OAAO,iBAAiB,UAAWC,EAAQ,EDjB3C,OAAS,uBAAAE,OAA2B,yBEVpC,OAAS,0BAAAC,OAAgE,8BCFzE,OAAS,eAAAC,GAAa,iBAAAC,OAAqB,OAG3C,OAAS,gBAAAC,OAAoB,0BAsBtB,SAASC,GAAkBC,EAA0D,CAC1F,GAAM,CAAE,GAAAC,EAAI,UAAAC,CAAU,EAAIF,EAAW,WACrC,MAAO,CACL,UAAAE,EACA,MAAM,KAAK,CAAE,KAAAC,CAAK,EAAG,CACnB,IAAMC,EAAS,MAAMN,GAAa,CAAE,QAAS,6BAAyB,IAAKE,EAAW,SAAU,CAAC,EACjG,GAAI,CACF,GAAM,CAAE,UAAAK,EAAW,SAAUC,CAAS,EAAI,MAAMF,EAAO,QAAQ,OAAQ,CAAE,aAAcH,EAAI,UAAWE,CAAK,CAAC,EAC5G,MAAO,CACL,UAAAE,EACA,SAAAC,EACA,IAAK,CAAE,GAAAL,CAAG,CACZ,CACF,QAAE,CACAG,EAAO,MAAM,CACf,CACF,EACA,MAAM,YAAY,CAAE,QAAAG,CAAQ,EAAG,CAC7B,OAAO,KAAK,KAAK,CAAE,KAAMX,GAAYW,CAAO,CAAE,CAAC,CACjD,EACA,MAAM,cAAcP,EAAY,CAC9B,OAAO,KAAK,KAAK,CAAE,KAAMH,GAAcG,CAAU,CAAE,CAAC,CACtD,EACA,KAAM,UACR,CACF,CD5CA,eAAsBQ,EACpBC,EACAC,EAC2C,CAC3C,GAAM,CAAE,WAAAC,CAAW,EAAIC,EAAM,SAAS,EAEhCC,EAAYF,EAAWD,CAAE,EAE/B,GAAI,CAACG,EACH,MAAM,IAAI,MAAM,6CAA6C,EAI/D,IAAMC,EAAS,CADCC,GAAkB,CAAE,WAAY,CAAE,GAAAL,EAAI,UAAAG,CAAU,EAAG,UAAYJ,EAAO,MAAmB,QAAS,CAAC,CAC5F,EAEvB,OAAO,MAAMO,GAAuB,CAAE,OAAAP,EAAQ,OAAAK,CAAO,CAAC,CACxD,CEvBA,OAAS,cAAAG,GAAY,eAAAC,OAAmB,OCAxC,OAAS,cAAAC,GAAiB,cAAAC,OAAgC,gBAC1D,OAAS,eAAAC,GAAa,eAAAC,OAAmB,+BAKzC,eAAsBC,GACpBC,EAIsB,CACtB,GAAM,CACJ,kBAAAC,EACA,eAAgBC,EAChB,eAAAC,EACA,UAAWC,EACX,yBAAAC,CACF,EAAIL,EAEEM,EAAYF,GAAgBD,EAAe,QAAQ,QAAQ,EAC3DI,EAAiBL,GAAqBC,EAAe,QAAQ,aAAa,EAE1EK,EAAyBZ,GAAWK,CAAiB,EAG3D,GAAIO,EAAuB,OAAS,GAAI,MAAM,IAAI,MAAM,2BAA2B,EAEnF,IAAMC,EAAOD,EAAuB,EAAE,EAGtC,IAAKC,EAAO,KAAU,EAAM,MAAM,IAAI,MAAM,2BAA2B,EAKvE,GAAIJ,IAA6BI,EAAO,KAAU,EAAM,MAAM,IAAI,MAAM,2BAA2B,EAInG,IAAKA,EAAO,KAAU,IAASA,EAAO,MAAU,GAAM,MAAM,IAAI,MAAM,2BAA2B,EAGjG,IAAMC,EAAO,wBACb,GAAIA,IAASP,EAAe,MAAM,OAAOG,CAAS,EAAGI,EAAK,OAAS,CAAC,EAAG,MAAM,IAAI,MAAM,wBAAwB,EAI/G,GAAI,CADUP,EAAe,MAAM,OAAOI,CAAc,CAAC,EAAE,MAAM,sBAAsB,EAC3E,MAAM,IAAI,MAAM,wBAAwB,EAGpD,IAAMI,EAAqB,IAAI,WAAW,MAAM,OAAO,OAAO,OAAO,UAAWb,GAAYK,CAAc,CAAC,CAAC,EACtGS,EAAc,IAAI,WACtB,MAAM,OAAO,OAAO,OAAO,UAAWf,GAAYD,GAAWK,CAAiB,EAAGU,CAAkB,CAAC,CACtG,EAEA,OAAOhB,GAAWiB,CAAW,CAC/B,CCzDA,OAAS,kBAAAC,GAAgB,sBAAAC,OAA0B,gBAEnD,OAAS,aAAAC,OAAiB,qBAEnB,SAASC,GAAuBC,EAA4B,CACjE,GAAM,CAAE,EAAAC,EAAG,EAAAC,CAAE,EAAIN,GAAeI,EAAM,YAAY,EAE5CG,EAAa,IAAIL,GAAU,UAAUG,EAAGC,CAAC,EAAE,eAAe,CAAC,EAAE,iBAAiBF,EAAM,YAAY,MAAM,CAAC,CAAC,EACxGI,EAAa,IAAIN,GAAU,UAAUG,EAAGC,CAAC,EAAE,eAAe,CAAC,EAAE,iBAAiBF,EAAM,YAAY,MAAM,CAAC,CAAC,EAE9G,MAAO,CAACH,GAAmBM,CAAU,EAAGN,GAAmBO,CAAU,CAAC,CACxE,CCPO,SAASC,GAAc,CAACC,EAAQC,CAAM,EAAgE,CAE3G,OAAOC,GAAe,CAAC,GAAGC,GAAuBH,CAAM,EAAG,GAAGG,GAAuBF,CAAM,CAAC,CAAC,CAC9F,CAEA,SAASC,GAAkBE,EAAyB,CAClD,IAAMC,EAAO,IAAI,IACjB,QAAWC,KAAKF,EAAK,CACnB,GAAIC,EAAK,IAAIC,CAAC,EACZ,OAAOA,EAETD,EAAK,IAAIC,CAAC,EAGd,CHdA,OAA4B,gBAAAC,OAAoB,0BAGhD,eAAsBC,GAAaC,EAA6C,CAC9E,IAAMC,EAAS,MAAMH,GAAa,CAAE,IAAKE,EAAM,SAAU,QAAS,kBAAc,CAAC,EACjF,GAAI,CACF,IAAME,EAAYC,GAAYC,GAAW,OAAO,gBAAgB,IAAI,WAAW,GAAG,CAAC,CAAC,CAAC,EAC/E,CAAE,aAAAC,EAAc,UAAAC,EAAW,SAAAC,CAAS,EAAI,MAAMN,EAAO,QAAQ,OAAQ,CAAE,UAAAC,CAAU,CAAC,EAElFM,EAAY,MAAO,SAAY,CACnC,IAAMC,EAAkBC,EAAM,SAAS,EAAE,WAAWL,CAAY,EAChE,GAAII,EAAiB,OAAOA,EAI5B,IAAME,EAAc,MAAMC,GAAeL,CAAQ,EAC3CM,EAAaV,GAAYG,CAAS,EAClCQ,EAAa,MAAMb,EAAO,QAAQ,OAAQ,CAAE,aAAAI,EAAc,UAAWQ,CAAW,CAAC,EACvF,GAAIC,EAAW,eAAiBT,EAC9B,MAAM,IAAI,MAAM,kBAAkB,EAGpC,IAAMG,EAAYO,GAAc,CAC9B,CAAE,YAAAJ,EAAa,aAAcL,CAAU,EACvC,CAAE,YAAa,MAAMM,GAAeE,EAAW,QAAQ,EAAG,aAAcA,EAAW,SAAU,CAC/F,CAAC,EACD,GAAI,CAACN,EACH,MAAM,IAAI,MAAM,iBAAiB,EAGnC,OAAAE,EAAM,SAAUM,IAAW,CACzB,WAAY,CACV,GAAGA,EAAM,WACT,CAACX,CAAY,EAAGG,CAClB,CACF,EAAE,EAEKA,CACT,GAAG,EAEH,eAAQ,IAAI,oBAAqBH,EAAcG,CAAS,EAExDE,EAAM,SAAS,KAAO,CACpB,iBAAkBL,CACpB,EAAE,EAEK,CAAE,aAAAA,EAAc,UAAAG,CAAU,CACnC,QAAE,CACAP,EAAO,MAAM,CACf,CACF,CIrDA,OAAS,gBAAAgB,OAAuC,0BAGhD,eAAsBC,GAAcC,EAA6C,CAC/E,IAAMC,EAAS,MAAMH,GAAa,CAAE,IAAKE,EAAM,SAAU,QAAS,wBAAoB,CAAC,EACvF,GAAI,CACF,IAAME,EAAa,MAAMD,EAAO,QAAQ,QAAQ,EAChD,eAAQ,IAAI,kBAAmBC,CAAU,EAEzCC,EAAM,SAAUC,IAAW,CACzB,iBAAkBF,EAAW,aAC7B,WAAY,CACV,GAAGE,EAAM,WACT,CAACF,EAAW,YAAY,EAAGA,EAAW,SACxC,CACF,EAAE,EAEKA,CACT,QAAE,CACAD,EAAO,MAAM,CACf,CACF,CCtBA,OAAS,iBAAAI,OAAqB,qBAC9B,OAA4C,YAAAC,OAAuC,OACnF,OAAOC,OAAiB,+BAKjB,IAAMC,EAAsB,CACjC,gBAAiB,GACnB,EAEaC,EAA+BJ,GAAc,CAAE,KAAM,SAAU,UAAW,GAAI,KAAM,WAAY,CAAC,EAEjGK,GAAcH,GAAY,WAAW,MAAM,OAE3CI,GAAWL,GAAS,CAC/B,iGACF,CAAC,EChBD,OAIE,uBAAuBM,OAClB,2BAGP,IAAMC,GAAiB,IAAI,IAAI,CAI7B,MAEA,MAEA,MAEA,GACF,CAAC,EAEM,SAASC,EAMd,CACA,iBAAAC,EACA,GAAGC,CACL,EAME,CACA,IAAMC,EAAQD,EAAO,OAASA,EAAO,QAAQ,MAC7C,OAAOE,GAAyB,CAC9B,GAAGC,EACH,UAAW,CACT,iBAAkB,UAAa,CAC7B,UAAWJ,EACX,cAAe,IACjB,EACF,EAEA,cAAe,CACb,mBAEEE,GAASJ,GAAe,IAAII,EAAM,EAAE,EAChC,UAAa,CACX,aAAc,QACd,qBAAsB,EACxB,GACA,MACR,EACA,GAAGD,CACL,CAAC,CACH,CVzCA,OAAS,YAAAI,OAAgB,gCWnBzB,OAAS,oBAAAC,OAAwB,6BACjC,OAAgB,gBAAAC,GAAc,YAAAC,GAAU,QAAAC,GAAM,aAAAC,OAAiB,OAC/D,OAAS,uBAAAC,GAAqB,sBAAAC,OAA0B,gBACxD,OAAS,WAAAC,OAAe,+BACxB,OAAS,gBAAAC,GAAc,kBAAAC,OAAsB,iCAEtC,SAASC,EAAoBC,EAAc,CAChD,IAAMC,EAAiBD,EAAM,QAAQ,SAAS,KAAK,CAAC,EAE9CE,EAAmBD,EACrBJ,GAAaD,GAAQJ,GAAKS,CAAc,CAAC,CAAC,EAC1CD,EAAM,KAAO,MACXF,GAAe,CACb,SAAUR,GAAa,CACrB,MAAAU,EACA,UAAWT,GAAS,CAACE,GAAU,EAAGD,GAAK,CAAC,CAAC,EACzC,QAASE,GAAoBC,GAAmB,CAAC,CACnD,CAAC,EAAE,OAAON,GAAiB,CAAC,CAC9B,CAAC,EACD,KACN,GAAI,CAACa,EACH,MAAM,IAAI,MAAM,SAASF,EAAM,8CAA8C,EAE/E,OAAOE,CACT,CXFA,OAAS,WAAAC,OAAe,+BAuBxBC,EAAiB,KAAO,UAEjB,SAASA,EAAiB,CAAE,QAAAC,CAAQ,EAAoD,CAC7F,OAAOC,GAAiBC,GAAW,CAEjC,GAAI,CAACA,EAAO,WACV,MAAM,IAAI,MAAM,wEAAwE,EAG1F,IAAMC,EAAQD,EAAO,OAAO,KAAME,GAAMA,EAAE,KAAOJ,CAAO,EACxD,GAAI,CAACG,EAAO,MAAM,IAAI,MAAM,gDAAgDH,IAAU,EAKtF,IAAMK,EAAkBH,EAAO,WAAWC,EAAM,EAAE,EAClD,GAAI,CAACE,EACH,MAAM,IAAI,MAAM,oDAAoDL,IAAU,EAEhF,IAAMM,EAAYR,GAAQO,CAAe,EAEnCE,EAAmBC,EAAoBL,CAAK,EAC5CM,EAAmBC,EAAoBP,CAAK,EAE5CQ,EAASC,GAAa,CAAE,GAAGC,EAAqB,MAAAV,EAAO,UAAAG,CAAU,CAAC,EAEpEQ,EAAYC,EAAM,SAAS,EAAE,kBAAoB,KAErD,MAAO,CACL,GAAI,UACJ,KAAMhB,EAAiB,KACvB,KAAM,UAIN,MAAM,eAAgB,CACpB,GAAM,CAAE,aAAAiB,CAAa,EAAI,MAAMC,GAAcd,CAAK,EAC5Ce,EAAU,MAAMC,EAAWR,EAAQK,CAAY,EACrD,KAAK,kBAAkB,CAACE,EAAQ,OAAO,CAAC,EACxC,KAAK,YAAY,CAAE,QAASE,GAAYpB,CAAO,CAAE,CAAC,CACpD,EACA,MAAM,cAAe,CACnB,GAAM,CAAE,aAAAgB,CAAa,EAAI,MAAMK,GAAalB,CAAK,EAC3Ce,EAAU,MAAMC,EAAWR,EAAQK,CAAY,EACrD,KAAK,kBAAkB,CAACE,EAAQ,OAAO,CAAC,EACxC,KAAK,YAAY,CAAE,QAASE,GAAYpB,CAAO,CAAE,CAAC,CACpD,EACA,YAAa,CACX,OAAO,OAAO,KAAKe,EAAM,SAAS,EAAE,UAAU,EAAE,OAAS,CAC3D,EAEA,MAAM,QAAQO,EAAQ,CAGpB,GAFA,QAAQ,IAAI,SAAS,EAEjBA,GAAQ,SAAW,MAAQA,EAAO,UAAYtB,EAChD,MAAM,IAAI,MAAM,0BAA0BsB,EAAO,gDAAgDtB,IAAU,EAKzG,CAACe,EAAM,SAAS,EAAE,kBAAoB,CAACO,GAAQ,gBACjD,MAAMD,GAAalB,CAAK,EAG1B,IAAMoB,EAAW,MAAM,KAAK,YAAY,EACxC,OAAAT,EAAYS,EAAS,OAAS,EAEvB,CAAE,SAAAA,EAAU,QAAAvB,CAAQ,CAC7B,EACA,MAAM,YAAa,CACjB,QAAQ,IAAI,YAAY,EACxBc,EAAY,GACZC,EAAM,SAAS,CAAE,iBAAkB,IAAK,CAAC,CAC3C,EACA,MAAM,aAAc,CAClB,QAAQ,IAAI,aAAa,EACzB,IAAMS,EAAKT,EAAM,SAAS,EAAE,iBAC5B,GAAI,CAACS,EAAI,MAAO,CAAC,EAEjB,GAAI,CACF,QAAQ,IAAI,iCAAkCA,CAAE,EAChD,IAAMN,EAAU,MAAMC,EAAWR,EAAQa,CAAE,EAC3C,eAAQ,IAAI,cAAeN,CAAO,EAC3B,CAACA,EAAQ,OAAO,CACzB,MAAE,CACA,QAAQ,IAAI,0CAA2CM,CAAE,CAC3D,CAEA,MAAO,CAAC,CACV,EACA,MAAM,YAAa,CACjB,OAAOxB,CACT,EACA,MAAM,cAAe,CAEnB,OADA,QAAQ,IAAI,cAAc,EACrBc,GACY,MAAM,KAAK,YAAY,GACxB,OAAS,EAFF,EAGzB,EACA,MAAM,YAAYQ,EAAQ,CAExB,GAAIA,EAAO,UAAYtB,EACrB,MAAM,IAAI,MAAM,0BAA0BsB,EAAO,gDAAgDtB,IAAU,EAG7G,IAAMG,EAAQD,EAAO,OAAO,KAAME,GAAMA,EAAE,KAAOkB,EAAO,OAAO,EAC/D,GAAI,CAACnB,EAAO,MAAM,IAAIsB,GAAiB,IAAIC,EAAyB,EACpE,OAAOvB,CACT,EACA,kBAAkBoB,EAAU,CAC1B,QAAQ,IAAI,mBAAmB,EAC3BA,EAAS,OAAS,EACpBrB,EAAO,QAAQ,KAAK,SAAU,CAC5B,SAAUqB,EAAS,IAAKI,GAAMC,GAAWD,CAAC,CAAC,CAC7C,CAAC,EAED,KAAK,aAAa,CAEtB,EACA,eAAe3B,EAAS,CACtB,QAAQ,IAAI,gBAAgB,EAC5BE,EAAO,QAAQ,KAAK,SAAU,CAAE,QAAS,OAAOF,CAAO,CAAE,CAAC,CAC5D,EACA,MAAM,UAAU6B,EAAc,CAC5B,QAAQ,IAAI,WAAW,EACvB,IAAMN,EAAW,MAAM,KAAK,YAAY,EACxCrB,EAAO,QAAQ,KAAK,UAAW,CAAE,SAAAqB,EAAU,QAAAvB,CAAQ,CAAC,CACtD,EACA,MAAM,aAAa8B,EAAQ,CACzB,QAAQ,IAAI,cAAc,EAC1B5B,EAAO,QAAQ,KAAK,YAAY,EAChCY,EAAY,EACd,EAWA,MAAM,UAAUQ,EAAQ,CACtB,QAAQ,IAAI,6BAA8BA,CAAM,EAEhD,IAAMN,EAAeD,EAAM,SAAS,EAAE,iBACtC,GAAI,CAACC,EAAc,MAAM,IAAI,MAAM,gBAAgB,EAEnD,IAAME,EAAU,MAAMC,EAAWR,EAAQK,CAAY,EAErD,OAAOe,EAAoB,CACzB,iBAAAxB,EACA,UAAWE,EACX,OAAAE,EACA,QAAAO,CACF,CAAC,EACE,OAAOc,GAAoB,CAAC,EAC5B,OAAOC,GAAS,CAAC,CACtB,EAEA,MAAM,YAAYC,EAAS,CAGzB,OAAOC,GAAO,CAAE,QAASxB,EAAO,UAAU,OAAQ,CAAC,EAAE,CAAE,WAAY,CAAE,CAAC,CACxE,CACF,CACF,CAAC,CACH,CDlNO,SAASyB,IAAwC,CAEtD,IAAMC,EADaC,GAAc,EACJ,KAAMC,GAAMA,EAAE,OAASC,EAAiB,IAAI,EACzE,GAAI,CAACH,EAEH,MAAM,IAAI,MACR,kHACF,EAEF,OAAOA,CACT,CaZA,OAAS,WAAAI,OAAe,iBAMpB,OASE,OAAAC,GATF,QAAAC,OAAA,oBAFG,SAASC,EAAK,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAU,CACnD,OACEH,GAAC,OACC,MAAM,6BACN,QAAQ,UACR,KAAK,eACL,eAAe,aACf,UAAWF,GAAQ,sCAAuCI,CAAS,EAClE,GAAGC,EAGJ,UAAAJ,GAAC,QAAK,EAAE,oNAAoN,EAC5NA,GAAC,QACC,EAAE,uIACF,QAAQ,KACV,EACAA,GAAC,QAAK,EAAE,sGAAsG,GAChH,CAEJ,CCxBA,OAAS,YAAAK,OAAgB,wBAElB,SAASC,EAAgBC,EAAyB,CACvD,OAAOF,GAAS,CACd,QAAS,CAAC,CAACE,EACX,MAAO,GACP,aAAc,GACd,eAAgB,GAChB,qBAAsB,GACtB,SAAU,CAAC,eAAgBA,CAAG,EAC9B,QAAS,IACP,IAAI,QAAoC,CAACC,EAASC,IAAW,CAC3D,GAAI,CAACF,EAAK,MAAM,IAAI,MAAM,uDAAuD,EACjF,IAAMG,EAAQ,IAAI,MAClBA,EAAM,OAAS,IAAMF,EAAQE,CAAK,EAClCA,EAAM,QAAU,IAAMD,EAAO,IAAI,MAAM;AAAA;AAAA,QAAoDF,GAAK,CAAC,EACjGG,EAAM,IAAMH,CACd,CAAC,CACL,CAAC,CACH,CCVI,OAIQ,OAAAI,EAJR,QAAAC,OAAA,oBALG,SAASC,IAAU,CACxB,GAAM,CAAE,QAAAC,EAAS,QAAAC,CAAQ,EAAIC,EAAkB,EACzC,CAAE,KAAMC,EAAY,UAAWC,CAAe,EAAIC,EAAgBJ,CAAO,EAE/E,OACEH,GAAC,OAAI,UAAU,4DACb,UAAAD,EAAC,OAAI,UAAU,gBACZ,SAACO,EAOE,KANFD,EACEN,EAAC,OAAI,IAAKI,EAAS,UAAU,6BAA6B,EAG1DJ,EAACS,EAAA,CAAK,UAAU,oDAAoD,EAG1E,EACAT,EAAC,OAAI,UAAU,kCAAmC,SAAAG,EAAQ,GAC5D,CAEJ,ClBhBA,OAAS,WAAAO,OAAe,iBAyBpB,cAAAC,EAkCE,QAAAC,OAlCF,oBAvBG,SAASC,IAAgB,CAC9B,IAAMC,EAAcC,GAAW,EACzB,CAAE,iBAAAC,CAAiB,EAAIC,EAAgB,EACvC,CAAE,iBAAAC,EAAkB,iBAAAC,CAAiB,EAAIC,GAAgB,EAKzDC,EAAmBC,GAAoB,EACvCC,EAAgBC,GAAY,CAChC,QAAUC,GAAU,QAAQ,MAAMA,CAAK,EACvC,YAAa,CAAC,gBAAiBJ,EAAiB,GAAIL,EAAkBG,EAAkBL,EAAY,MAAM,EAC1G,WAAY,IAAMO,EAAiB,cAAc,CACnD,CAAC,EACKK,EAAeF,GAAY,CAC/B,QAAUC,GAAU,QAAQ,MAAMA,CAAK,EACvC,YAAa,CAAC,eAAgBJ,EAAiB,GAAIL,EAAkBG,EAAkBL,EAAY,MAAM,EACzG,WAAY,IAAMO,EAAiB,aAAa,CAClD,CAAC,EAEKM,EAAaN,EAAiB,WAAW,EAEzCO,EAAU,CACdjB,EAACkB,EAAA,CAEC,QAASF,EAAa,WAAa,YACnC,UAAU,gCACV,QAASJ,EAAc,SAAW,WAAaA,EAAc,SAAW,UACxE,QAAS,IAAMA,EAAc,OAAO,EACpC,UAAW,CAACI,EACb,2BANK,QAQN,EACAhB,EAACkB,EAAA,CAEC,QAASF,EAAa,YAAc,WACpC,UAAU,gCACV,QAASD,EAAa,SAAW,WAAaA,EAAa,SAAW,UACtE,QAAS,IAAMA,EAAa,OAAO,EACnC,UAAWC,EACZ,oBANK,QAQN,CACF,EAEA,OAAIA,GACFC,EAAQ,QAAQ,EAIhBhB,GAAC,OACC,UAAWF,GAAQ,0BAA2B,gEAAgE,EAE9G,UAAAC,EAAC,OAAI,UAAU,MAEb,SAAAA,EAACmB,GAAA,EAAQ,EACX,EACAlB,GAAC,OAAI,UAAU,uCACZ,UAAAgB,EACDjB,EAAC,UACC,UAAU,uEACV,SAAUG,EAAY,SAAW,aAEjC,QAASI,EACV,kCAED,GACF,GACF,CAEJ,CmB/EA,OAAS,aAAAa,GAAW,WAAAC,GAAS,UAAAC,GAAQ,YAAAC,OAAgB,QAErD,OAAS,WAAAC,OAAe,iBCDxB,OAAS,cAAAC,OAAkB,OAQpB,IAAMC,EAAgBD,GAAW,MAAM,ECP9C,OAAS,aAAAE,OAAiB,QAC1B,OAAS,gBAAAC,GAAc,YAAAC,OAAgB,wBCHvC,OAAS,eAAAC,OAAmB,oBAC5B,OAAS,YAAAC,OAAgB,OAKlB,IAAMC,GAAeD,GAAS,CACnC,uEACA,qDACA,2CACF,CAAC,EAEYE,GAAkBH,GAAY,CACzC,WAAY,CACV,KAAM,CACJ,UAAW,GACX,OAAQ,CACN,UAAW,CACT,OAAQ,CACN,KAAM,UACN,UAAW,SACb,EACA,IAAK,CAAC,MAAM,CACd,EACA,QAAS,CACP,OAAQ,CACN,QAAS,UACT,UAAW,SACb,EACA,IAAK,CAAC,SAAS,CACjB,EACA,WAAY,CACV,OAAQ,CACN,KAAM,UACN,OAAQ,UACR,YAAa,UACb,YAAa,SACf,EACA,IAAK,CAAC,OAAQ,QAAQ,CACxB,EACA,WAAY,CACV,OAAQ,CACN,OAAQ,UACR,YAAa,UACb,cAAe,UACf,eAAgB,UAChB,QAAS,SACX,EACA,IAAK,CAAC,QAAQ,CAChB,EACA,QAAS,CACP,OAAQ,CACN,QAAS,UACT,KAAM,SACR,EACA,IAAK,CAAC,SAAS,CACjB,EACA,aAAc,CACZ,OAAQ,CACN,WAAY,SACd,EACA,IAAK,CAAC,CACR,CACF,CACF,CACF,CACF,CAAC,EAEYI,EAAkBD,GAAgB,WAAW,KAAK,OClE/D,OAAS,aAAAE,OAAiB,6BAU1B,eAAsBC,GAAa,CAAE,OAAAC,EAAQ,iBAAAC,EAAkB,YAAAC,CAAY,EAAuB,CAOhG,OANe,MAAMJ,GAAUE,EAAQ,CACrC,QAASC,EACT,MAAOE,EAAgB,UACvB,IAAK,CAAE,KAAMD,CAAY,EACzB,SAAU,SACZ,CAAC,GACa,SAChB,CFdO,SAASE,GAAyB,CACvC,OAAAC,EACA,iBAAAC,EACA,YAAAC,CACF,EAIG,CACD,IAAMC,EAAW,CAAC,eAAgBH,GAAQ,MAAM,GAAIC,EAAkBC,CAAW,EACjF,OAAOE,GACLJ,GAAUE,EACN,CACE,SAAAC,EACA,QAAS,IAAME,GAAa,CAAE,OAAAL,EAAQ,iBAAAC,EAAkB,YAAAC,CAAY,CAAC,CACvE,EACA,CAAE,SAAAC,EAAU,QAAS,EAAM,CACjC,CACF,CAEO,SAASG,GAAaJ,EAAkC,CAC7D,GAAM,CAAE,QAAAK,EAAS,iBAAAN,CAAiB,EAAIO,EAAkB,EAClDR,EAASS,GAAU,CAAE,QAAAF,CAAQ,CAAC,EACpC,OAAOG,GAASX,GAAyB,CAAE,OAAAC,EAAQ,iBAAAC,EAAkB,YAAAC,CAAY,CAAC,CAAC,CACrF,CG5BA,OAAS,aAAAS,OAAiB,QAC1B,OAAS,gBAAAC,GAAc,YAAAC,OAAgB,wBCDvC,OAAS,aAAAC,OAAiB,6BAS1B,eAAsBC,GAAW,CAAE,OAAAC,EAAQ,iBAAAC,EAAkB,YAAAC,EAAa,eAAAC,CAAe,EAAqB,CAO5G,OANe,MAAML,GAAUE,EAAQ,CACrC,QAASC,EACT,MAAOG,EAAgB,QACvB,IAAK,CAAE,QAASD,CAAe,EAC/B,SAAU,SACZ,CAAC,GACa,KAAK,YAAY,IAAMD,EAAY,YAAY,CAC/D,CDbO,SAASG,GAAuB,CACrC,OAAAC,EACA,iBAAAC,EACA,YAAAC,EACA,eAAAC,CACF,EAKG,CACD,IAAMC,EAAW,CAAC,aAAcJ,GAAQ,MAAM,GAAIC,EAAkBC,EAAaC,CAAc,EAC/F,OAAOE,GACLL,GAAUE,GAAeC,EACrB,CACE,SAAAC,EACA,QAAS,IAAME,GAAW,CAAE,OAAAN,EAAQ,iBAAAC,EAAkB,YAAAC,EAAa,eAAAC,CAAe,CAAC,CACrF,EACA,CAAE,SAAAC,EAAU,QAAS,EAAM,CACjC,CACF,CExBA,OAAS,aAAAG,OAAiB,QAC1B,OAAS,gBAAAC,GAAc,YAAAC,OAAgB,wBCFvC,OAAS,aAAAC,OAAiB,6BAU1B,eAAsBC,GAAc,CAAE,OAAAC,EAAQ,aAAAC,EAAc,YAAAC,EAAa,eAAAC,CAAe,EAAwB,CAO9G,OANe,MAAMC,GAAUJ,EAAQ,CACrC,QAASC,EACT,MAAOI,GAAY,sBACnB,IAAK,CAAE,UAAWH,EAAa,UAAWC,CAAe,EACzD,SAAU,SACZ,CAAC,GACa,sBAAwBG,CACxC,CDbO,SAASC,GAA0B,CACxC,OAAAC,EACA,aAAAC,EACA,YAAAC,EACA,eAAAC,CACF,EAKG,CACD,IAAMC,EAAW,CAAC,gBAAiBJ,GAAQ,MAAM,GAAIC,EAAcC,EAAaC,CAAc,EAC9F,OAAOE,GACLL,GAAUE,GAAeC,EACrB,CACE,SAAAC,EACA,QAAS,IAAME,GAAc,CAAE,OAAAN,EAAQ,aAAAC,EAAc,YAAAC,EAAa,eAAAC,CAAe,CAAC,CACpF,EACA,CAAE,SAAAC,EAAU,QAAS,EAAM,CACjC,CACF,CEtBA,OAAsB,gBAAAG,GAAc,YAAAC,GAAU,kBAAAC,OAAsB,wBAEpE,OAAS,aAAAC,OAAiB,QCJ1B,OAAS,aAAAC,OAAiB,QAC1B,OAAyB,gBAAAC,GAAc,YAAAC,OAAgB,wBCDvD,OAAS,0BAAAC,OAA8B,8BCFvC,OAAS,eAAAC,OAAmB,kBAC5B,OAAS,WAAAC,OAAe,qBASjB,IAAMC,EAAQF,GACnBC,GACE,KAAO,CACL,QAAS,CAAC,CACZ,GACA,CACE,KAAM,eACN,WAAY,CAAC,CAAE,QAAAE,CAAQ,KAAO,CAAE,QAAAA,CAAQ,EAC1C,CACF,CACF,EAGA,SAASC,GAASC,EAAqB,CACjCA,EAAM,MAAQH,EAAM,QAAQ,WAAW,EAAE,MAC3CA,EAAM,QAAQ,UAAU,CAE5B,CACA,OAAO,iBAAiB,UAAWE,EAAQ,EC1B3C,OAAS,sBAAAE,GAAoB,uBAAAC,OAA2B,gBAEjD,SAASC,GAAiBC,EAAsB,CACrD,IAAMC,EACJC,EAAM,SAAS,EAAE,QAAQF,CAAW,IACnC,IAAM,CACL,IAAMG,EAAaN,GAAmB,EACtC,OAAAK,EAAM,SAAUE,IAAW,CACzB,QAAS,CACP,GAAGA,EAAM,QACT,CAACJ,CAAW,EAAGG,CACjB,CACF,EAAE,EACKA,CACT,GAAG,EAEL,OAAOL,GAAoBG,CAAuB,CACpD,CFdA,eAAsBI,GAAuC,CAC3D,OAAAC,EACA,YAAAC,CACF,EAG0B,CACxB,IAAMC,EAAgBC,GAAiBF,CAAW,EAClD,OAAO,MAAMG,GAAuB,CAAE,OAAAJ,EAAQ,OAAQ,CAACE,CAAa,CAAE,CAAC,CACzE,CDPO,SAASG,GAA8B,CAC5C,OAAAC,EACA,YAAAC,CACF,EAGG,CACD,IAAMC,EAAW,CAAC,oBAAqBF,GAAQ,MAAM,GAAIC,CAAW,EACpE,OAAOE,GACLH,GAAUC,EACN,CACE,SAAAC,EACA,QAAS,IAAME,GAAkB,CAAE,OAAAJ,EAAQ,YAAAC,CAAY,CAAC,EACxD,UAAW,GACb,EACA,CAAE,SAAAC,EAAU,QAAS,EAAM,CACjC,CACF,CAEO,SAASG,GAAkBJ,EAAgE,CAChG,GAAM,CAAE,QAAAK,CAAQ,EAAIC,EAAkB,EAChCP,EAASQ,GAAU,CAAE,QAAAF,CAAQ,CAAC,EACpC,OAAOG,GAASV,GAA8B,CAAE,YAAAE,EAAa,OAAAD,CAAO,CAAC,CAAC,CACxE,CDpBO,SAASU,GAA2B,CACzC,YAAAC,EACA,OAAAC,EACA,YAAAC,EACA,iBAAAC,EACA,aAAAC,CACF,EAMG,CACD,IAAMC,EAAW,CAAC,mBAAoBJ,GAAQ,MAAM,GAAIC,CAAW,EACnE,OAAOI,GACLL,GAAUC,EACN,CACE,SAAAG,EACA,QAAS,SAAY,CACnB,GAAM,CAAE,QAASE,CAAe,EAAI,MAAMP,EAAY,WACpDQ,GAA8B,CAAE,OAAAP,EAAQ,YAAAC,CAAY,CAAC,CACvD,EACM,CAACO,EAAWC,EAAWC,CAAa,EAAI,MAAM,QAAQ,IAAI,CAC9DX,EAAY,WAAWY,GAAyB,CAAE,OAAAX,EAAQ,iBAAAE,EAAkB,YAAAD,CAAY,CAAC,CAAC,EAC1FF,EAAY,WAAWa,GAAuB,CAAE,OAAAZ,EAAQ,iBAAAE,EAAkB,YAAAD,EAAa,eAAAK,CAAe,CAAC,CAAC,EACxGP,EAAY,WAAWc,GAA0B,CAAE,OAAAb,EAAQ,aAAAG,EAAc,YAAAF,EAAa,eAAAK,CAAe,CAAC,CAAC,CACzG,CAAC,EACKQ,EAAeN,GAAaO,EAClC,MAAO,CACL,aAAAD,EACA,UAAAL,EACA,cAAAC,EACA,SAAUI,GAAgBL,GAAaC,CACzC,CACF,CACF,EACA,CAAE,SAAAN,EAAU,QAAS,EAAM,CACjC,CACF,CAEO,SAASY,EAAiBf,EAAkC,CACjE,IAAMF,EAAckB,GAAe,EAC7B,CAAE,QAAAC,EAAS,iBAAAhB,EAAkB,aAAAC,CAAa,EAAIgB,EAAkB,EAChEnB,EAASoB,GAAU,CAAE,QAAAF,CAAQ,CAAC,EAepC,OAXgBG,GACdvB,GAA2B,CACzB,YAAAC,EACA,OAAAC,EACA,YAAAC,EACA,iBAAAC,EACA,aAAAC,CACF,CAAC,EACDJ,CACF,CAGF,CKrEA,OAAS,iBAAAuB,OAAqB,QCC9B,OAAS,YAAAC,OAAgB,wBAElB,SAASC,EAAOC,EAA0B,CAC/C,IAAMC,EAAoBD,GAAS,YAAY,EAC/C,OAAOF,GAKJ,CACD,QAAS,CAAC,CAACG,EACX,SAAU,CAAC,MAAOA,CAAiB,EAEnC,QAAS,SAAY,CAEnB,IAAMC,EAAO,MAAM,MAAM,wCAAwCD,GAAmB,EAAE,KAAME,GAAQA,EAAI,KAAK,CAAC,EAC9G,MAAO,CACL,QAASD,EAAK,SAAW,OACzB,KAAMA,EAAK,MAAQ,OACnB,YAAaA,EAAK,aAAe,OACjC,OAAQA,EAAK,QAAU,MACzB,CACF,CACF,CAAC,CACH,CCjBW,cAAAE,GAIP,QAAAC,OAJO,oBAFJ,SAASC,EAAa,CAAE,IAAAC,CAAI,EAAU,CAC3C,OAAIA,EAAI,QAAU,GACTH,GAAC,QAAK,MAAOG,EAAM,SAAAA,EAAI,EAI9BF,GAAC,QAAK,MAAOE,EACX,UAAAH,GAAC,QAAK,UAAU,6CAAyC,SAAAG,EAAI,MAAM,EAAG,CAAC,EAAE,EACzEH,GAAC,QAAK,UAAU,mCAAoC,SAAAG,EAAI,MAAM,EAAG,EAAE,EAAE,EACpEA,EAAI,MAAM,EAAE,GACf,CAEJ,CFMQ,OACE,OAAAC,EADF,QAAAC,OAAA,oBAXD,SAASC,GAAO,CAAE,SAAAC,EAAU,WAAAC,EAAY,YAAAC,CAAY,EAAU,CACnE,GAAM,CAAE,KAAMC,CAAI,EAAIC,EAAOF,CAAW,EAClC,CAAE,WAAAG,EAAY,UAAWC,CAAoB,EAAIC,GAAc,EAC/D,CAAE,kBAAAC,CAAkB,EAAIC,EAAgB,EAK9C,OACEX,GAAC,OAAI,UAAU,sBACb,UAAAA,GAAC,OAAI,UAAU,6BACb,UAAAA,GAAC,OACC,UAAAD,EAAC,OAAI,mBAAO,EACZA,EAAC,OAAI,UAAU,uBAAwB,SAAAM,GAAK,MAAQN,EAACa,EAAA,CAAa,IAAKR,EAAa,EAAG,GACzF,EACAL,EAACc,EAAA,CACC,QAASX,EAAW,UAAY,WAChC,UAAU,iCACV,UAAWA,EACX,QAASM,EACT,QAAS,IAAM,CACbE,EAAkB,EAClBH,EAAW,CACb,EACD,oBAED,GACF,EACCJ,EACCJ,EAAC,KAAE,UAAU,UAAU,qFAAyE,EAC9F,MACN,CAEJ,CG5CA,OAAS,eAAAe,GAAa,kBAAAC,OAAsB,wBAC5C,OAAS,gBAAAC,OAAoB,iCAEtB,SAASC,IAAkB,CAChC,IAAMC,EAAcH,GAAe,EAC7B,CAAE,MAAAI,CAAM,EAAIC,EAAkB,EAE9BC,EAAc,CAAC,eAAgBF,EAAM,EAAE,EAC7C,OAAOL,GAAY,CACjB,YAAAO,EACA,QAAUC,GAAU,QAAQ,MAAMA,CAAK,EACvC,WAAY,MAAOC,GAAyB,CAG1C,MAAMP,GAAa,CAAE,MAAAG,EAAO,YAAAI,CAAY,CAAC,EAEzC,MAAM,QAAQ,IAAI,CAChBL,EAAY,kBAAkB,CAAE,SAAU,CAAC,cAAc,CAAE,CAAC,EAC5DA,EAAY,kBAAkB,CAAE,SAAU,CAAC,kBAAkB,CAAE,CAAC,CAClE,CAAC,CACH,EACA,MAAO,CACT,CAAC,CACH,CCxBA,OAAS,WAAAM,OAAe,iBAMpB,OAOE,OAAAC,EAPF,QAAAC,OAAA,oBAFG,SAASC,GAAQ,CAAE,UAAAC,EAAW,GAAGC,CAAM,EAAU,CACtD,OACEH,GAAC,OACC,MAAM,6BACN,QAAQ,cACR,KAAK,eACL,UAAWF,GAAQ,oBAAqBI,CAAS,EAChD,GAAGC,EAEJ,UAAAJ,EAAC,QAAK,EAAE,gCAAgC,EACxCA,EAAC,QAAK,EAAE,qBAAqB,YAAY,MAAM,EAC/CA,EAAC,QAAK,EAAE,qBAAqB,EAC7BA,EAAC,QAAK,EAAE,0BAA0B,YAAY,MAAM,GACtD,CAEJ,CCpBA,OAAS,eAAAK,OAAmB,OAErB,SAASC,GAAcC,EAAa,CAEzC,IAAMC,EAAYH,GAAYE,CAAG,EAC3BE,EAAY,KAAK,MAAM,WAAWD,CAAS,CAAC,EAAE,SAAS,EAAE,OAC/D,OAAO,WAAWA,CAAS,EAAE,eAAe,QAAS,CAAE,sBAAuB,KAAK,IAAI,EAAG,EAAIC,CAAS,CAAE,CAAC,CAC5G,CCEI,OACuB,OAAAC,GADvB,QAAAC,OAAA,oBAFG,SAASC,GAAQ,CAAE,IAAAC,CAAI,EAAU,CACtC,OACEF,GAAC,QAAK,UAAU,iCACb,UAAAG,GAAcD,CAAG,EAAE,IAACH,GAACK,GAAA,EAAQ,GAChC,CAEJ,CCPA,OAAS,aAAAC,OAAiB,QAgClB,OACE,OAAAC,EADF,QAAAC,OAAA,oBAvBD,SAASC,GAAU,CAAE,SAAAC,EAAU,WAAAC,EAAY,YAAAC,CAAY,EAAU,CACtE,IAAMC,EAAYC,GAAaF,CAAW,EACpCG,EAAeC,GAAgB,EAErC,OAAAC,GAAU,IAAM,CAKd,IAAMC,EAAQ,WAAW,IAAM,CACzBR,GAAYK,EAAa,SAAW,QAAUF,EAAU,WAAaA,EAAU,KAAOM,GACxFJ,EAAa,OAAOH,CAAW,CAEnC,CAAC,EACD,MAAO,IAAM,aAAaM,CAAK,CACjC,EAAG,CAACL,EAAU,KAAMA,EAAU,UAAWE,EAAcL,EAAUE,CAAW,CAAC,EAM3EJ,GAAC,OAAI,UAAU,sBACb,UAAAA,GAAC,OAAI,UAAU,6BACb,UAAAA,GAAC,OACC,UAAAD,EAAC,OAAI,qBAAS,EACdA,EAAC,OAAI,UAAU,uBACZ,SAAAM,EAAU,MAAQ,KAAON,EAACa,GAAA,CAAQ,IAAKP,EAAU,KAAM,EAAKN,EAACc,EAAA,CAAY,UAAU,UAAU,EAChG,GACF,EACAd,EAACe,EAAA,CACC,QAASZ,EAAW,UAAY,WAChC,UAAU,iCACV,UAAWA,GAAYC,EACvB,QAASE,EAAU,SAAW,WAAaE,EAAa,SAAW,UACnE,QAAS,IAAMA,EAAa,OAAOH,CAAW,EAC/C,kBAED,GACF,EACCD,EAAaJ,EAAC,KAAE,UAAU,UAAU,kEAAsD,EAAO,MACpG,CAEJ,CCzDA,OAAc,sBAAAgB,OAA0B,OACxC,OAAS,eAAAC,GAAa,kBAAAC,OAAsB,wBAC5C,OAAS,aAAAC,OAAiB,aAC1B,OAAS,qBAAAC,GAAmB,+BAAAC,OAAmC,2BAI/D,OAAS,6BAAAC,OAAiC,eAE1C,OAAS,aAAAC,OAAiB,QAC1B,OAAS,iBAAAC,OAAqB,qBAC9B,OAAOC,OAAmB,2DCV1B,OAAS,iBAAiBC,OAA0B,eACpD,OAAS,aAAAC,OAAiB,aCF1B,OAAwD,SAAAC,OAAa,OACrE,OAAS,iBAAAC,OAAqB,eAC9B,OAAS,0BAAAC,OAA8B,6BACvC,OAAS,aAAAC,OAAiB,6BAC1B,OAAOC,OAAmB,gDAC1B,OAAS,iBAAAC,OAAqB,qBAC9B,OAAS,aAAAC,OAAiB,aAY1B,eAAsBC,GAAsC,CAC1D,WAAAC,EACA,aAAAC,EACA,SAAAC,EACA,SAAAC,EACA,MAAOC,EACP,OAAAC,CACF,EAA2B,CACzB,IAAMC,EACJF,IACCC,GAEK,MAAMV,GAAUU,EAAQ,CACtB,QAASJ,EACT,MAAOL,GAAc,OAAO,wBAC5B,IAAK,CAAE,OAAQI,EAAW,QAAQ,OAAQ,EAC1C,SAAU,SACZ,CAAC,GACD,MACF,IAEA,CAAE,UAAWO,EAAiB,KAAMC,CAAW,EAAIX,GAAcK,CAAQ,EAE/E,OAAO,MAAMJ,GACXE,EACAP,GACA,eACF,EAAE,CACA,QAASO,EAAW,QACpB,OAAQ,CACN,kBAAmBC,EACnB,KAAMT,GAAMQ,EAAW,MAAM,GAAI,CAAE,KAAM,EAAG,CAAC,CAC/C,EACA,MAAON,GACP,YAAa,OACb,QAAS,CACP,OAAQM,EAAW,QAAQ,QAC3B,gBAAAO,EACA,WAAAC,EACA,SAAAL,EACA,MAAAG,CACF,CACF,CAAC,CACH,CDzDA,OAAOG,OAA0B,+GASjC,eAAsBC,GAA+C,CACnE,cAAAC,EACA,GAAGC,CACL,EAAoC,CAClC,IAAMC,EAAY,MAAMC,GAASF,CAAI,EACrC,OAAOG,GACLJ,EACAK,GACA,eACF,EAAE,CACA,QAASJ,EAAK,aACd,IAAKH,GACL,aAAc,oBACd,KAAM,CAACG,EAAK,WAAW,QAAQ,QAASA,EAAK,SAAUA,EAAK,SAAUC,CAAS,CACjF,CAAU,CACZ,CDdO,SAASI,GAAgB,CAAE,WAAAC,CAAW,EAAoC,CAC/E,IAAMC,EAAcC,GAAe,EAC7B,CAAE,QAAAC,EAAS,aAAAC,EAAc,iBAAAC,CAAiB,EAAIC,EAAkB,EAChEC,EAASC,GAAU,CAAE,QAAAL,CAAQ,CAAC,EAE9BM,EAAc,CAAC,eAAgBF,GAAQ,MAAM,GAAIP,EAAW,QAAQ,OAAO,EACjF,OAAOU,GAAY,CACjB,YAAAD,EACA,QAAUE,GAAU,QAAQ,MAAMA,CAAK,EACvC,WAAY,MAAO,CACjB,cAAAC,EACA,gBAAAC,EACA,mBAAAC,CACF,IAIqB,CACnB,GAAI,CAACP,EAAQ,MAAM,IAAI,MAAM,mBAAmB,EAChD,IAAMQ,EAAiBH,EAAc,QAAQ,QAI7C,GAFA,QAAQ,IAAI,oBAAoB,EAE5BZ,EAAW,QAAQ,OAAS,QAAS,CACvC,IAAMgB,EAAa,CAAC,EAEpB,GAAIH,EAAiB,CACnB,QAAQ,IAAI,qBAAqB,EACjC,IAAMI,EAAK,MAAMC,GAAkB,CACjC,OAAAX,EACA,WAAAP,EACA,cAAAY,EACA,aAAcP,EACd,SAAUc,GAAc,CAAE,KAAM,SAAU,UAAW,GAAI,KAAM,eAAgB,CAAC,EAChF,SAAUC,GAAmB,CAC3B,IAAKC,GACL,aAAc,kBACd,KAAM,CAACN,CAAc,CACvB,CAAC,CACH,CAAC,EACD,QAAQ,IAAI,iBAAkBE,CAAE,EAChCD,EAAI,KAAKC,CAAE,EAGb,GAAIH,EAAoB,CACtB,QAAQ,IAAI,wBAAwB,EACpC,IAAMG,EAAK,MAAMC,GAAkB,CACjC,OAAAX,EACA,WAAAP,EACA,cAAAY,EACA,aAAAR,EACA,SAAUe,GAAc,CAAE,KAAM,SAAU,UAAW,GAAI,KAAM,cAAe,CAAC,EAC/E,SAAUC,GAAmB,CAC3B,IAAKE,GACL,aAAc,qBACd,KAAM,CAACP,EAAgBQ,EAA8B,IAAI,CAC3D,CAAC,CACH,CAAC,EACD,QAAQ,IAAI,oBAAqBN,CAAE,EACnCD,EAAI,KAAKC,CAAE,EAGb,GAAI,CAACD,EAAI,OAAQ,OAEjB,QAAQ,IAAI,cAAeA,EAAI,OAAQ,UAAU,EACjD,QAAWQ,KAAQR,EAAK,CACtB,IAAMS,EAAU,MAAMC,GAAUnB,EAAQoB,GAA2B,2BAA2B,EAAE,CAAE,KAAAH,CAAK,CAAC,EACxG,QAAQ,IAAI,iBAAkBC,CAAO,EACjCA,EAAQ,SAAW,YACrB,QAAQ,MAAM,eAAgBA,CAAO,OAGpC,CACL,IAAMG,EAAQ,CAAC,EA0Bf,GAxBIf,IACF,QAAQ,IAAI,qBAAqB,EACjCe,EAAM,KACO,CACT,GAAIvB,EACJ,IAAKgB,GACL,aAAc,kBACd,KAAM,CAACN,CAAc,CACvB,CACF,GAGED,IACF,QAAQ,IAAI,wBAAwB,EACpCc,EAAM,KACO,CACT,GAAIxB,EACJ,IAAKyB,GACL,aAAc,qBACd,KAAM,CAACd,EAAgBQ,EAA8B,IAAI,CAC3D,CACF,GAGE,CAACK,EAAM,OAAQ,OAEnB,QAAQ,IAAI,0BAA2BA,EAAO5B,CAAU,EACxD,IAAMwB,EAAO,MAAME,GAAU1B,EAAY8B,GAAmB,mBAAmB,EAAE,CAAE,MAAAF,CAAM,CAAC,EAC1F,QAAQ,IAAI,mBAAoBJ,CAAI,EAEpC,IAAMC,EAAU,MAAMC,GACpB1B,EACA+B,GACA,6BACF,EAAE,CAAE,KAAAP,CAAK,CAAC,EACV,QAAQ,IAAI,sBAAuBC,CAAO,EAErCA,EAAQ,SACX,QAAQ,MAAM,kBAAmBA,CAAO,EAI5C,MAAM,QAAQ,IAAI,CAChBxB,EAAY,kBAAkB,CAAE,SAAU,CAAC,YAAY,CAAE,CAAC,EAC1DA,EAAY,kBAAkB,CAAE,SAAU,CAAC,eAAe,CAAE,CAAC,EAC7DA,EAAY,kBAAkB,CAAE,SAAU,CAAC,kBAAkB,CAAE,CAAC,CAClE,CAAC,CACH,EACA,MAAO,CACT,CAAC,CACH,CGxIA,OAAS,aAAA+B,OAAiB,QCD1B,OAAS,aAAAC,OAAiB,QAC1B,OAAyB,gBAAAC,GAAc,YAAAC,OAAgB,wBCFvD,OAAS,uBAAAC,OAA2B,iBACpC,OAAS,YAAAC,OAAgB,6BAEzB,OAAS,YAAAC,OAAgB,gCAKzB,eAAsBC,GAAsC,CAC1D,OAAAC,EACA,YAAAC,EACA,eAAAC,EACA,aAAAC,EACA,iBAAAC,CACF,EAMkC,CAChC,IAAMC,EAAmBC,EAAoBN,EAAO,KAAK,EAazD,OAXsBO,EAAoB,CACxC,iBAAAH,EACA,UAAWC,EACX,OAAAL,EACA,QAASE,CACX,CAAC,EACE,OAAOM,GAAoB,CAAC,EAC5B,OAAOC,GAAS,CAAE,aAAAN,EAAc,iBAAkBF,EAAa,aAAcD,CAAO,CAAC,CAAC,EACtF,OAAOU,GAAS,CAAC,EACjB,OAAO,KAAO,CAAE,YAAAT,CAAY,EAAE,CAGnC,CD3BO,SAASU,GAA6B,CAC3C,eAAAC,EACA,OAAAC,EACA,YAAAC,EACA,aAAAC,EACA,iBAAAC,CACF,EAMG,CACD,IAAMC,EAAW,CAAC,mBAAoBJ,GAAQ,IAAKC,EAAaF,GAAgB,QAASG,CAAY,EACrG,OAAOG,GACLL,GAAUC,GAAeF,EACrB,CACE,SAAAK,EACA,QAAS,IACPE,GAAiB,CACf,eAAAP,EACA,OAAAC,EACA,YAAAC,EACA,aAAAC,EACA,iBAAAC,CACF,CAAC,EACH,UAAW,GACb,EACA,CAAE,SAAAC,EAAU,QAAS,EAAM,CACjC,CACF,CAEO,SAASG,EAAiBN,EAAiE,CAChG,GAAM,CAAE,QAAAO,EAAS,aAAAN,EAAc,iBAAAC,CAAiB,EAAIM,EAAkB,EAChET,EAASU,GAAU,CAAE,QAAAF,CAAQ,CAAC,EAC9B,CAAE,KAAMT,CAAe,EAAIY,GAAkBV,CAAW,EAC9D,OAAOW,GACLd,GAA6B,CAC3B,eAAAC,EACA,YAAAE,EACA,OAAAD,EACA,aAAAE,EACA,iBAAAC,CACF,CAAC,CACH,CACF,CDfQ,OACE,OAAAU,EADF,QAAAC,OAAA,oBAzBD,SAASC,GAAQ,CAAE,SAAAC,EAAU,WAAAC,EAAY,WAAAC,EAAY,gBAAAC,EAAiB,mBAAAC,CAAmB,EAAU,CACxG,GAAM,CAAE,KAAMC,CAAc,EAAIC,EAAiBJ,EAAW,QAAQ,OAAO,EACrEK,EAAQC,GAAgB,CAAE,WAAAN,CAAW,CAAC,EACtCO,EAAa,CAACL,GAAsB,CAACA,EAE3C,OAAAM,GAAU,IAAM,CAKd,IAAMC,EAAQ,WAAW,IAAM,CACzBX,GAAYO,EAAM,SAAW,QAAUF,GAAiB,CAACI,GAC3DF,EAAM,OAAO,CACX,cAAAF,EACA,gBAAAF,EACA,mBAAAC,CACF,CAAC,CAEL,CAAC,EACD,MAAO,IAAM,aAAaO,CAAK,CACjC,EAAG,CAACF,EAAYT,EAAUI,EAAoBD,EAAiBE,EAAeE,CAAK,CAAC,EAGlFT,GAAC,OAAI,UAAU,sBACb,UAAAA,GAAC,OAAI,UAAU,6BACb,UAAAA,GAAC,OACC,UAAAD,EAAC,OAAI,mBAAO,EACZA,EAAC,OAAI,UAAU,uBAAwB,SAAAY,EAAa,UAAY,SAAS,GAC3E,EACCA,EACCZ,EAACe,EAAA,CAAO,QAAQ,WAAW,UAAU,iCAAiC,UAAWZ,EAAU,SAAQ,GAAC,mBAEpG,EAEAH,EAACe,EAAA,CACC,QAASZ,EAAW,UAAY,WAChC,UAAU,iCACV,UAAWA,EACX,QAAS,CAACK,GAAiBE,EAAM,SAAW,UAC5C,QACEF,EACI,IACEE,EAAM,OAAO,CACX,cAAAF,EACA,gBAAAF,EACA,mBAAAC,CACF,CAAC,EACH,OAEP,kBAED,GAEJ,EACCH,EACCJ,EAAC,KAAE,UAAU,UAAU,oFAAwE,EAC7F,MACN,CAEJ,CzBnB4B,cAAAgB,MAAA,oBAtCrB,SAASC,GAAe,CAAE,WAAAC,EAAY,mBAAAC,CAAmB,EAAU,CACxE,IAAMC,EAAcF,EAAW,QAAQ,QACjC,CAAE,KAAMG,CAAc,EAAIC,EAAiBF,CAAW,EAEtD,CAAE,kBAAAG,CAAkB,EAAIC,EAAgB,EACxCC,EAAkBL,IAAgBD,EAElCO,EAAuBC,GAAON,CAAa,EACjDO,GAAU,IAAM,CACVP,GAAiB,OACjBK,EAAqB,SAAW,OAClCA,EAAqB,QAAUL,GAG7BA,EAAc,WACZI,GAAmB,CAACC,EAAqB,QAAQ,WACnDH,EAAkB,EAGxB,EAAG,CAACA,EAAmBE,EAAiBJ,CAAa,CAAC,EAEtD,GAAM,CAAE,aAAAQ,EAAc,UAAAC,EAAW,cAAAC,CAAc,EAAIV,GAAiB,CAAC,EAE/DW,EAAQC,GAAQ,IACfb,EAUE,CACL,CACE,GAAI,SACJ,WAAY,GACZ,QAAUc,GAAUlB,EAACmB,GAAA,CAAQ,GAAGD,EAAO,YAAad,EAAa,CACnE,EACA,CACE,GAAI,YACJ,WAAY,CAAC,CAACS,EACd,QAAUK,GAAUlB,EAACoB,GAAA,CAAW,GAAGF,EAAO,YAAad,EAAa,CACtE,EACA,CACE,GAAI,UACJ,WAAY,CAAC,CAACU,GAAa,CAAC,CAACC,EAC7B,QAAUG,GACRlB,EAACqB,GAAA,CACE,GAAGH,EACJ,WAAYhB,EACZ,gBAAiB,CAACY,EAClB,mBAAoB,CAACC,EACvB,CAEJ,CACF,EAhCS,CACL,CACE,GAAI,SACJ,WAAY,GACZ,QAAS,IAAM,IACjB,CACF,EA2BD,CAACF,EAAcE,EAAeD,EAAWV,EAAaF,CAAU,CAAC,EAE9D,CAACoB,CAAc,EAAIC,GAAwB,IAAI,EAC/CC,EAAWR,EAAM,KAAMS,GAASA,EAAK,SAAW,MAAQ,CAACA,EAAK,UAAU,EACxEC,EAAiBV,EAAM,OAAQS,GAASA,EAAK,UAAU,EACvDE,IACHL,GAAkB,KAAON,EAAM,KAAMS,GAASA,EAAK,KAAOH,CAAc,EAAI,OAC7EE,IACCE,EAAe,OAASV,EAAM,OAASU,EAAe,GAAG,EAAE,EAAI,MAC5DE,GAAkBD,GAAaX,EAAM,QAAQW,EAAU,EAAI,GAEjE,OACE3B,EAAC,OACC,UAAW6B,GACT,+DACA,gEACF,EAEC,SAAAb,EAAM,IAAI,CAACS,EAAMK,KAAM,CACtB,IAAMC,GAAWN,IAASE,GACpBK,GAAaD,IAAYL,EAAe,SAAWV,EAAM,OACzDiB,GAAa,CAACR,EAAK,YAAcG,KAAoB,IAAME,GAAIF,GACrE,OACE5B,EAAC,OAAkB,UAAW6B,GAAQ,oCAAqCE,GAAW,YAAc,IAAI,EACtG,SAAA/B,EAAC,OAAI,UAAW6B,GAAQ,gBAAiBI,GAAa,iCAAmC,IAAI,EAC1F,SAAAR,EAAK,QAAQ,CAAE,SAAAM,GAAU,WAAAC,EAAW,CAAC,EACxC,GAHQP,EAAK,EAIf,CAEJ,CAAC,EACH,CAEJ,CpBtGA,OAAS,UAAAS,OAAc,QASZ,cAAAC,OAAA,oBAPJ,SAASC,IAAsB,CACpC,GAAM,CAAE,QAAAC,CAAQ,EAAIC,EAAkB,EAChCC,EAAaC,GAAmB,CAAE,QAAAH,CAAQ,CAAC,EAC3C,CAAE,QAASI,CAAY,EAAIC,GAAW,EACtCC,EAAqBT,GAAOO,CAAW,EAE7C,OAAIF,EAAW,SAAW,UACjBJ,GAACS,GAAA,EAAc,EAGjBT,GAACU,GAAA,CAAe,WAAYN,EAAW,KAAM,mBAAoBI,EAAmB,QAAS,CACtG,CgDjBA,OAAoB,YAAAG,OAAgB,QACpC,OAAS,iBAAAC,OAAqB,uBCD9B,OAAS,WAAAC,OAAe,iBACxB,OAAS,aAAAC,GAAW,4BAAAC,OAAgC,OAwBhD,OAOE,OAAAC,GAPF,QAAAC,OAAA,oBAjBG,SAASC,GAAY,CAAE,MAAOC,EAAc,MAAAC,CAAM,EAAU,CAGjE,GAFI,CAACA,GAEDA,aAAiBN,IAAaM,EAAM,KAAMC,GAAMA,aAAaN,EAAwB,GAAK,KAC5F,OAAO,KAIT,IAAMO,EAAQH,GAAgB,QAGxBI,EACJ,OAAOH,GAAU,SAAWA,EAAQA,aAAiB,MAAQ,OAAOA,CAAK,EAAI,iCAI/E,OACEH,GAAC,OACC,UAAWJ,GACT,oCACA,0BACA,kCACF,EAEA,UAAAG,GAAC,OAAI,UAAU,oBAAqB,SAAAM,EAAM,EAC1CN,GAAC,OAAI,UAAU,oEAAqE,SAAAO,EAAQ,GAC9F,CAEJ,CDjCA,OAAS,QAAAC,OAAY,2BACrB,OAAS,WAAAC,OAAe,iBACxB,OAAS,gBAAAC,OAAoB,cAiBnB,cAAAC,EAEE,QAAAC,OAFF,oBAVH,SAASC,GAA0B,CAAE,SAAAC,CAAS,EAAU,CAC7D,IAAMC,EAAYC,GAAa,EACzB,CAACC,EAASC,CAAU,EAAIC,GAAS,CAAC,EAIxC,OACER,EAACS,GAAA,CACC,eAAgB,CAAC,CAAE,MAAAC,EAAO,mBAAAC,CAAmB,IAC3CV,GAAC,OAAI,UAAWW,GAAQ,kDAAkD,EACxE,UAAAZ,EAACa,GAAA,CAAY,MAAOH,aAAiB,MAAQA,EAAM,OAASA,EAAM,QAAUA,EAAO,EAClFJ,EAAU,EACTL,GAAC,UACC,KAAK,SACL,QAAS,MAAOa,GAAU,CAExBA,EAAM,cAAc,SAAW,OAC/B,MAAMC,GAAK,GAAI,EACfJ,EAAmB,EACfP,EAAU,IACZG,EAAYS,GAAUA,EAAQ,CAAC,EAC/BF,EAAM,cAAc,SAAW,KAEnC,EACA,UAAU,uEAEV,UAAAd,EAACiB,EAAA,CAAY,UAAU,kGAAkG,EACzHjB,EAAC,QAAK,UAAU,oGAAoG,kBAEpH,GACF,EACE,MACN,EAGD,SAAAG,EACH,CAEJ,CjD7CA,OAAS,eAAAe,GAAa,eAAAC,OAAmB,yBmDJzC,OAAS,WAAAC,OAAe,iBAMpB,cAAAC,OAAA,oBAFG,SAASC,GAAQ,CAAE,UAAAC,EAAW,SAAAC,EAAU,GAAGC,CAAM,EAAU,CAChE,OACEJ,GAAC,OACC,MAAM,6BACN,QAAQ,YACR,KAAK,eACL,UAAWD,GAAQ,sCAAuCG,CAAS,EAClE,GAAGE,EAEH,SAAAD,EACH,CAEJ,CCZM,cAAAE,OAAA,oBAHC,SAASC,GAAUC,EAAc,CACtC,OACEF,GAACG,GAAA,CAAQ,YAAY,IAAI,OAAO,eAAgB,GAAGD,EACjD,SAAAF,GAAC,QACC,EAAE,uBACF,KAAK,OACL,OAAO,eACP,YAAY,IACZ,cAAc,QACd,eAAe,QACjB,EACF,CAEJ,CpDDM,cAAAI,EAeI,QAAAC,OAfJ,oBALC,SAASC,IAAe,CAC7B,GAAM,CAAE,iBAAAC,EAAkB,mBAAAC,CAAmB,EAAIC,EAAgB,EACjE,OACEJ,GAACK,GAAA,CAAM,KAAMH,EAAkB,aAAcC,EAE3C,UAAAJ,EAACO,GAAA,CAAY,UAAU,UAAU,iCAAqB,EACrDJ,EACCF,GAAC,OACC,UAAWO,GACT,uBACA,yEACA,6DACA,mBACA,gEACF,EAEA,UAAAR,EAACS,GAAA,CACC,SAAAT,EAACU,GAAA,EAAoB,EACvB,EAEAT,GAAC,KACC,KAAK,kBACL,OAAO,SACP,IAAI,sBACJ,UAAU,0IAEV,UAAAD,EAAC,QAAK,UAAU,gBACd,SAAAA,EAACW,EAAA,CAAK,UAAU,8EAA8E,EAChG,EACAX,EAAC,QAAK,0BAAc,GACtB,EAEAA,EAAC,OAAI,UAAU,yBACb,SAAAA,EAACY,GAAA,CACC,UAAWJ,GACT,kDACA,yCACF,EACA,MAAM,QAEN,SAAAR,EAACa,GAAA,CAAU,UAAU,MAAM,EAC7B,EACF,GACF,EACE,MACN,CAEJ,CqDxCI,OAEE,OAAAC,GAFF,QAAAC,OAAA,oBAFG,SAASC,GAAiB,CAAE,OAAAC,EAAQ,SAAAC,CAAS,EAAU,CAC5D,OACEH,GAACI,GAAA,CAAuB,OAAQF,EAC7B,UAAAC,EACDJ,GAACM,GAAA,EAAa,GAChB,CAEJ,CClBA,OAAS,cAAAC,OAAkB,QAC3B,OAAS,WAAAC,MAAe,iBCCxB,OAAS,WAAAC,OAAe,iBAWpB,mBAAAC,GAEI,OAAAC,EADF,QAAAC,OADF,oBALG,SAASC,GAAY,CAAE,QAAAC,CAAQ,EAAU,CAC9C,GAAM,CAAE,KAAMC,CAAI,EAAIC,EAAOF,CAAO,EAC9BG,EAASC,EAAgBH,GAAK,MAAM,EAE1C,OACEH,GAAAF,GAAA,CACE,UAAAE,GAAC,QAAK,UAAU,8DACd,UAAAD,EAAC,OACC,IAAKI,GAAK,QAAUE,EAAO,UAAYF,EAAI,OAAS,OACpD,UAAWN,GACT,0BACA,sGACA,yBACAQ,EAAO,UAAY,cAAgB,WACrC,EACF,EACAN,EAACQ,EAAA,CACC,UAAWV,GACT,0CACA,0BACAM,IAAQ,CAACA,EAAI,QAAUE,EAAO,SAAW,cAAgB,WAC3D,EACF,GACF,EACAN,EAAC,QAAK,UAAU,YAAa,SAAAI,GAAK,MAAQJ,EAACS,EAAA,CAAa,IAAKN,EAAS,EAAG,GAC3E,CAEJ,CD9BA,OAAS,UAAAO,OAAc,QA+CI,cAAAC,EAmBjB,QAAAC,OAnBiB,oBA7C3B,IAAMC,GAAsBC,EAC1B,+CACA,4BACA,wBACF,EAEMC,GAAsBD,EAC1B,+CACA,6DACF,EACME,GAAiCF,EACrC,8GACF,EAEO,SAASG,IAAgB,CAC9B,GAAM,CAAE,iBAAAC,EAAkB,iBAAAC,CAAiB,EAAIC,EAAgB,EACzD,CAAE,OAAAC,EAAQ,QAASC,CAAY,EAAIC,GAAW,EAC9CC,EAAqBd,GAAOY,CAAW,EAEvCG,EAAUC,EAAiBJ,CAAW,EAGtCK,EAAcN,IAAW,aAAgBA,IAAW,gBAAkBC,EACtEM,EAAkBN,IAAgBE,EAAmB,QACrDK,EAAaJ,EAAQ,UAAYA,EAAQ,KAAK,SAAWG,EAAkB,GAAQD,EAEnFG,GAAe,IAAM,CACzB,GAAIL,EAAQ,UAAW,CACrB,GAAI,CAACA,EAAQ,KAAK,aAAc,MAAO,SACvC,GAAI,CAACA,EAAQ,KAAK,eAAiB,CAACA,EAAQ,KAAK,UAAW,MAAO,SAErE,MAAO,SACT,GAAG,EAEH,OACEd,EAACoB,EAAA,CAAO,KAAK,QACV,SAAAF,EACClB,EAAC,UAGC,KAAK,SACL,UAAWG,EAAQD,GAAqBE,GAAqBC,EAA8B,EAC3F,QAASE,EAET,SAAAP,EAAC,QAAK,UAAU,mEACb,SAAAW,EAAcX,EAACqB,GAAA,CAAY,QAASV,EAAa,EAAK,KACzD,GAPI,WAQN,EAEAV,GAAC,UAGC,KAAK,SACL,UAAWE,EACTD,GACA,QACA,sCACA,uCACA,sBACA,sBACF,EACA,YAAWM,EACX,QAASD,EAET,UAAAN,GAAC,QAAK,UAAU,2DACd,UAAAD,EAAC,QACC,UAAWG,EACT,uCACA,gDACA,qDACF,EAEA,SAAAH,EAACsB,EAAA,EAAK,EACR,EACAtB,EAAC,QACC,cAAW,GACX,UAAWG,EACT,0BACA,sDACA,uDACF,EAEA,SAAAH,EAACuB,EAAA,EAAY,EACf,GACF,EACAvB,EAAC,QAAK,UAAU,cAAe,SAAAmB,EAAY,IAlCvC,SAmCN,EAEJ,CAEJ,CElGA,OAAS,sBAAAK,OAA0B,QAO5B,SAASC,IAAmE,CACjF,GAAM,CAAE,QAAAC,CAAQ,EAAIC,EAAkB,EAChCC,EAAaC,GAAmB,CAAE,QAAAH,CAAQ,CAAC,EAC7CE,EAAW,OAAO,QAAQ,MAAM,+BAAgCA,EAAW,KAAK,EAEpF,IAAME,EAAcF,EAAW,MAAM,QAAQ,QACvCG,EAAgBC,EAAiBF,CAAW,EAC5CG,EAAgBC,EAAiBJ,CAAW,EAElD,OAAKF,EAAW,UACZ,CAACG,EAAc,WAAa,CAACA,EAAc,KAAK,SAAiB,CAAE,GAAGA,EAAe,KAAM,MAAU,EAClGE,EAF2B,CAAE,GAAGL,EAAY,KAAM,MAAU,CAGrE,CCpBA,OAAqB,wBAAAO,GAAsB,qBAAAC,OAAyB,yBACpE,OAAyC,gBAAAC,OAAoB,QCC7D,IAAMC,GAAU,6BAA6B,KAE3C,ksDACF,IAIaC,GAAiBC,GAA+B,KAAe,CAC1E,GAAI,UACJ,KAAM,UACN,QAAAF,GACA,eAAgB,OAChB,gBAAkBG,GAAmBC,IAAY,CAC/C,GAAGC,EAAiBH,CAAI,EAAEE,CAAM,EAChC,GAAGD,CACL,EACF,GDfA,OAAS,aAAAG,OAAiB,2BAC1B,OAAS,WAAAC,OAAe,+BAiBjB,SAASC,GAGdC,EAAkF,CAClF,GAAM,CAAE,QAASC,CAAe,EAAIC,GAAkB,EAChDC,EAAsB,CAC1B,CACE,UAAW,cACX,QAAS,CACPC,GAAc,CAEZ,QAASJ,EAAO,OAClB,CAAC,CACH,CACF,EACA,GAAGC,CACL,EAEMI,EAAaC,GAAqBH,EAAS,CAC/C,QAASH,EAAO,QAChB,UAAWA,EAAO,sBACpB,CAAC,EAED,OAAOO,GAAa,CAClB,WAAAF,EACA,OAAQL,EAAO,OACf,WAAYH,GAAUG,EAAO,WAAaQ,GAAcV,GAAQU,CAAS,CAAC,EAC1E,gBAAiBR,EAAO,eAC1B,CAAC,CACH,CEnDA,OAAqB,wBAAAS,OAA4B,yBCAjD,OAAqB,qBAAAC,OAAyB,yBAGvC,SAASC,GAAWC,EAAkD,CAC3E,GAAM,CAAE,QAASC,CAAe,EAAIC,GAAkB,EACtD,MAAO,CACL,CACE,UAAW,cACX,QAAS,CACPC,GAAc,CAEZ,QAASH,EAAO,OAClB,CAAC,CACH,CACF,EACA,GAAGC,CACL,CACF,CDbO,SAASG,GAAc,CAC5B,QAAAC,EACA,GAAGC,CACL,EAQ4D,CAC1D,OAAOC,GAAqBF,GAAWG,GAAWF,CAAM,EAAG,CACzD,QAASA,EAAO,QAChB,UAAWA,EAAO,sBACpB,CAAC,CACH","names":["defineConfig","input","DialogRoot","DialogPortal","DialogContent","forwardRef","useEffect","useRef","useState","ReactDOM","useResizeObserver","mergeRefs","createContext","useContext","jsx","Context","FrameProvider","frame","children","useMediaQuery","createContext","useContext","RainbowKitProvider","lightTheme","midnightTheme","useChains","getChainContractAddress","getPaymasterAddress","chain","jsx","Context","createContext","EntryKitConfigProvider","config","children","useContext","chain","useChains","id","paymasterAddress","getPaymasterAddress","RainbowKitProvider","lightTheme","midnightTheme","useEntryKitConfig","useTheme","initialTheme","useEntryKitConfig","darkMode","useMediaQuery","jsx","jsxs","Resizer","onSize","props","ref","useRef","useResizeObserver","Shadow","forwardRef","mode","children","forwardedRef","frameRef","loaded","setLoaded","useState","frame","frameSize","setFrameSize","frameDocument","theme","useTheme","useEffect","frameStyle","mergeRefs","ReactDOM","FrameProvider","tailwind_default","twMerge","jsx","jsxs","Modal","open","onOpenChange","children","DialogRoot","DialogPortal","Shadow","DialogContent","event","useCallback","useMemo","useStore","createStore","store","useAccountModal","accountModalOpen","state","openAccountModal","closeAccountModal","toggleAccountModal","open","twMerge","useAccount","useConnectorClient","useAccount","twMerge","twMerge","jsx","jsxs","PendingIcon","className","props","jsx","jsxs","buttonClassName","variant","twMerge","Button","pending","type","className","children","disabled","props","PendingIcon","useConnectModal","useMutation","useConnectors","createClient","custom","getAddress","numberToHex","SwitchChainError","ChainNotConfiguredError","createConnector","createStore","persist","cache","listener","event","smartAccountActions","toCoinbaseSmartAccount","hashMessage","hashTypedData","createBridge","toWebAuthnAccount","parameters","id","publicKey","hash","bridge","signature","webauthn","message","getAccount","client","id","publicKeys","cache","publicKey","owners","toWebAuthnAccount","toCoinbaseSmartAccount","bytesToHex","hashMessage","bytesToHex","hexToBytes","concatBytes","utf8ToBytes","getMessageHash","webauthn","authenticatorData","challengeIndexRaw","clientDataJSON","typeIndexRaw","userVerificationRequired","typeIndex","challengeIndex","authenticatorDataBytes","flag","type","clientDataJSONHash","messageHash","parseSignature","serializePublicKey","secp256r1","getCandidatePublicKeys","input","r","s","candidate1","candidate2","findPublicKey","input1","input2","firstDuplicate","getCandidatePublicKeys","arr","seen","s","createBridge","reusePasskey","chain","bridge","challenge","hashMessage","bytesToHex","credentialId","signature","metadata","publicKey","cachedPublicKey","cache","messageHash","getMessageHash","challenge2","signature2","findPublicKey","state","createBridge","createPasskey","chain","bridge","credential","cache","state","resourceToHex","parseAbi","worldConfig","defaultClientConfig","unlimitedDelegationControlId","worldTables","worldAbi","viem_createBundlerClient","knownChainFees","createBundlerClient","paymasterAddress","config","chain","viem_createBundlerClient","defaultClientConfig","observer","transactionQueue","createClient","fallback","http","webSocket","privateKeyToAccount","generatePrivateKey","wiresaw","gasEstimator","userOpExecutor","getBundlerTransport","chain","bundlerHttpUrl","bundlerTransport","wiresaw","passkeyConnector","chainId","createConnector","config","chain","c","configTransport","transport","paymasterAddress","getPaymasterAddress","bundlerTransport","getBundlerTransport","client","createClient","defaultClientConfig","connected","cache","credentialId","createPasskey","account","getAccount","numberToHex","reusePasskey","params","accounts","id","SwitchChainError","ChainNotConfiguredError","a","getAddress","_connectInfo","_error","createBundlerClient","smartAccountActions","observer","_params","custom","usePasskeyConnector","connector","useConnectors","c","passkeyConnector","twMerge","jsx","jsxs","Logo","className","props","useQuery","usePreloadImage","url","resolve","reject","image","jsx","jsxs","AppInfo","appName","appIcon","useEntryKitConfig","hasAppIcon","appIconLoading","usePreloadImage","Logo","twMerge","jsx","jsxs","ConnectWallet","userAccount","useAccount","accountModalOpen","useAccountModal","openConnectModal","connectModalOpen","useConnectModal","passkeyConnector","usePasskeyConnector","createPasskey","useMutation","error","reusePasskey","hasPasskey","buttons","Button","AppInfo","useEffect","useMemo","useRef","useState","twMerge","parseEther","minGasBalance","useClient","queryOptions","useQuery","defineStore","parseAbi","paymasterAbi","paymasterConfig","paymasterTables","getRecord","getAllowance","client","paymasterAddress","userAddress","paymasterTables","getAllowanceQueryOptions","client","paymasterAddress","userAddress","queryKey","queryOptions","getAllowance","useAllowance","chainId","useEntryKitConfig","useClient","useQuery","useClient","queryOptions","useQuery","getRecord","getSpender","client","paymasterAddress","userAddress","sessionAddress","paymasterTables","getSpenderQueryOptions","client","paymasterAddress","userAddress","sessionAddress","queryKey","queryOptions","getSpender","useClient","queryOptions","useQuery","getRecord","getDelegation","client","worldAddress","userAddress","sessionAddress","getRecord","worldTables","unlimitedDelegationControlId","getDelegationQueryOptions","client","worldAddress","userAddress","sessionAddress","queryKey","queryOptions","getDelegation","queryOptions","useQuery","useQueryClient","useClient","useClient","queryOptions","useQuery","toCoinbaseSmartAccount","createStore","persist","store","signers","listener","event","generatePrivateKey","privateKeyToAccount","getSessionSigner","userAddress","sessionSignerPrivateKey","store","privateKey","state","getSessionAccount","client","userAddress","sessionSigner","getSessionSigner","toCoinbaseSmartAccount","getSessionAccountQueryOptions","client","userAddress","queryKey","queryOptions","getSessionAccount","useSessionAccount","chainId","useEntryKitConfig","useClient","useQuery","getPrequisitesQueryOptions","queryClient","client","userAddress","paymasterAddress","worldAddress","queryKey","queryOptions","sessionAddress","getSessionAccountQueryOptions","allowance","isSpender","hasDelegation","getAllowanceQueryOptions","getSpenderQueryOptions","getDelegationQueryOptions","hasAllowance","minGasBalance","usePrerequisites","useQueryClient","chainId","useEntryKitConfig","useClient","useQuery","useDisconnect","useQuery","useENS","address","normalizedAddress","data","res","jsx","jsxs","TruncatedHex","hex","jsx","jsxs","Wallet","isActive","isExpanded","userAddress","ens","useENS","disconnect","disconnectIsPending","useDisconnect","closeAccountModal","useAccountModal","TruncatedHex","Button","useMutation","useQueryClient","claimGasPass","useClaimGasPass","queryClient","chain","useEntryKitConfig","mutationKey","error","userAddress","twMerge","jsx","jsxs","EthIcon","className","props","formatEther","formatBalance","wei","formatted","magnitude","jsx","jsxs","Balance","wei","formatBalance","EthIcon","useEffect","jsx","jsxs","Allowance","isActive","isExpanded","userAddress","allowance","useAllowance","claimGasPass","useClaimGasPass","useEffect","timer","minGasBalance","Balance","PendingIcon","Button","encodeFunctionData","useMutation","useQueryClient","getAction","sendUserOperation","waitForUserOperationReceipt","waitForTransactionReceipt","useClient","resourceToHex","IBaseWorldAbi","viem_writeContract","getAction","toHex","signTypedData","callWithSignatureTypes","getRecord","modulesConfig","hexToResource","getAction","signCall","userClient","worldAddress","systemId","callData","initialNonce","client","nonce","systemNamespace","systemName","CallWithSignatureAbi","callWithSignature","sessionClient","opts","signature","signCall","getAction","viem_writeContract","useSetupSession","userClient","queryClient","useQueryClient","chainId","worldAddress","paymasterAddress","useEntryKitConfig","client","useClient","mutationKey","useMutation","error","sessionClient","registerSpender","registerDelegation","sessionAddress","txs","tx","callWithSignature","resourceToHex","encodeFunctionData","paymasterAbi","IBaseWorldAbi","unlimitedDelegationControlId","hash","receipt","getAction","waitForTransactionReceipt","calls","worldAbi","sendUserOperation","waitForUserOperationReceipt","useEffect","useClient","queryOptions","useQuery","smartAccountActions","callFrom","observer","getSessionClient","client","userAddress","sessionAccount","worldAddress","paymasterAddress","bundlerTransport","getBundlerTransport","createBundlerClient","smartAccountActions","callFrom","observer","getSessionClientQueryOptions","sessionAccount","client","userAddress","worldAddress","paymasterAddress","queryKey","queryOptions","getSessionClient","useSessionClient","chainId","useEntryKitConfig","useClient","useSessionAccount","useQuery","jsx","jsxs","Session","isActive","isExpanded","userClient","registerSpender","registerDelegation","sessionClient","useSessionClient","setup","useSetupSession","hasSession","useEffect","timer","Button","jsx","ConnectedSteps","userClient","initialUserAddress","userAddress","prerequisites","usePrerequisites","closeAccountModal","useAccountModal","isNewConnection","initialPrerequisites","useRef","useEffect","hasAllowance","isSpender","hasDelegation","steps","useMemo","props","Wallet","Allowance","Session","selectedStepId","useState","nextStep","step","completedSteps","activeStep","activeStepIndex","twMerge","i","isActive","isExpanded","isDisabled","useRef","jsx","AccountModalContent","chainId","useEntryKitConfig","userClient","useConnectorClient","userAddress","useAccount","initialUserAddress","ConnectWallet","ConnectedSteps","useState","ErrorBoundary","twMerge","BaseError","UserRejectedRequestError","jsx","jsxs","ErrorNotice","initialTitle","error","e","title","message","wait","twMerge","useIsMounted","jsx","jsxs","AccountModalErrorBoundary","children","isMounted","useIsMounted","retries","setRetries","useState","ErrorBoundary","error","resetErrorBoundary","twMerge","ErrorNotice","event","wait","value","PendingIcon","DialogClose","DialogTitle","twMerge","jsx","IconSVG","className","children","props","jsx","CloseIcon","props","IconSVG","jsx","jsxs","AccountModal","accountModalOpen","toggleAccountModal","useAccountModal","Modal","DialogTitle","twMerge","AccountModalErrorBoundary","AccountModalContent","Logo","DialogClose","CloseIcon","jsx","jsxs","EntryKitProvider","config","children","EntryKitConfigProvider","AccountModal","useAccount","twMerge","twMerge","Fragment","jsx","jsxs","AccountName","address","ens","useENS","avatar","usePreloadImage","Logo","TruncatedHex","useRef","jsx","jsxs","containerClassNames","twMerge","secondaryClassNames","secondaryInteractiveClassNames","AccountButton","openAccountModal","accountModalOpen","useAccountModal","status","userAddress","useAccount","initialUserAddress","prereqs","usePrerequisites","isConnected","isNewConnection","isSignedIn","buttonLabel","Shadow","AccountName","Logo","PendingIcon","useConnectorClient","useSessionClientReady","chainId","useEntryKitConfig","userClient","useConnectorClient","userAddress","prerequisites","usePrerequisites","sessionClient","useSessionClient","connectorsForWallets","getDefaultWallets","createConfig","iconUrl","passkeyWallet","opts","walletDetails","config","passkeyConnector","mapObject","wiresaw","createWagmiConfig","config","defaultWallets","getDefaultWallets","wallets","passkeyWallet","connectors","connectorsForWallets","createConfig","transport","connectorsForWallets","getDefaultWallets","getWallets","config","defaultWallets","getDefaultWallets","passkeyWallet","getConnectors","wallets","config","connectorsForWallets","getWallets"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@latticexyz/entrykit",
3
- "version": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
3
+ "version": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
4
4
  "description": "User onboarding flows for MUD apps",
5
5
  "repository": {
6
6
  "type": "git",
@@ -39,16 +39,16 @@
39
39
  "usehooks-ts": "^3.1.0",
40
40
  "webauthn-p256": "^0.0.10",
41
41
  "zustand": "^4.5.2",
42
- "@latticexyz/common": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
43
- "@latticexyz/config": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
44
- "@latticexyz/explorer": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
45
- "@latticexyz/id": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
46
- "@latticexyz/paymaster": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
47
- "@latticexyz/protocol-parser": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
48
- "@latticexyz/store": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
49
- "@latticexyz/wiresaw": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
50
- "@latticexyz/world": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2",
51
- "@latticexyz/world-modules": "2.2.15-entrykit-c1ba62d6e50bfa6fcec7150e5d0525d7cb1185c2"
42
+ "@latticexyz/common": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
43
+ "@latticexyz/config": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
44
+ "@latticexyz/explorer": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
45
+ "@latticexyz/id": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
46
+ "@latticexyz/paymaster": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
47
+ "@latticexyz/protocol-parser": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
48
+ "@latticexyz/store": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
49
+ "@latticexyz/wiresaw": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
50
+ "@latticexyz/world": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5",
51
+ "@latticexyz/world-modules": "2.2.15-entrykit-e48e9d8de80d80b7348c80a38d447530da689df5"
52
52
  },
53
53
  "devDependencies": {
54
54
  "@tanstack/react-query": "^5.56.2",