@spicenet-io/spiceflow-ui 1.10.6 → 1.10.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.cjs.js +6 -6
- package/dist/index.js +10 -10
- package/package.json +1 -1
package/dist/index.cjs.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"use client";
|
|
2
|
-
"use strict";var zs=Object.create;var $t=Object.defineProperty;var Vs=Object.getOwnPropertyDescriptor;var Ns=Object.getOwnPropertyNames;var Ys=Object.getPrototypeOf,qs=Object.prototype.hasOwnProperty;var Ps=(t,o,r,n)=>{if(o&&typeof o=="object"||typeof o=="function")for(let s of Ns(o))!qs.call(t,s)&&s!==r&&$t(t,s,{get:()=>o[s],enumerable:!(n=Vs(o,s))||n.enumerable});return t};var lt=(t,o,r)=>(r=t!=null?zs(Ys(t)):{},Ps(o||!t||!t.__esModule?$t(r,"default",{value:t,enumerable:!0}):r,t));const re=require("viem"),Tt=require("viem/actions"),At=require("viem/chains"),e=require("react/jsx-runtime"),a=require("react"),de=require("./Button-Cn16gFtO.js"),Js=require("react-dom"),Je=require("@privy-io/react-auth"),_t=require("@dynamic-labs/sdk-react-core"),Ye=require("@spicenet-io/spiceflow-core"),Ae=require("wagmi"),Zs=require("./auth-dynamic.cjs.js"),Gs=require("./auth-privy.cjs.js"),es=require("@tanstack/react-query"),ts=require("wagmi/chains"),ss=require("wagmi/connectors"),dt=[{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_spender",type:"address"},{name:"_value",type:"uint256"}],name:"approve",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[],name:"totalSupply",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transferFrom",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[{name:"_owner",type:"address"},{name:"_spender",type:"address"}],name:"allowance",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{payable:!0,stateMutability:"payable",type:"fallback"},{anonymous:!1,inputs:[{indexed:!0,name:"owner",type:"address"},{indexed:!0,name:"spender",type:"address"},{indexed:!1,name:"value",type:"uint256"}],name:"Approval",type:"event"},{anonymous:!1,inputs:[{indexed:!0,name:"from",type:"address"},{indexed:!0,name:"to",type:"address"},{indexed:!1,name:"value",type:"uint256"}],name:"Transfer",type:"event"}],os={11155111:{id:11155111,name:"Ethereum Sepolia",displayName:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/sepolia/b59c444a55b74d56b3f836d2dd7144eb",blockExplorers:{default:{name:"Etherscan",url:"https://sepolia.etherscan.io"}},viemChain:At.sepolia,delegateContract:"0xDF7d39BB544778F467D10b08B1F5C170fd7fB480",icon:{symbol:"\u039E",backgroundColor:"#627EEA",textColor:"#FFFFFF"},moralisName:"sepolia",supportedTokens:[{address:"0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238",name:"USD Coin",symbol:"USDC",decimals:6},{address:"0x76f983E0F5a4B72C4bac99Fc9399845a58078787",name:"Mock Tether USD",symbol:"USDT",decimals:6},{address:"0x4Fc381B6CC6Df8cF1c1bD46D184475bE5b7A3c62",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},421614:{id:421614,name:"Arbitrum Sepolia",displayName:"Arbitrum Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/arbitrum-sepolia/a3b4b1042f834a959541c96811ef44bb",blockExplorers:{default:{name:"Arbiscan",url:"https://sepolia.arbiscan.io"}},viemChain:At.arbitrumSepolia,delegateContract:"0x151755d1bdFeB6082D141EF86e4291b2e902b43F",icon:{symbol:"A",backgroundColor:"#28A0F0",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0xBeB51deb2018b67b35d5695Fd15bb30D452c7868",name:"USD Coin",symbol:"USDC",decimals:18},{address:"0xBA4c54d4CF10C766c22A08F783998cFaB237F7C9",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},84532:{id:84532,name:"Base Sepolia",displayName:"Base Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/base-sepolia/0563a61e273c428f906716cd4befa362",blockExplorers:{default:{name:"Basescan",url:"https://sepolia.basescan.org"}},viemChain:At.baseSepolia,delegateContract:"0xD4C4A222cdd42f5c3219249a083a5aBf1420E9D8",icon:{symbol:"B",backgroundColor:"#0052FF",textColor:"#FFFFFF"},moralisName:"0x14a34",supportedTokens:[{address:"0xf370dC3765f81aC9dD2FEBd59Fb4e710330B0BC8",name:"USD Coin",symbol:"USDC",decimals:18},{address:"0x16DD3a855433059Be478FAcb416D9aFed6CA96Ec",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},5115:{id:5115,name:"Citrea Testnet",displayName:"Citrea Testnet",nativeCurrency:{name:"cBTC",symbol:"cBTC",decimals:18},rpc:"https://rpc.testnet.citrea.xyz",blockExplorers:{default:{name:"Citrea Explorer",url:"https://explorer.testnet.citrea.xyz"}},viemChain:At.citreaTestnet,delegateContract:"0x9DE3D53419a8F821b6E2039A7249c5738004FB94",icon:{symbol:"C",backgroundColor:"#EA4B4B",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0xf19308F923582A6f7c465e5CE7a9Dc1BEC6665B1",name:"USD Coin",symbol:"USD",decimals:18},{address:"0x2876a1fb400c238b0a9e4edd2e7e03d3cf9b53c2",name:"CBTC Vault",symbol:"eCBTC",decimals:18,logoURI:"https://citrea.elitra.xyz/images/tokens/cbtc.jpg"},{address:"0x2d41d86bb9e7161561fa3186b47d160467efcee3",name:"NUSD Vault",symbol:"eNUSD",decimals:18,logoURI:"https://www.satsuma.exchange/nusd-icon.svg"},{address:"0x8d0c9d1c17aE5e40ffF9bE350f57840E9E66Cd93",name:"Wrapped Citrea BTC",symbol:"WCBTC",decimals:18,logoURI:"https://citrea.elitra.xyz/images/tokens/cbtc.jpg"}]},123420001114:{id:123420001114,name:"Base Camp",displayName:"Base Camp",nativeCurrency:{name:"Ethereum",symbol:"ETH",decimals:18},rpc:"https://rpc.basecamp.t.raas.gelato.cloud",blockExplorers:{default:{name:"Base Camp Explorer",url:"https://basecamp.gelato.network"}},viemChain:At.basecampTestnet,delegateContract:"0xA15BFeD4eC0BEdd36b00b9856aFa1C6BCFE61574",icon:{symbol:"B",backgroundColor:"#0052FF",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[]},688688:{id:688688,name:"Pharos Testnet",displayName:"Pharos Testnet",nativeCurrency:{name:"PHRS",symbol:"PHRS",decimals:18},rpc:"https://testnet.dplabs-internal.com",blockExplorers:{default:{name:"Pharos Explorer",url:"https://testnet.pharosscan.xyz"}},viemChain:re.defineChain({id:688688,name:"Pharos Testnet",nativeCurrency:{decimals:18,name:"PHRS",symbol:"PHRS"},rpcUrls:{default:{http:["https://testnet.dplabs-internal.com"]}},blockExplorers:{default:{name:"Pharos Explorer",url:"https://testnet.pharosscan.xyz"}},testnet:!0}),delegateContract:"0xAd45b774C4c632540d36f2105889C0E6aC28b504",icon:{symbol:"P",backgroundColor:"#4A90E2",textColor:"#FFFFFF"},moralisName:""},688689:{id:688689,name:"Pharos Testnet",displayName:"Pharos Testnet",nativeCurrency:{name:"PHRS",symbol:"PHRS",decimals:18},rpc:"https://atlantic.dplabs-internal.com",blockExplorers:{default:{name:"Pharos Atlantic Explorer",url:"https://atlantic.pharosscan.xyz/"}},viemChain:re.defineChain({id:688689,name:"Pharos Testnet",nativeCurrency:{decimals:18,name:"PHRS",symbol:"PHRS"},rpcUrls:{default:{http:["https://atlantic.dplabs-internal.com"]}},blockExplorers:{default:{name:"Pharos Atlantic Explorer",url:"https://atlantic.pharosscan.xyz/"}},testnet:!0}),delegateContract:"0xAd45b774C4c632540d36f2105889C0E6aC28b504",icon:{symbol:"P",backgroundColor:"#4A90E2",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0x16b90aeb3de140dde993da1d5734bca28574702b",name:"USD Stable Coin",symbol:"USD",decimals:6}]}},fe=t=>os[t],st=t=>fe(t)?.name||`Chain ${t}`,ct=t=>{const o=fe(t);if(!o)throw new Error(`Unsupported chain ID: ${t}`);return o.delegateContract},Wt=(t,o,r)=>{const n=fe(t);return n?.blockExplorers?.default?.url?`${n.blockExplorers.default.url}/tx/${o}`:"#"},Ve=t=>{const o=fe(t);if(!o)throw new Error(`Unsupported chain ID: ${t}`);return re.createPublicClient({chain:o.viemChain,transport:re.http(o.rpc)})},Ks=t=>{const o=fe(t);if(o)return{icon:o.icon.symbol,bg:o.icon.backgroundColor,text:o.icon.textColor};const r=`Chain ${t}`,n=r.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:r.charAt(0).toUpperCase()}},Os=()=>{const t={};return Object.values(os).forEach(o=>{t[o.id]={name:o.name,moralisName:o.moralisName||"",chain:o.viemChain,rpcUrl:o.rpc}}),t},Xs=t=>{const o=fe(t);if(!o)throw new Error(`Chain ${t} not supported`);return re.createPublicClient({chain:o.viemChain,transport:re.http(o.rpc)})},$s=(t,o,r=BigInt(0),n=0)=>({address:o.address,name:o.name,symbol:o.symbol,decimals:o.decimals,balance:r,balanceFormatted:n,balanceUsd:0,logoURI:o.logoURI,isNative:!1,chainId:t}),_s=(t,o=BigInt(0),r=0)=>{const n=fe(t);return n?{address:"0x0000000000000000000000000000000000000000",name:n.nativeCurrency.name,symbol:n.nativeCurrency.symbol,decimals:n.nativeCurrency.decimals,balance:o,balanceFormatted:r,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:t}:null},Rt=(t,o=[])=>{const r=fe(t);if(!r)return[];const n=[];if(![11155111,421614,84532,688689].includes(t)){const s=o.find(c=>c.chainId===t&&c.isNative);s?n.push(s):n.push(_s(t))}return r.supportedTokens&&r.supportedTokens.forEach(s=>{const c=o.find(i=>i.chainId===t&&i.address.toLowerCase()===s.address.toLowerCase());c?n.push(c):n.push($s(t,s))}),n},Dt=t=>{const o=t.toLowerCase();return o==="0x0"||o==="0x0000000000000000000000000000000000000000"||o==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"},wt=t=>Dt(t)?"0x0":t,ns=async(t,o)=>{const r=fe(t);if(!r)throw new Error(`Unsupported chain ID: ${t}`);const n=o.toLowerCase();if(Dt(n)){if(!r.nativeCurrency?.decimals)throw new Error(`Native currency decimals not configured for chain ${t}`);return r.nativeCurrency.decimals}if(r.supportedTokens){const s=r.supportedTokens.find(c=>c.address.toLowerCase()===n);if(s)return s.decimals}try{if(!re.isAddress(o))throw new Error(`Invalid token address: ${o}`);const s=re.getAddress(o),c=Ve(t),i=await Tt.readContract(c,{address:s,abi:dt,functionName:"decimals"});return Number(i)}catch(s){throw console.error(`Failed to fetch decimals for token ${o} on chain ${t}:`,s),new Error(`Could not determine decimals for token ${o} on chain ${t}`)}},eo=(t,o,r)=>{if(o===r)return t;if(o<r){const n=BigInt(10)**BigInt(r-o);return t*n}else{const n=BigInt(10)**BigInt(o-r);return t/n}},to="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJub25jZSI6ImVmMWEzZDM1LTYwMGUtNDcwNC04MTk3LTIzODc2NWNlYmQ2NCIsIm9yZ0lkIjoiNDY2Nzk0IiwidXNlcklkIjoiNDgwMjI3IiwidHlwZUlkIjoiMTk3YWMxMzMtNDY3ZS00YWIyLWFlZmUtM2VlMjU0NGNjM2NiIiwidHlwZSI6IlBST0pFQ1QiLCJpYXQiOjE3NTU5NjY3MjIsImV4cCI6NDkxMTcyNjcyMn0.7KHx_SwI89GVKFkgqtl-sUV9CUKWkDjZbkBAVAX2Djk",so="https://deep-index.moralis.io/api/v2.2",St=Os(),rs=Xs,as=async(t,o)=>{try{const r=rs(o),n=await Tt.getBalance(r,{address:t}),s=St[o],c=parseFloat((Number(n)/Math.pow(10,18)).toFixed(6));return{address:"0x0000000000000000000000000000000000000000",name:s.chain.nativeCurrency.name,symbol:s.chain.nativeCurrency.symbol,decimals:s.chain.nativeCurrency.decimals,balance:n,balanceFormatted:c,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:o}}catch(r){return console.error(`Error fetching native balance for ${o}:`,r),{address:"0x0000000000000000000000000000000000000000",name:St[o].chain.nativeCurrency.name,symbol:St[o].chain.nativeCurrency.symbol,decimals:18,balance:BigInt(0),balanceFormatted:0,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:o}}},is=async(t,o,r,n,s,c)=>{try{if(!re.isAddress(r))return console.warn(`Invalid token address ${r} for chain ${o}, skipping...`),null;const i=re.getAddress(r),d=re.isAddress(t)?re.getAddress(t):t,g=rs(o),f=await Tt.readContract(g,{address:i,abi:dt,functionName:"balanceOf",args:[d]}),u=parseFloat((Number(f)/Math.pow(10,c)).toFixed(6));return u>0?{address:i,name:n,symbol:s,decimals:c,balance:f,balanceFormatted:u,balanceUsd:0,logoURI:void 0,isNative:!1,chainId:o}:null}catch(i){return i?.message?.includes("checksum")||i?.message?.includes("Address")||i?.message?.includes("invalid")||console.error(`Error fetching ERC20 balance for ${r} on chain ${o}:`,i),null}},pt=async(t,o)=>{try{const r=St[o];if(!r.moralisName){const i=[],d=await as(t,o);d.balanceFormatted>0&&i.push(d);const g=fe(o);if(g?.supportedTokens&&g.supportedTokens.length>0){const f=g.supportedTokens.map(u=>is(t,o,u.address,u.name,u.symbol,u.decimals));(await Promise.allSettled(f)).forEach(u=>{u.status==="fulfilled"&&u.value&&i.push(u.value)})}return{tokens:i,chainId:o}}const n=await(await import("axios")).default.get(`${so}/wallets/${t}/tokens`,{params:{chain:r.moralisName},headers:{"X-API-Key":to}}),s=[],c=n.data?.result||[];console.log("allTokens",c);for(const i of c){const d=parseFloat(i.balance_formatted||"0");if(d>0){const g={address:i.token_address,name:i.name||"Unknown",symbol:i.symbol||"UNKNOWN",decimals:parseInt(i.decimals)||18,balance:BigInt(i.balance||"0"),balanceFormatted:d,balanceUsd:parseFloat(i.usd_value||"0"),logoURI:i.logo,isNative:i.native_token||!1,chainId:o};s.push(g)}}return{tokens:s,chainId:o}}catch(r){if(console.error(`Error fetching tokens for ${o}:`,r),!St[o].moralisName)try{const n=[],s=await as(t,o);s.balanceFormatted>0&&n.push(s);const c=fe(o);if(c?.supportedTokens&&c.supportedTokens.length>0){const i=c.supportedTokens.map(d=>is(t,o,d.address,d.name,d.symbol,d.decimals));(await Promise.allSettled(i)).forEach(d=>{d.status==="fulfilled"&&d.value&&n.push(d.value)})}return{tokens:n,chainId:o}}catch(n){console.error(`Fallback balance fetch failed for ${o}:`,n)}return{tokens:[],chainId:o}}},zt=async t=>{if(!t)throw new Error("Wallet address is required");console.log("Fetching multi-chain balances for:",t);const[o,r,n,s,c,i]=await Promise.allSettled([pt(t,11155111),pt(t,5115),pt(t,123420001114),pt(t,84532),pt(t,688689),pt(t,421614)]),d={};return o.status==="fulfilled"&&(d[11155111]=o.value),r.status==="fulfilled"&&(d[5115]=r.value),n.status==="fulfilled"&&(d[123420001114]=n.value),s.status==="fulfilled"&&(d[84532]=s.value),c.status==="fulfilled"&&(d[688689]=c.value),i.status==="fulfilled"&&(d[421614]=i.value),console.log("Balances:",d),d},Vt=({address:t,supportedChains:o,fetchBalances:r,refreshInterval:n=8e3})=>{const[s,c]=a.useState([]),[i,d]=a.useState(!1),[g,f]=a.useState(null),u=a.useRef(!0),l=a.useRef(t),C=a.useRef(o),A=a.useRef(r);a.useEffect(()=>{l.current=t,C.current=o,A.current=r},[t,o,r]);const w=a.useCallback(async()=>{const b=l.current,m=C.current,j=A.current;if(!b){c([]);return}u.current&&d(!0),f(null);try{const y=await j(b),h=Object.values(y).flatMap(x=>x.tokens.map(S=>({...S,chainId:x.chainId}))).filter(x=>m.includes(x.chainId));c(h)}catch(y){const h=y instanceof Error?y.message:"Failed to fetch assets";f(h),console.error("Error fetching assets:",y)}finally{u.current&&(d(!1),u.current=!1)}},[]),k=a.useCallback(b=>s.filter(m=>m.chainId===b),[s]),p=a.useCallback(()=>s.filter(b=>b.isNative),[s]);return a.useEffect(()=>{t&&(u.current=!0,w())},[t,w]),a.useEffect(()=>{if(!t||!n)return;const b=setInterval(()=>{w()},n);return()=>clearInterval(b)},[t,n]),{assets:s,loading:i,error:g,refreshAssets:w,getAssetsByChain:k,getNativeAssets:p}},kt=({checkStepStatus:t,pollingInterval:o=4e3})=>{const[r,n]=a.useState(null),[s,c]=a.useState(null),i=a.useRef(!1),d=a.useCallback(()=>{s&&(clearInterval(s),c(null))},[s]),g=a.useCallback(()=>{n(null),d()},[d]),f=a.useCallback((u,l)=>{d(),i.current=!1;const C={intentId:u,steps:l.map(k=>({...k,status:"pending"})),overallStatus:"processing"};n(C);const A=async()=>{i.current||n(k=>k?((async()=>{const p=[...k.steps];let b=!0,m=!1;for(let y=0;y<p.length;y++){const h=p[y];if(h.status!=="success"){if((h.stepId===0||y>0&&p[y-1].status==="success")&&(h.status==="pending"||h.status==="processing"))try{const x=await t(u,h.stepId);x.data.status==="success"?(p[y]={...h,status:"success",transactionHash:x.data.transactionHash},y+1<p.length&&p[y+1].status==="pending"&&(p[y+1]={...p[y+1],status:"processing"})):x.data.status==="executing"||x.data.status==="created"?p[y]={...h,status:"processing"}:x.data.status==="reverted"&&(p[y]={...h,status:"failed",transactionHash:x.data.transactionHash},m=!0)}catch(x){console.error(`Error checking step ${h.stepId}:`,x)}p[y].status!=="success"&&(b=!1)}}const j=m?"failed":b?"success":"processing";n(y=>y?{...y,steps:p,overallStatus:j}:null),(b||m)&&(i.current=!0,d())})().catch(()=>{}),k):null)};A();const w=setInterval(A,o);c(w)},[t,o,d]);return a.useEffect(()=>()=>{d()},[d]),{intentStatus:r,startStatusPolling:f,stopStatusPolling:d,clearStatus:g}},It=(t,o=4)=>t===0?"0":t<1e-4?"< 0.0001":t.toFixed(o),oo=(t,o=6,r=4)=>t.length<=o+r?t:`${t.slice(0,o)}...${t.slice(-r)}`,no=t=>oo(t,8,8),ls=t=>{const o=t.replace(/[^0-9.]/g,""),r=o.split(".");return r.length>2?r[0]+"."+r.slice(1).join(""):o},ro=async t=>{try{return await navigator.clipboard.writeText(t),!0}catch(o){return console.error("Failed to copy to clipboard:",o),!1}};var ut="",ao="";const io={USDC:ut,WBTC:ao},ot=({symbol:t,logoURI:o,size:r=20,theme:n})=>{const s=n||de.createTheme("dark"),c={width:`${r}px`,height:`${r}px`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${r*.4}px`,fontWeight:s.typography.fontWeight.bold,flexShrink:0,overflow:"hidden",backgroundColor:"#ffffff"},i=t.toUpperCase(),d=o||io[i];if(d)return e.jsx("img",{src:d,alt:t,style:{...c,objectFit:"cover"},onError:f=>{const u=f.target;u.style.display="none";const l=u.parentElement;l&&(l.innerHTML=Nt(t).icon,Object.assign(l.style,Nt(t).style))}});const g=Nt(t);return e.jsx("div",{style:{...c,...g.style},children:g.icon})},Nt=t=>{const o=t.toUpperCase(),r={ETH:{bg:"#627EEA",text:"#FFFFFF",icon:"\u039E"},BTC:{bg:"#F7931A",text:"#FFFFFF",icon:"\u20BF"},USDC:{bg:"#2775CA",text:"#FFFFFF"},USDT:{bg:"#26A17B",text:"#FFFFFF"},DAI:{bg:"#F5AC37",text:"#FFFFFF"},WETH:{bg:"#627EEA",text:"#FFFFFF",icon:"\u039E"},WBTC:{bg:"#F09242",text:"#FFFFFF",icon:"\u20BF"},CBTC:{bg:"#F7931A",text:"#FFFFFF",icon:"\u20BF"},USD:{bg:"#26A17B",text:"#FFFFFF",icon:"$"},MATIC:{bg:"#8247E5",text:"#FFFFFF"},AVAX:{bg:"#E84142",text:"#FFFFFF"},SOL:{bg:"#9945FF",text:"#FFFFFF"},DOT:{bg:"#E6007A",text:"#FFFFFF"},ADA:{bg:"#0033AD",text:"#FFFFFF"},LINK:{bg:"#375BD2",text:"#FFFFFF"},UNI:{bg:"#FF007A",text:"#FFFFFF"},AAVE:{bg:"#B6509E",text:"#FFFFFF"},CRV:{bg:"#40E0D0",text:"#000000"}}[o];if(r)return{style:{backgroundColor:r.bg,color:r.text},icon:r.icon||o.charAt(0)};const n=o.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:o.charAt(0)}},Ft=({chainId:t,name:o,size:r=16,theme:n})=>{const s=n||de.createTheme("dark"),c={width:`${r}px`,height:`${r}px`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${r*.5}px`,fontWeight:s.typography.fontWeight.bold,flexShrink:0},i=lo(t,o);return e.jsx("div",{style:{...c,backgroundColor:"style"in i?i.style?.backgroundColor:i.bg,color:"style"in i?i.style?.color:i.text},children:i.icon})},lo=(t,o)=>{if(t)return Ks(t);const r=o||"Unknown Chain",n=r.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:r.charAt(0).toUpperCase()}},ds=t=>{switch(t){case 11155111:return"Sepolia";case 421614:return"Arbitrum Sepolia";case 5115:return"Citrea Testnet";case 123420001114:return"Basecamp Testnet";case 84532:return"Base Sepolia";case 688689:return"Pharos Atlantic";default:return`Chain ${t}`}},cs=({selectedAsset:t,assets:o,onAssetSelect:r,showDropdown:n,onToggleDropdown:s,disabled:c=!1,theme:i})=>{const d=i||de.createTheme("dark"),g=a.useRef(null),f=a.useRef(null),u=a.useRef(null),[l,C]=a.useState(null);a.useEffect(()=>{if(n&&f.current){const I=()=>{if(f.current){const G=f.current.getBoundingClientRect();C({top:G.bottom+6,right:window.innerWidth-G.right})}};return I(),window.addEventListener("scroll",I,!0),window.addEventListener("resize",I),()=>{window.removeEventListener("scroll",I,!0),window.removeEventListener("resize",I)}}else C(null)},[n]),a.useEffect(()=>{const I=G=>{g.current&&!g.current.contains(G.target)&&u.current&&!u.current.contains(G.target)&&n&&s()};return n&&document.addEventListener("mousedown",I),()=>{document.removeEventListener("mousedown",I)}},[n,s]);const[A,w]=a.useState(!1),[k,p]=a.useState(!1),b={backgroundColor:"transparent",border:A?"1px solid #F4A5A5":"1px solid #CDCFD1",borderRadius:"6px",color:"#3c3e42",cursor:c?"not-allowed":"pointer",padding:"8px 12px 8px 8px",width:"100%",display:"flex",flexDirection:"column",gap:"4px",opacity:c?.6:1,transition:"all 0.15s ease",transform:k?"scale(0.98)":"scale(1)"},m={display:"flex",justifyContent:"space-between",alignItems:"center"},j={display:"flex",alignItems:"center",gap:"4px",paddingTop:"4px",borderTop:"1px solid #e5e7eb"},y=()=>l?{position:"fixed",top:`${l.top}px`,right:`${l.right}px`,backgroundColor:d.colors.secondary,border:`1px solid ${d.colors.border}`,borderRadius:d.borderRadius.md,boxShadow:d.shadows.lg,zIndex:100,width:"200px",maxHeight:"300px",overflow:"auto"}:{},h={backgroundColor:"transparent",border:"none",color:d.colors.text,cursor:"pointer",padding:d.spacing.sm,width:"100%",display:"flex",alignItems:"center",gap:d.spacing.sm,transition:`background-color ${d.animation.normal}`,":hover":{backgroundColor:d.colors.surfaceHover}},x={display:"flex",flexDirection:"column",alignItems:"flex-start",flex:1},S={fontSize:d.typography.fontSize.sm,fontWeight:d.typography.fontWeight.medium},F={fontSize:d.typography.fontSize.xs,color:d.colors.textMuted},B={transition:`transform ${d.animation.normal}`,transform:n?"rotate(180deg)":"rotate(0deg)"};return e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{position:"relative"},ref:g,children:e.jsxs("div",{ref:f,style:b,onClick:c?void 0:s,onMouseEnter:()=>w(!0),onMouseLeave:()=>{w(!1),p(!1)},onMouseDown:()=>p(!0),onMouseUp:()=>p(!1),children:[e.jsxs("div",{style:m,children:[e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(ot,{symbol:t.asset.symbol,logoURI:t.asset.logoURI,theme:d,size:30}),e.jsx("span",{style:{fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.asset.symbol})]}):e.jsx("span",{style:{fontSize:"14px",color:"#71757a"},children:"Select"})}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"#71757a",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",style:B,children:e.jsx("path",{d:"M6 9l6 6 6-6"})})]}),t?.asset&&e.jsxs("div",{style:j,children:[e.jsx(Ft,{chainId:t.asset.chainId,theme:d}),e.jsx("span",{style:{fontSize:"11px",color:"#71757a"},children:ds(t.asset.chainId)})]})]})}),n&&l&&Js.createPortal(e.jsx("div",{ref:u,style:y(),children:o.map(I=>e.jsxs("button",{style:h,onClick:()=>{r(I),s()},children:[e.jsx(ot,{symbol:I.symbol,logoURI:I.logoURI,theme:d},`${I.address}-${I.chainId}`),e.jsxs("div",{style:x,children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:d.spacing.xs},children:[e.jsx("span",{style:S,children:I.symbol}),e.jsx(Ft,{chainId:I.chainId,theme:d})]}),e.jsxs("span",{style:F,children:[It(I.balanceFormatted)," \u2022"," ",ds(I.chainId)]})]})]},`${I.address}-${I.chainId}`))}),document.body)]})},co=({assets:t,selectedAsset:o,onAssetSelect:r,onAmountChange:n,disabled:s=!1,loading:c=!1,label:i="Select Asset",showBalance:d=!0,showMaxButton:g=!0,placeholder:f="0.0",theme:u,styles:l,allowSecondAsset:C=!1,onAddAsset:A,canAddAsset:w=!1})=>{const k=u||de.createTheme("dark"),[p,b]=a.useState(!1),[m,j]=a.useState(null),[y,h]=a.useState(null),[x,S]=a.useState(o?.amount||""),F=a.useRef(null),B=a.useRef("");a.useEffect(()=>{const M=o?.asset?`${o.asset.chainId}-${o.asset.address}`:"";M!==B.current&&(S(o?.amount||""),B.current=M)},[o?.asset?.chainId,o?.asset?.address,o?.amount]);const I=M=>{const z=ls(M);if(!z){S(z),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(z)},300);return}if(o?.asset){const E=parseFloat(z),U=o.asset.balanceFormatted;if(!isNaN(E)&&E>U){const X=U.toString();S(X),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(X)},300);return}}S(z),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(z)},300)},G=M=>{if(o?.asset){const z=(o.asset.balanceFormatted*M/100).toString();S(z),F.current&&clearTimeout(F.current),n(z)}},P=o?.asset?.balanceFormatted??0,_=parseFloat(x)||0,$=P>0?_/P*100:0;a.useEffect(()=>()=>{F.current&&clearTimeout(F.current)},[]);const J={backgroundColor:l?.assetSelector?.backgroundColor||l?.secondaryBackground||"#e9e9e9",border:"0.5px solid #A8A8A7",borderRadius:l?.assetSelector?.borderRadius||"6px",padding:l?.assetSelector?.padding||"16px",height:"auto",minHeight:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative",opacity:s?.6:1};return c?e.jsx("div",{style:J,children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"16px",width:"60px"}}),e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"40px",width:"150px"}})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",gap:"8px"},children:[e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"12px",width:"80px"}}),e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"6px",height:"46px",width:"128px"}})]})]})}):e.jsxs("div",{style:J,children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:i}),d&&o?.asset&&e.jsxs("span",{style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:["Balance: ",It(o.asset.balanceFormatted)]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",flex:1},children:[e.jsx("input",{type:"text",value:x,onChange:M=>I(M.target.value),placeholder:f,disabled:s||!o?.asset,style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"40px",fontWeight:700,color:s?"rgba(14, 13, 11, 0.16)":x?"#0e0d0b":"#d1d5db",lineHeight:"1.08",letterSpacing:"-1.2px",backgroundColor:"transparent",border:"none",outline:"none",padding:0,width:"100%",maxWidth:"200px"}}),e.jsx("div",{style:{width:"128px",position:"relative",flexShrink:0},children:e.jsx(cs,{selectedAsset:o,assets:t,onAssetSelect:r,showDropdown:p,onToggleDropdown:()=>b(!p),disabled:s,theme:k})})]}),e.jsx("div",{style:{display:"flex",justifyContent:"flex-end",alignItems:"center",gap:"10px",height:"14px"},children:[0,25,50,75,100].map((M,z)=>{const E=Math.abs($-M)<1,U=z===4,X=M/100,ee=m===M,H=y===M;return e.jsx("button",{onClick:()=>G(M),onMouseEnter:()=>j(M),onMouseLeave:()=>{j(null),h(null)},onMouseDown:()=>h(M),onMouseUp:()=>h(null),disabled:s||!o?.asset,title:`${M}%`,style:{width:"14px",height:"14px",padding:0,border:"none",backgroundColor:"transparent",cursor:s||!o?.asset?"not-allowed":"pointer",opacity:E?1:ee?.8:.5,transform:H?"scale(0.85)":ee?"scale(1.15)":"scale(1)",transition:"all 0.15s ease"},children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:U?"#ea4b4b":"none",stroke:U?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!U&&X>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${X>.5?1:0} 1 ${7+6.84375*Math.sin(X*2*Math.PI)} ${7-6.84375*Math.cos(X*2*Math.PI)} Z`,fill:"#3C3E42"})]})},M)})})]})},ht=co,ps=({status:t,size:o=20,theme:r})=>{const n=r||de.createTheme("dark"),s={width:`${o}px`,height:`${o}px`,display:"flex",alignItems:"center",justifyContent:"center"};return(()=>{switch(t){case"success":return e.jsx("svg",{style:{...s,color:n.colors.success},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 13l4 4L19 7"})});case"failed":return e.jsx("svg",{style:{...s,color:n.colors.error},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M6 18L18 6M6 6l12 12"})});case"processing":return e.jsx("div",{style:{...s,border:`2px solid ${n.colors.primary}`,borderTop:"2px solid transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}});case"pending":default:return e.jsx("div",{style:{...s,border:`2px solid ${n.colors.textMuted}`,borderRadius:"50%",backgroundColor:n.colors.surface}})}})()},po=({step:t,explorerUrlBuilder:o,animationDelay:r=0,theme:n})=>{const s=n||de.createTheme("dark"),c=(()=>{switch(t.status){case"success":return{bg:`${s.colors.success}20`,border:s.colors.success};case"failed":return{bg:`${s.colors.error}20`,border:s.colors.error};case"processing":return{bg:`${s.colors.info}20`,border:s.colors.info};default:return{bg:s.colors.surface,border:s.colors.border}}})(),i=t.transactionHash&&o?o(t.chainId,t.transactionHash):null,d={display:"flex",alignItems:"center",gap:s.spacing.md,padding:s.spacing.md,borderRadius:s.borderRadius.lg,border:`1px solid ${c.border}`,backgroundColor:c.bg,transition:`all ${s.animation.normal}`,animation:t.status==="processing"?"pulse 2s infinite":void 0,animationDelay:`${r}ms`},g={flex:1,minWidth:0},f={display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:s.spacing.xs},u={fontSize:s.typography.fontSize.sm,fontWeight:s.typography.fontWeight.medium,color:s.colors.text},l={fontSize:s.typography.fontSize.xs,fontWeight:s.typography.fontWeight.medium,padding:`${s.spacing.xs} ${s.spacing.sm}`,borderRadius:s.borderRadius.full,backgroundColor:`${c.border}20`,color:c.border},C={fontSize:s.typography.fontSize.xs,color:s.colors.textMuted,marginBottom:s.spacing.xs},A={fontSize:s.typography.fontSize.xs,color:s.colors.textMuted,fontFamily:"IBM Plex Mono",marginTop:s.spacing.xs},w={fontSize:s.typography.fontSize.xs,backgroundColor:`${s.colors.info}20`,color:s.colors.info,border:"none",borderRadius:s.borderRadius.full,padding:`${s.spacing.xs} ${s.spacing.sm}`,cursor:"pointer",textDecoration:"none",display:"inline-flex",alignItems:"center",gap:s.spacing.xs,transition:`all ${s.animation.normal}`,":hover":{backgroundColor:`${s.colors.info}30`,color:s.colors.info}};return e.jsxs("div",{style:d,children:[e.jsx("div",{style:{flexShrink:0},children:e.jsx(ps,{status:t.status,theme:s})}),e.jsxs("div",{style:g,children:[e.jsxs("div",{style:f,children:[e.jsx("span",{style:u,children:t.chainName}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:s.spacing.sm},children:[e.jsx("span",{style:l,children:t.status.charAt(0).toUpperCase()+t.status.slice(1)}),t.status==="success"&&i&&e.jsxs("a",{href:i,target:"_blank",rel:"noopener noreferrer",style:w,title:"View on explorer",children:[e.jsx("svg",{width:"12",height:"12",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14"})}),"Explorer"]})]})]}),e.jsx("p",{style:C,children:t.description}),t.transactionHash&&e.jsx("p",{className:"ibm-plex-mono",style:A,children:no(t.transactionHash)})]})]})},uo=({intentStatus:t,onClose:o,onRetry:r,txType:n,onNewTx:s,explorerUrlBuilder:c,theme:i})=>{const d=i||de.createTheme("dark"),g={width:"100%",maxWidth:"28rem",margin:"0 auto",backgroundColor:d.colors.background,border:`1px solid ${d.colors.border}`,borderRadius:d.borderRadius.lg,padding:d.spacing.lg,color:d.colors.text},f={textAlign:"center",marginBottom:d.spacing.lg},u={width:"4rem",height:"4rem",margin:"0 auto",backgroundColor:d.colors.surface,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",border:`2px solid ${d.colors.border}`,marginBottom:d.spacing.md},l={fontSize:d.typography.fontSize.lg,fontWeight:d.typography.fontWeight.semibold,color:d.colors.text,marginBottom:d.spacing.sm},C={fontSize:d.typography.fontSize.sm,color:d.colors.textMuted},A={display:"flex",flexDirection:"column",gap:d.spacing.md,marginBottom:d.spacing.lg},w={padding:d.spacing.md,borderRadius:d.borderRadius.lg,marginBottom:d.spacing.lg},k={display:"flex",flexDirection:"column",gap:d.spacing.sm},p=(()=>{switch(t.overallStatus){case"success":return{title:`${n.charAt(0).toUpperCase()+n.slice(1)} completed successfully!`,description:"Your tokens are now available in your wallet",style:{...w,background:`linear-gradient(to right, ${d.colors.success}20, ${d.colors.success}10)`,border:`1px solid ${d.colors.success}`},icon:e.jsx("svg",{className:"w-4 h-4",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 13l4 4L19 7"})}),iconColor:d.colors.success};case"failed":return{title:"Transaction failed",description:"Please try again or contact support if the issue persists",style:{...w,background:`linear-gradient(to right, ${d.colors.error}20, ${d.colors.error}10)`,border:`1px solid ${d.colors.error}`},icon:e.jsx("svg",{className:"w-4 h-4",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z"})}),iconColor:d.colors.error};default:return{title:`Processing your ${n}...`,description:"This may take a few seconds to complete",style:{...w,background:`linear-gradient(to right, ${d.colors.primary}20, ${d.colors.primary}10)`,border:`1px solid ${d.colors.primary}`},icon:e.jsx("div",{style:{width:"1rem",height:"1rem",border:`2px solid ${d.colors.primary}`,borderTop:"2px solid transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),iconColor:d.colors.primary}}})();return e.jsxs("div",{style:g,children:[e.jsxs("div",{style:f,children:[e.jsx("div",{style:u,children:e.jsx(ps,{status:t.overallStatus,size:32,theme:d})}),e.jsx("h3",{style:l,children:t.overallStatus==="success"?`${n.charAt(0).toUpperCase()+n.slice(1)} Completed!`:t.overallStatus==="failed"?"Transaction Failed":`Processing ${n}`}),e.jsx("p",{style:C,children:t.overallStatus==="success"?`Your tokens have been successfully ${n}`:t.overallStatus==="failed"?"Something went wrong with your transaction":`Please wait while we process your ${n} across chains`})]}),e.jsx("div",{style:A,children:t.steps.map((b,m)=>e.jsx(po,{step:b,explorerUrlBuilder:c,animationDelay:m*100,theme:d},b.stepId))}),e.jsx("div",{style:p.style,children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:d.spacing.md},children:[e.jsx("div",{style:{width:"2rem",height:"2rem",backgroundColor:`${p.iconColor}20`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",color:p.iconColor},children:p.icon}),e.jsxs("div",{children:[e.jsx("p",{style:{color:p.iconColor,fontWeight:d.typography.fontWeight.medium,fontSize:d.typography.fontSize.sm,margin:0},children:p.title}),e.jsx("p",{style:{color:`${p.iconColor}CC`,fontSize:d.typography.fontSize.xs,margin:`${d.spacing.xs} 0 0 0`},children:p.description})]})]})}),e.jsxs("div",{style:k,children:[t.overallStatus==="success"&&s&&e.jsxs(de.Button,{variant:"success",fullWidth:!0,onClick:s,theme:d,children:["Start New ",n]}),t.overallStatus==="failed"&&r&&e.jsx(de.Button,{variant:"error",fullWidth:!0,onClick:r,theme:d,children:"Try Again"}),t.overallStatus==="processing"&&e.jsx(de.Button,{variant:"ghost",fullWidth:!0,onClick:o,theme:d,children:"Cancel & Close"})]})]})},ho=({config:t,onChange:o,theme:r,styles:n})=>{const s=r||de.createTheme("dark"),c=["0%","0.1%","0.5%","1%"],i=p=>{o({...t,slippage:p,customSlippage:p==="custom"?t.customSlippage:void 0})},d=p=>{o({...t,slippage:"custom",customSlippage:p})},g={backgroundColor:n?.slippageSettings?.backgroundColor,border:n?.slippageSettings?.borderColor?`1px solid ${n.slippageSettings.borderColor}`:void 0,borderRadius:n?.slippageSettings?.borderRadius,padding:n?.slippageSettings?.padding,marginBottom:s.spacing.sm},f={fontSize:n?.slippageSettings?.label?.fontSize||s.typography.fontSize.xs,color:n?.slippageSettings?.label?.color||s.colors.textMuted,fontWeight:n?.slippageSettings?.label?.fontWeight,fontFamily:n?.slippageSettings?.label?.fontFamily||n?.fontFamily||s.typography.fontFamily,marginBottom:"4px"},u={display:"grid",gridTemplateColumns:"repeat(5, 1fr)",gap:"6px",alignItems:"center"},l={backgroundColor:n?.slippageSettings?.presetButton?.backgroundColor||s.colors.secondary,border:`1px solid ${n?.slippageSettings?.presetButton?.borderColor||s.colors.border}`,borderRadius:n?.slippageSettings?.presetButton?.borderRadius||s.borderRadius.md,color:n?.slippageSettings?.presetButton?.color||s.colors.textSecondary,cursor:"pointer",fontSize:n?.slippageSettings?.presetButton?.fontSize||s.typography.fontSize.xs,fontWeight:n?.slippageSettings?.presetButton?.fontWeight,fontFamily:n?.slippageSettings?.presetButton?.fontFamily||n?.fontFamily||s.typography.fontFamily,padding:n?.slippageSettings?.presetButton?.padding||`${s.spacing.xs} 0`,textAlign:"center",transition:`all ${s.animation.normal}`,":hover":{backgroundColor:n?.slippageSettings?.presetButton?.hoverBackgroundColor||s.colors.surfaceHover,borderColor:s.colors.borderHover}},C={...l,backgroundColor:n?.slippageSettings?.presetButton?.activeBackgroundColor||n?.primaryColor||s.colors.primary,borderColor:n?.slippageSettings?.presetButton?.activeBorderColor||n?.primaryColor||s.colors.primary,color:n?.slippageSettings?.presetButton?.activeColor||s.colors.text},A={backgroundColor:n?.slippageSettings?.customInput?.backgroundColor||"transparent",border:`1px solid ${t.slippage==="custom"?n?.slippageSettings?.customInput?.focusBorderColor||n?.primaryColor||s.colors.primary:n?.slippageSettings?.customInput?.borderColor||s.colors.border}`,borderRadius:n?.slippageSettings?.customInput?.borderRadius||s.borderRadius.md,color:n?.slippageSettings?.customInput?.color||s.colors.text,fontSize:n?.slippageSettings?.customInput?.fontSize||s.typography.fontSize.xs,fontWeight:n?.slippageSettings?.customInput?.fontWeight,fontFamily:n?.slippageSettings?.customInput?.fontFamily||n?.fontFamily||s.typography.fontFamily,padding:n?.slippageSettings?.customInput?.padding||s.spacing.sm,textAlign:"center",paddingRight:"1.5rem",width:"100%",outline:"none","::placeholder":{color:s.colors.textMuted}},w={position:"relative",display:"flex",alignItems:"center"},k={position:"absolute",right:s.spacing.xs,fontSize:n?.slippageSettings?.customInput?.fontSize||s.typography.fontSize.xs,fontFamily:n?.slippageSettings?.customInput?.fontFamily||n?.fontFamily||s.typography.fontFamily,color:s.colors.textMuted,pointerEvents:"none"};return e.jsxs("div",{style:g,children:[e.jsx("div",{style:f,children:"Slippage Tolerance"}),e.jsxs("div",{style:u,children:[c.map(p=>e.jsx("button",{style:t.slippage===p?C:l,onClick:()=>i(p),children:p},p)),e.jsxs("div",{style:w,children:[e.jsx("input",{type:"text",style:A,placeholder:"Custom",value:t.customSlippage||"",onFocus:()=>i("custom"),onChange:p=>d(p.target.value)}),t.slippage==="custom"&&e.jsx("span",{style:k,children:"%"})]})]})]})},go=({assets:t,selectedAsset:o,onAssetSelect:r,onAmountChange:n,amount:s="",disabled:c=!1,loading:i=!1,label:d="Collateral",placeholder:g="0.0",theme:f,styles:u})=>{const l=f||de.createTheme("dark"),[C,A]=a.useState(!1),w=a.useCallback(()=>{A(B=>!B)},[]),k=a.useCallback(B=>{const I=ls(B);n?.(I)},[n]),p=a.useCallback(()=>{o&&n&&n(o.balanceFormatted.toString())},[o,n]),b={backgroundColor:u?.assetSelector?.backgroundColor||u?.secondaryBackground||l.colors.surface,border:`1px solid ${u?.assetSelector?.borderColor||l.colors.border}`,borderRadius:u?.assetSelector?.borderRadius||l.borderRadius.md,padding:u?.assetSelector?.padding||`${l.spacing.sm} ${l.spacing.md}`,transition:`border-color ${l.animation.normal}`,opacity:c?.6:1,color:l.colors.text},m={display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"6px"},j={fontSize:u?.assetSelector?.label?.fontSize||l.typography.fontSize.xs,color:u?.assetSelector?.label?.color||l.colors.textMuted,fontWeight:u?.assetSelector?.label?.fontWeight,fontFamily:u?.assetSelector?.label?.fontFamily||u?.fontFamily||l.typography.fontFamily},y={fontSize:u?.assetSelector?.balance?.fontSize||l.typography.fontSize.xs,color:u?.assetSelector?.balance?.color||l.colors.textMuted,fontWeight:u?.assetSelector?.balance?.fontWeight,fontFamily:u?.assetSelector?.balance?.fontFamily||u?.fontFamily||l.typography.fontFamily},h={display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"6px"},x={background:u?.assetSelector?.amountInput?.backgroundColor||"transparent",border:"none",outline:"none",fontSize:u?.assetSelector?.amountInput?.fontSize||l.typography.fontSize.xl,fontWeight:u?.assetSelector?.amountInput?.fontWeight||l.typography.fontWeight.medium,color:u?.assetSelector?.amountInput?.color||l.colors.text,fontFamily:u?.assetSelector?.amountInput?.fontFamily||u?.fontFamily||l.typography.fontFamily,width:"50%","::placeholder":{color:l.colors.textMuted}},S={display:"flex",justifyContent:"space-between",alignItems:"center"},F={background:u?.button?.backgroundColor||l.colors.secondary,border:"none",borderRadius:u?.button?.borderRadius||l.borderRadius.sm,color:u?.button?.color||l.colors.textMuted,cursor:"pointer",fontSize:u?.button?.fontSize||l.typography.fontSize.xs,fontWeight:u?.button?.fontWeight,fontFamily:u?.button?.fontFamily||u?.fontFamily||l.typography.fontFamily,padding:u?.button?.padding||`4px ${l.spacing.xs}`,transition:`color ${l.animation.normal}`,":hover":{color:l.colors.text}};return i?e.jsxs("div",{style:b,children:[e.jsxs("div",{style:m,children:[e.jsx("div",{style:{...j,backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"60px"}}),e.jsx("div",{style:{...y,backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"80px"}})]}),e.jsxs("div",{style:h,children:[e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"32px",width:"100px"}}),e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"40px",width:"120px"}})]}),e.jsx("div",{style:S,children:e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"50px"}})})]}):e.jsxs("div",{style:b,children:[e.jsxs("div",{style:m,children:[e.jsx("span",{style:j,children:d}),o&&e.jsxs("span",{style:y,children:["Balance: ",It(o.balanceFormatted)," ",o.symbol]})]}),e.jsxs("div",{style:h,children:[e.jsx("input",{type:"text",style:x,value:s,onChange:B=>k(B.target.value),placeholder:g,disabled:c||!o}),e.jsx("div",{style:{position:"relative",width:"120px"},children:e.jsx(cs,{selectedAsset:o?{asset:o,amount:""}:void 0,assets:t,onAssetSelect:r,showDropdown:C,onToggleDropdown:w,disabled:c,theme:l})})]}),e.jsxs("div",{style:S,children:[e.jsx("span",{style:y,children:o?`${It(o.balanceFormatted)} ${o.symbol}`:""}),o&&!c&&n&&e.jsx("button",{style:F,onClick:p,title:`Max: ${It(o.balanceFormatted,6)} ${o.symbol}`,children:"MAX"})]})]})},Ue=a.createContext(null),xo=({children:t,appId:o,supportedViemChains:r})=>{const[n,s]=a.useState(null),[c,i]=a.useState(!1);return a.useEffect(()=>{i(!0),typeof window<"u"&&import("@privy-io/react-auth").then(d=>{s(()=>d.PrivyProvider)}).catch(d=>{console.error("Failed to load Privy SDK:",d)})},[]),!c||!n?e.jsx(e.Fragment,{children:t}):e.jsx(n,{appId:o,config:{supportedChains:r,appearance:{loginMessage:"Log in or create your Spicenet account",accentColor:"#ea4b4b",theme:"#fafafa",showWalletLoginFirst:!1,walletChainType:"ethereum-only",walletList:["detected_ethereum_wallets","metamask","coinbase_wallet","base_account","rainbow","wallet_connect"]},loginMethods:["google","email","passkey"],fundingMethodConfig:{moonpay:{useSandbox:!0}},embeddedWallets:{requireUserPasswordOnCreate:!1,showWalletUIs:!0,ethereum:{createOnLogin:"users-without-wallets"},solana:{createOnLogin:"off"}},mfa:{noPromptOnMfaRequired:!1},externalWallets:{}},children:t})},fo=({children:t,environmentId:o})=>{const[r,n]=a.useState(null),[s,c]=a.useState(!1);return a.useEffect(()=>{c(!0),typeof window<"u"&&Promise.all([import("@dynamic-labs/sdk-react-core"),import("@dynamic-labs/ethereum")]).then(([i,d])=>{n({DynamicContextProvider:i.DynamicContextProvider,EthereumWalletConnectors:d.EthereumWalletConnectors})}).catch(i=>{})},[]),!s||!r?e.jsx(e.Fragment,{children:t}):e.jsx(r.DynamicContextProvider,{settings:{environmentId:o,walletConnectors:[r.EthereumWalletConnectors]},children:t})},mo=({children:t,provider:o,privyAppId:r,dynamicEnvironmentId:n,supportedChainIds:s=[11155111,421614,5115,123420001114],mode:c="7702",nativeChainId:i,appName:d="Spicenet"})=>{const g=s.map(f=>fe(f)?.viemChain).filter(Boolean);return c!=="7702"?(console.log(`[SpiceFlow] Running in ${c} mode - skipping embedded wallet providers`),e.jsx(Ue.Provider,{value:{provider:o,supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:t})):o==="privy"?r?e.jsx(Ue.Provider,{value:{provider:"privy",supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:e.jsx(xo,{appId:r,supportedViemChains:g,children:t})}):(console.warn("[SpiceFlow] Privy provider selected but no appId provided"),e.jsx(e.Fragment,{children:t})):o==="dynamic"?n?e.jsx(Ue.Provider,{value:{provider:"dynamic",supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:e.jsx(fo,{environmentId:n,children:t})}):(console.warn("[SpiceFlow] Dynamic provider selected but no environmentId provided"),e.jsx(e.Fragment,{children:t})):(console.warn("[SpiceFlow] No valid provider configuration found"),e.jsx(e.Fragment,{children:t}))},yo=()=>{const[t,o]=a.useState(!1);let r=null,n=null;try{r=_t.useDynamicContext()}catch(g){n=g instanceof Error?g.message:String(g),console.log("Dynamic context error in useWallet:",n)}if(a.useEffect(()=>{o(!0)},[]),n)return{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:"dynamic",actions:{signAuthorization:async()=>{throw new Error("Dynamic context not available")},signMessage:async()=>{throw new Error("Dynamic context not available")}}};const{user:s,primaryWallet:c}=r||{},i=!!s,d=c?.address;return{isReady:t&&!!r,isAuthenticated:i,isConnected:i&&!!d,address:d,provider:"dynamic",actions:{signAuthorization:async g=>{if(!c)throw new Error("Dynamic primary wallet not available");const{isEthereumWallet:f}=await import("@dynamic-labs/ethereum");throw f(c)?new Error("Dynamic EIP-7702 authorization not yet implemented - check Dynamic docs for your version"):new Error("Primary wallet is not an Ethereum wallet")},signMessage:async g=>{if(!c)throw new Error("Dynamic primary wallet not available");const{isEthereumWallet:f}=await import("@dynamic-labs/ethereum");if(!f(c))throw new Error("Primary wallet is not an Ethereum wallet");const u=typeof g=="object"&&"raw"in g?{raw:g.raw}:g;return{signature:await(await c.getWalletClient()).signMessage({message:u,account:c.address})}}}}},gt=()=>{const t=a.useContext(Ue),o=t?.mode||"7702";let r=null;try{r=Je.useWallets()}catch{r=null}const n=r?.wallets?.find(i=>i.connectorType==="embedded")?.address;let s=null;try{s=_t.useDynamicContext()}catch{s=null}const c=s?.primaryWallet?.address;if(!(!t||o!=="7702"))return t.provider==="privy"?n:t.provider==="dynamic"?c:n??c},bo=()=>{const[t,o]=a.useState(!1);let r=null,n=null,s=null,c=null;try{r=Je.usePrivy(),n=Je.useSign7702Authorization(),s=Je.useSignMessage(),c=Je.useWallets()}catch{return{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:null,actions:{signAuthorization:async()=>{throw new Error("Privy not available")},signMessage:async()=>{throw new Error("Privy not available")}}}}a.useEffect(()=>{o(!0)},[]);const{ready:i=!1,authenticated:d=!1}=r||{},g=gt(),f=c?.wallets?.find(u=>u.connectorType==="embedded");return{isReady:i,isAuthenticated:d,isConnected:i&&d&&!!g,address:g,provider:"privy",actions:{signAuthorization:async u=>{if(!n)throw new Error("Privy sign authorization not available");try{const l=await n.signAuthorization({contractAddress:u.contractAddress,chainId:u.chainId,nonce:u.nonce},{address:g});return delete l.v,l}catch(l){const C=l?.message||String(l);throw C.includes("not configured")||C.includes("chain")?new Error(`Chain ${u.chainId} is not configured in PrivyProvider. Add this chain to your Privy dashboard or supportedChainIds.`):l}},signMessage:async u=>{if(typeof u=="object"&&"raw"in u){if(!f)throw new Error("Embedded wallet not available for raw signing");const l=await f.getEthereumProvider();return{signature:await re.createWalletClient({account:f.address,transport:re.custom(l)}).signMessage({account:f.address,message:{raw:u.raw}})}}if(!s)throw new Error("Privy sign message not available");return{signature:(await s.signMessage({message:u})).signature}}}}},Lt=()=>{const t=a.useContext(Ue)?.provider;return t==="privy"?bo():t==="dynamic"?yo():{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:null,actions:{signAuthorization:async()=>{throw new Error("No wallet provider available")},signMessage:async()=>{throw new Error("No wallet provider available")}}}},Yt=process.env.NEXT_PUBLIC_RELAYER_API_URL||"https://tx-submission-api-dev.spicenet.io";class Co{constructor(){this.baseUrl=Yt}async createAction(o){const r=await fetch(`${this.baseUrl}/actions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o,(n,s)=>typeof s=="bigint"?s.toString():s)});if(!r.ok){const n=await r.text();throw new Error(`Relayer API error: ${r.status} - ${n}`)}return r.json()}async executeStep(o,r,n,s){const c=await fetch(`${this.baseUrl}/actions/${o}/intents/${r}/steps/${n}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(s)});if(!c.ok){const i=await c.text();throw new Error(`Execute step error: ${c.status} - ${i}`)}return{success:!0}}async checkStepStatus(o,r){const n=o.split("/");let s="";if(n.length>=2){const d=n[0],g=n[1];s=`${this.baseUrl}/actions/${d}/intents/${g}/steps/${r}`}else s=`${this.baseUrl}/actions/${o}/intents/0/steps/${r}`;const c=await fetch(s);if(!c.ok)throw new Error(`Intent step status check failed: ${c.status}`);const i=await c.json();return{success:!0,data:{status:i.status==="error"?"reverted":i.status,transactionHash:i.txid}}}async submitSpiceDeposit(o){const r=o.isDeposit?"deposit":"withdrawal";try{const n=await fetch(`${this.baseUrl}/spicedeposit`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o)}),s=await n.json();return!n.ok||!s.success?(console.error(`Failed to submit ${r} request to API:`,s.error?.message),{success:!1,error:s.error}):s}catch(n){return console.error(`Error submitting ${r} request to API:`,n),{success:!1,error:{message:n instanceof Error?n.message:"Unknown error"}}}}async requestSpiceUsdAirdrop(o){try{const r=await fetch(`${this.baseUrl}/airdrop/${o.chainId}/spiceUsd`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({wallet:o.address})}),n=await r.json().catch(()=>({}));if(!r.ok){const s=n&&(n.error||n.message)||"Failed to request airdrop";return{success:!1,errorMessage:String(s)}}return n&&typeof n.error=="string"?{success:!1,errorMessage:n.error}:n&&(n.txHash||n.amount)?{success:!0,txHash:n.txHash,amount:n.amount}:{success:!0}}catch(r){return{success:!1,errorMessage:r?.message&&typeof r.message=="string"?r.message:"Failed to request airdrop"}}}}const we=new Co,Et=(t,o)=>{const r=s=>o?o(s):st(s),n=[];return t.forEach((s,c)=>{if(s.calls&&s.calls.length>0){const i={stepId:c,status:c===0?"processing":"pending",chainId:s.chainId,chainName:r(s.chainId),description:"Processing transaction"};n.push(i)}}),n},Ao=({swapBatches:t,tokenAddress:o="0x0",supportedChains:r,theme:n="light",styles:s,className:c="",showSlippageSettings:i=!0,enableFlipSwap:d=!0,fromInputHook:g,toInputUpdateHook:f})=>{const u=de.createTheme(n),l={...u,typography:{...u.typography,fontFamily:s?.fontFamily||u.typography.fontFamily},colors:{...u.colors,primary:s?.primaryColor||u.colors.primary,primaryHover:s?.primaryColor?`${s.primaryColor}dd`:u.colors.primaryHover}},C=Lt(),{isReady:A,isAuthenticated:w,isConnected:k,address:p,provider:b,actions:m}=C,j=a.useContext(Ue),[y,h]=a.useState(null),[x,S]=a.useState(null),[F,B]=a.useState(null),[I,G]=a.useState(""),[P,_]=a.useState({slippage:"0.5%"}),[$,J]=a.useState(!1),[M,z]=a.useTransition(),{assets:E,loading:U,error:X,refreshAssets:ee}=Vt({address:p,supportedChains:r,fetchBalances:zt}),[H,ne]=a.useState(!1),[xe,ue]=a.useState(null),{intentStatus:Ee,startStatusPolling:R,clearStatus:q}=kt({checkStepStatus:(W,K)=>we.checkStepStatus(W,K)}),pe=a.useCallback(()=>{if(E.length===0||F)return;const W=E.filter(ie=>ie.isNative),K=W.length>0?W[0]:E[0];K&&B(K)},[E,F]);a.useEffect(()=>{pe()},[pe]),a.useEffect(()=>{f&&f.toAmount!==x?.amount&&x&&S({...x,amount:f.toAmount})},[f?.toAmount,x]);const v=a.useCallback(()=>{ue(null)},[]),N=(W,K)=>W.chainId===K.chainId&&W.address.toLowerCase()===K.address.toLowerCase(),O=(W,K)=>{if(K==="collateral"){const ie=E.filter(me=>!N(me,W));return ie.length>0?ie[0]:null}else{const ie=r.flatMap(me=>Rt(me,E)).filter(me=>!N(me,W));return ie.length>0?ie[0]:null}},se=W=>{if(x&&N(x.asset,W)){const K=O(W,"fromTo");S(K?{asset:K,amount:""}:null)}if(F&&N(F,W)){const K=O(W,"collateral");B(K)}h({asset:W,amount:y?.amount||""}),v()},ae=W=>{if(y&&N(y.asset,W)){const K=O(W,"fromTo");h(K?{asset:K,amount:""}:null)}if(F&&N(F,W)){const K=O(W,"collateral");B(K)}S({asset:W,amount:x?.amount||""}),v()},Z=W=>{if(y&&N(y.asset,W)){const K=O(W,"fromTo");h(K?{asset:K,amount:""}:null)}if(x&&N(x.asset,W)){const K=O(W,"fromTo");S(K?{asset:K,amount:""}:null)}B(W),v()},he=a.useCallback(W=>{y&&(z(()=>{h({...y,amount:W}),x&&S({...x,amount:W}),G(W),v()}),g&&g.setFromAmount(W))},[y,x,g,v]),Ce=a.useCallback(W=>{x&&z(()=>{S({...x,amount:W}),y&&h({...y,amount:W}),G(W),v()})},[x,y,v]),T=a.useCallback(W=>{z(()=>{G(W),y&&h({...y,amount:W}),x&&S({...x,amount:W}),v()})},[y,x,v]),oe=a.useCallback(()=>{if(d&&y&&x){const W=y.amount;z(()=>{h({asset:x.asset,amount:W}),S({asset:y.asset,amount:W}),G(W),J(!$),v()})}},[d,y,x,$,v]),le=async()=>{if(!y||!x||!F||!p||t.length===0)return;const W=j?.mode||"7702";if(W==="7702"&&(!A||!w)){ue(`Please authenticate with ${b||"wallet provider"} to continue`);return}if(W!=="7702"){ue("Only EIP-7702 mode is currently supported for Swaps.");return}ne(!0),ue(null);try{const K=await Ve(F.chainId).getBlockNumber(),ie=[{chainId:F.chainId,recentBlock:K,calls:[{to:"0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",value:re.parseEther(I),data:"0x"}]},...t],me=[...new Set(ie.map(be=>be.chainId))],$e=[];for(const be of me){const Re=Ve(be),ge=ct(be),nt=await Ye.getAccountNonce(p,Re),tt=await m.signAuthorization({contractAddress:ge,chainId:be,nonce:Number(nt)});$e.push(tt)}const Y=Ye.hashChainBatches(ie),te=Math.floor(Date.now()/1e3)+60*10,Fe=Ye.getIntentHash(BigInt(0),BigInt(te),Y),De=await m.signMessage({raw:Fe}),_e=typeof De=="string"?De:De.signature;if(!_e)throw new Error("Failed to sign intent authorization");const at={mode:"7702",signatureType:"ecdsa",signature:_e,nbf:0,exp:te,chainBatches:Y.map(be=>({hash:be.hash,chainId:Number(be.chainId),tokenTransfers:[],calls:be.calls}))},et={user:p,chainAuthorizations:$e.map(be=>({...be,r:be.r,s:be.s,nonce:Number(be.nonce),chainId:Number(be.chainId)})),intents:[at]},Ze=await we.createAction(et);if(Ze){const be=Et(ie,Re=>`Chain ${Re}`);R(Ze.intentIds[0],be);for(let Re=0;Re<ie.length;Re++)console.log(`[SwapWidget] Executing step ${Re}...`),await we.executeStep(Ze.actionId,0,Re,{action:"execute"}),console.log(`[SwapWidget] Step ${Re} completed`);console.log("[SwapWidget] All steps executed"),ee()}}catch(K){const ie=K instanceof Error?K.message:"Swap failed";ue(ie)}finally{ne(!1)}},Se=r.flatMap(W=>Rt(W,E)),ve=r.flatMap(W=>Rt(W,E)),ke=E.filter(W=>r.includes(W.chainId)),Ie=y&&x&&F&&y.amount&&parseFloat(y.amount)>0&&parseFloat(y.amount)<=y.asset.balanceFormatted&&I&&parseFloat(I)>0&&parseFloat(I)<=F.balanceFormatted&&k&&!H&&t.length>0,ce=X||xe,ze={backgroundColor:s?.container?.backgroundColor||s?.primaryBackground||l.colors.background,border:`1px solid ${s?.container?.borderColor||l.colors.border}`,borderRadius:s?.container?.borderRadius||l.borderRadius.lg,padding:s?.container?.padding||l.spacing.md,width:s?.container?.width||"100%",maxWidth:"28rem",margin:"0 auto",color:l.colors.text,fontFamily:l.typography.fontFamily,boxShadow:s?.container?.boxShadow||(l.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")};return Ee?e.jsx("div",{className:c,children:e.jsx(uo,{intentStatus:Ee,onClose:q,onRetry:()=>{q(),le()},txType:"swap",onNewTx:()=>{q(),h(null),S(null),B(null),G(""),ee()},explorerUrlBuilder:(W,K)=>Wt(W,K),theme:l})}):e.jsxs("div",{style:ze,className:c,children:[e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsxs("div",{style:{padding:s?.statusDisplay?.padding||"8px",backgroundColor:s?.statusDisplay?.backgroundColor||s?.tertiaryBackground||(l.mode==="light"?"#f9fafb":l.colors.surface),border:`1px solid ${s?.statusDisplay?.borderColor||(l.mode==="light"?"#e5e7eb":l.colors.border)}`,borderRadius:s?.statusDisplay?.borderRadius||l.borderRadius.md},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("span",{style:{fontSize:s?.statusDisplay?.text?.fontSize||l.typography.fontSize.xs,fontWeight:s?.statusDisplay?.text?.fontWeight||l.typography.fontWeight.medium,color:s?.statusDisplay?.text?.color||l.colors.text,fontFamily:s?.statusDisplay?.text?.fontFamily||l.typography.fontFamily},children:[j?.provider==="privy"?"Privy":j?.provider==="dynamic"?"Dynamic":"Wallet"," ","Status"]}),e.jsx("span",{style:{fontSize:s?.statusDisplay?.text?.fontSize||l.typography.fontSize.xs,padding:`2px ${l.spacing.xs}`,borderRadius:l.borderRadius.sm,border:`1px solid ${k?s?.statusDisplay?.successColor||l.colors.success:s?.statusDisplay?.warningColor||l.colors.warning}`,backgroundColor:k?l.mode==="light"?"#dcfce7":`${s?.statusDisplay?.successColor||l.colors.success}20`:l.mode==="light"?"#fef3c7":`${s?.statusDisplay?.warningColor||l.colors.warning}20`,color:k?s?.statusDisplay?.successColor||l.colors.success:s?.statusDisplay?.warningColor||l.colors.warning,fontFamily:s?.statusDisplay?.text?.fontFamily||l.typography.fontFamily},children:k?"Connected":"Disconnected"})]}),k&&p&&e.jsxs("div",{className:"ibm-plex-mono",style:{marginTop:"6px",backgroundColor:s?.addressDisplay?.backgroundColor||(l.mode==="light"?"#f3f4f6":l.colors.secondary),border:`1px solid ${s?.addressDisplay?.borderColor||(l.mode==="light"?"#d1d5db":l.colors.borderHover)}`,borderRadius:s?.addressDisplay?.borderRadius||l.borderRadius.sm,padding:s?.addressDisplay?.padding||`${l.spacing.xs} ${l.spacing.sm}`,fontSize:s?.addressDisplay?.fontSize||l.typography.fontSize.xs,fontFamily:s?.addressDisplay?.fontFamily||(s?.fontFamily?`${s.fontFamily}, IBM Plex Mono`:"IBM Plex Mono"),color:s?.addressDisplay?.color||l.colors.text,display:"flex",alignItems:"center",gap:l.spacing.sm},children:[e.jsxs("span",{style:{flex:1},children:[p.slice(0,6),"...",p.slice(-4)]}),e.jsx("button",{style:{fontSize:s?.addressDisplay?.copyButton?.fontSize||l.typography.fontSize.xs,padding:s?.addressDisplay?.copyButton?.padding||`${l.spacing.xs} ${l.spacing.sm}`,backgroundColor:s?.addressDisplay?.copyButton?.backgroundColor||(l.mode==="light"?"#e5e7eb":l.colors.surfaceHover),border:`1px solid ${s?.addressDisplay?.copyButton?.borderColor||(l.mode==="light"?"#d1d5db":l.colors.border)}`,borderRadius:s?.addressDisplay?.copyButton?.borderRadius||l.borderRadius.sm,color:s?.addressDisplay?.copyButton?.color||l.colors.text,fontFamily:s?.addressDisplay?.copyButton?.fontFamily||l.typography.fontFamily,cursor:"pointer",transition:`background-color ${l.animation.normal}`},onClick:()=>ro(p),title:"Copy address",children:"Copy"})]}),!A&&e.jsxs("div",{style:{marginTop:"6px",fontSize:l.typography.fontSize.xs,color:l.colors.textSecondary,fontFamily:l.typography.fontFamily},children:["Loading"," ",j?.provider==="privy"?"Privy":j?.provider==="dynamic"?"Dynamic":"Wallet","..."]})]})]}),e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(go,{assets:ke,selectedAsset:F,onAssetSelect:Z,onAmountChange:T,amount:I,loading:U,label:"Collateral",theme:l,styles:s})]}),e.jsx("div",{style:{marginBottom:0},children:e.jsx(ht,{assets:Se,selectedAsset:y||void 0,onAssetSelect:se,onAmountChange:he,loading:U,label:"From",showBalance:!0,showMaxButton:!0,theme:l,styles:s})}),d&&e.jsx("div",{style:{display:"flex",justifyContent:"center",margin:`-${l.spacing.sm} 0`,position:"relative",zIndex:10},children:e.jsx("button",{onClick:oe,disabled:H||U,style:{backgroundColor:s?.flipButton?.backgroundColor||l.colors.primary,border:`1px solid ${s?.flipButton?.borderColor||l.colors.primary}`,borderRadius:s?.flipButton?.borderRadius||"50%",width:s?.flipButton?.size||"2.5rem",height:s?.flipButton?.size||"2.5rem",display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",color:s?.flipButton?.color||"#ffffff",transition:`all ${l.animation.normal}`,transform:$?"rotate(180deg)":"rotate(0deg)",boxShadow:l.mode==="light"?"0 2px 4px rgba(0, 0, 0, 0.1)":"0 2px 4px rgba(0, 0, 0, 0.3)"},onMouseEnter:W=>{W.currentTarget.style.backgroundColor=s?.flipButton?.hoverBackgroundColor||l.colors.primaryHover,W.currentTarget.style.transform=$?"rotate(360deg) scale(1.1)":"rotate(0deg) scale(1.1)"},onMouseLeave:W=>{W.currentTarget.style.backgroundColor=s?.flipButton?.backgroundColor||l.colors.primary,W.currentTarget.style.transform=$?"rotate(360deg) scale(1)":"rotate(0deg) scale(1)"},children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"M6 9l6 6 6-6"})})})}),e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(ht,{assets:ve,selectedAsset:x||void 0,onAssetSelect:ae,onAmountChange:Ce,loading:U,label:"To",theme:l,styles:s})]}),i&&e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(ho,{config:P,onChange:_,theme:l,styles:s})]}),t.length>0&&e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsxs("div",{style:{backgroundColor:s?.infoCard?.backgroundColor||s?.tertiaryBackground||(l.mode==="light"?"#f9fafb":l.colors.surface),border:`1px solid ${s?.infoCard?.borderColor||(l.mode==="light"?"#e5e7eb":l.colors.border)}`,borderRadius:s?.infoCard?.borderRadius||l.borderRadius.md,padding:s?.infoCard?.padding||l.spacing.sm},children:[e.jsx("div",{style:{fontSize:s?.infoCard?.title?.fontSize||l.typography.fontSize.xs,fontWeight:s?.infoCard?.title?.fontWeight||l.typography.fontWeight.medium,color:s?.infoCard?.title?.color||l.colors.text,fontFamily:s?.infoCard?.title?.fontFamily||l.typography.fontFamily,marginBottom:"4px"},children:"Swap Batches Ready"}),e.jsxs("div",{style:{fontSize:s?.infoCard?.description?.fontSize||l.typography.fontSize.xs,color:s?.infoCard?.description?.color||l.colors.textSecondary,fontFamily:s?.infoCard?.description?.fontFamily||l.typography.fontFamily},children:[t.length," swap batch",t.length>1?"es":""," across chains:"," ",[...new Set(t.map(W=>W.chainId))].join(", ")]})]})]}),ce&&e.jsx("div",{style:{backgroundColor:s?.errorMessage?.backgroundColor||(l.mode==="light"?"#fef2f2":`${s?.statusDisplay?.errorColor||l.colors.error}20`),border:`1px solid ${s?.errorMessage?.borderColor||(l.mode==="light"?"#fecaca":s?.statusDisplay?.errorColor||l.colors.error)}`,borderRadius:s?.errorMessage?.borderRadius||l.borderRadius.md,padding:s?.errorMessage?.padding||l.spacing.md,marginBottom:l.spacing.sm},children:e.jsx("p",{style:{color:s?.errorMessage?.color||s?.statusDisplay?.errorColor||l.colors.error,fontSize:s?.errorMessage?.fontSize||l.typography.fontSize.sm,fontWeight:s?.errorMessage?.fontWeight,fontFamily:s?.errorMessage?.fontFamily||l.typography.fontFamily,margin:0},children:ce})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:l.spacing.sm},children:e.jsx(de.Button,{variant:"primary",fullWidth:!0,onClick:le,loading:H,disabled:!Ie||!k,theme:l,styles:s,children:A?w?k?H?"Executing Swap...":y?x?F?y.amount?I?parseFloat(y.amount)>y.asset.balanceFormatted?"Insufficient From Balance":parseFloat(I)>F.balanceFormatted?"Insufficient Collateral Balance":t.length===0?"No Swap Batches":"Execute Swap":"Enter Collateral Amount":"Enter Amount":"Select Collateral":"Select To Token":"Select From Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})},us=({address:t,supportedChains:o,enabled:r=!0,refetchInterval:n})=>{const[s,c]=a.useState([]),[i,d]=a.useState(!1),[g,f]=a.useState(null),[u,l]=a.useState(!1),C=a.useRef(!1),A=a.useRef(!1),w=o?JSON.stringify([...o].sort()):"",k=a.useCallback(async(m=!1)=>{if(!t||!r){c([]),l(!1),C.current=!1;return}if(!A.current){A.current=!0,!C.current&&!m&&d(!0),f(null);try{const j=await fetch(`${Yt}/spicedeposit/${t}`);if(!j.ok)throw new Error(`Failed to fetch balance: ${j.status}`);const y=await j.json();if(y.success&&y.data?.tokens&&Array.isArray(y.data.tokens)){const h=[];y.data.tokens.forEach(x=>{const S=x.chainId,F=x.tokenAddress,B=x.amount;if(o&&!o.includes(S))return;const I=BigInt(B||"0");if(I>BigInt(0)){const G=fe(S),P=F.toLowerCase()==="0x0"||F.toLowerCase()==="0x0000000000000000000000000000000000000000"||F.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";let _=18,$="TOKEN",J=F.slice(0,6)+"..."+F.slice(-4),M;if(P)_=G?.nativeCurrency?.decimals||18,$=G?.nativeCurrency?.symbol||"ETH",J=G?.nativeCurrency?.name||"Native Token";else{const E=G?.supportedTokens?.find(U=>U.address.toLowerCase()===F.toLowerCase());E&&(_=E.decimals,$=E.symbol,J=E.name,M=E.logoURI)}const z=parseFloat((Number(I)/Math.pow(10,_)).toFixed(6));z>0&&h.push({address:P?"0x0000000000000000000000000000000000000000":F,symbol:$,name:J,decimals:_,chainId:S,balance:I,balanceFormatted:z,balanceUsd:0,isNative:P,logoURI:M})}}),c(h),l(h.length>0),C.current=!0}else c([]),l(!1)}catch(j){const y=j instanceof Error?j.message:"Failed to fetch balance";f(y),console.error("Error fetching Spice assets:",j),C.current||(c([]),l(!1))}finally{d(!1),A.current=!1}}},[t,r,w]);a.useEffect(()=>{r&&t&&(C.current=!1,k(!1))},[t,r,w]),a.useEffect(()=>{if(!r||!t||!n)return;const m=setInterval(()=>{k(!0)},n);return()=>clearInterval(m)},[t,r,n,w]);const p=a.useCallback(m=>s.filter(j=>j.chainId===m),[s]),b=a.useCallback(async()=>{await k(!0)},[k]);return{assets:s,loading:i,error:g,hasBalance:u,refetch:b,getAssetsByChain:p}},hs=({isSuccess:t,type:o,chainName:r,explorerUrl:n,txHash:s})=>e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"14px 16px",borderRadius:"8px",backgroundColor:t?"#d1fae5":"#fee2e2",border:t?"1px solid #6ee7b7":"1px solid #fca5a5"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px"},children:[e.jsx("div",{style:{width:"28px",height:"28px",borderRadius:"50%",backgroundColor:t?"#10b981":"#ef4444",display:"flex",alignItems:"center",justifyContent:"center"},children:t?e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",children:e.jsx("path",{d:"M11.6667 3.5L5.25 9.91667L2.33333 7",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})}):e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",children:e.jsx("path",{d:"M10.5 3.5L3.5 10.5M3.5 3.5L10.5 10.5",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}),e.jsxs("div",{children:[e.jsx("p",{style:{margin:0,fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.5px",color:t?"#065f46":"#dc2626"},children:t?`${o.toUpperCase()} CONFIRMED`:`${o.toUpperCase()} FAILED`}),e.jsxs("p",{style:{margin:"2px 0 0 0",fontSize:"12px",color:"#6b7280"},children:["on ",r]})]})]}),n&&s&&e.jsxs("a",{href:`${n}/tx/${s}`,target:"_blank",rel:"noopener noreferrer",style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"13px",color:"#6b7280",textDecoration:"none",whiteSpace:"nowrap"},children:["View on explorer",e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",children:[e.jsx("path",{d:"M9 6.5V9.5C9 9.76522 8.89464 10.0196 8.70711 10.2071C8.51957 10.3946 8.26522 10.5 8 10.5H2.5C2.23478 10.5 1.98043 10.3946 1.79289 10.2071C1.60536 10.0196 1.5 9.76522 1.5 9.5V4C1.5 3.73478 1.60536 3.48043 1.79289 3.29289C1.98043 3.10536 2.23478 3 2.5 3H5.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M7.5 1.5H10.5V4.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M5 7L10.5 1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"})]})]})]}),qt=({isOpen:t,onClose:o,onComplete:r,type:n,results:s,chainName:c="Network",explorerUrl:i,theme:d,styles:g,intentStatus:f,onRetry:u,onNewTx:l,onRetryTx:C,asOverlay:A=!1,isProcessing:w=!1})=>{const k=d||de.createTheme("light"),[p,b]=a.useState(!1),[m,j]=a.useState(!0),[y,h]=a.useState(null),[x,S]=a.useState(null);a.useEffect(()=>{!t&&!f&&b(!1)},[t,f]);const F=()=>{b(!0),setTimeout(()=>{r?.()},300)},B=()=>{j(!m)};if(f){const{steps:P,overallStatus:_}=f,$=_==="processing",J=_==="success",M=_==="failed",z=P.find(ee=>ee.transactionHash),E=c!=="Network"?c:P[0]?.chainName||c,U=i||(z?Wt(z.chainId,z.transactionHash||"").replace(/\/tx\/.*$/,""):void 0),X=e.jsxs(e.Fragment,{children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"16px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",cursor:"pointer"},onClick:B,children:[e.jsxs("span",{style:{fontSize:"13px",fontWeight:500,color:"#6b7280",fontFamily:g?.fontFamily||k.typography.fontFamily},children:[$?`Processing ${n.charAt(0).toUpperCase()+n.slice(1)}`:`${n.charAt(0).toUpperCase()+n.slice(1)} results`," "]}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",style:{transform:m?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.3s ease"},children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#6b7280",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]}),!$&&e.jsx("button",{onClick:o,onMouseEnter:()=>h("close"),onMouseLeave:()=>{h(null),S(null)},onMouseDown:()=>S("close"),onMouseUp:()=>S(null),style:{background:x==="close"?"#f3f4f6":y==="close"?"#f9fafb":"none",border:"none",borderRadius:"4px",cursor:"pointer",padding:"4px",display:"flex",alignItems:"center",justifyContent:"center",color:y==="close"||x==="close"?"#374151":"#6b7280",transform:x==="close"?"scale(0.9)":y==="close"?"scale(1.1)":"scale(1)",transition:"all 0.15s ease"},children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:e.jsx("path",{d:"M12 4L4 12M4 4L12 12",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})})]}),e.jsx("div",{style:{marginBottom:"16px"},children:$?e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"20px 16px",borderRadius:"8px",backgroundColor:"#f3f4f6",border:"1px solid #e5e7eb",gap:"12px"},children:[e.jsx("div",{style:{width:"24px",height:"24px",border:"3px solid #e5e7eb",borderTopColor:k.colors.primary,borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsxs("div",{children:[e.jsx("p",{style:{margin:0,fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.5px",color:"#374151"},children:"PROCESSING TRANSACTION"}),e.jsxs("p",{style:{margin:"2px 0 0 0",fontSize:"12px",color:"#6b7280"},children:["on ",E]})]})]}):e.jsx(hs,{isSuccess:J,type:n,chainName:E,explorerUrl:U,txHash:z?.transactionHash})}),e.jsx("style",{children:`
|
|
2
|
+
"use strict";var zs=Object.create;var $t=Object.defineProperty;var Vs=Object.getOwnPropertyDescriptor;var Ns=Object.getOwnPropertyNames;var Ys=Object.getPrototypeOf,qs=Object.prototype.hasOwnProperty;var Ps=(t,o,r,n)=>{if(o&&typeof o=="object"||typeof o=="function")for(let s of Ns(o))!qs.call(t,s)&&s!==r&&$t(t,s,{get:()=>o[s],enumerable:!(n=Vs(o,s))||n.enumerable});return t};var dt=(t,o,r)=>(r=t!=null?zs(Ys(t)):{},Ps(o||!t||!t.__esModule?$t(r,"default",{value:t,enumerable:!0}):r,t));const re=require("viem"),Tt=require("viem/actions"),At=require("viem/chains"),e=require("react/jsx-runtime"),a=require("react"),de=require("./Button-Cn16gFtO.js"),Js=require("react-dom"),Je=require("@privy-io/react-auth"),_t=require("@dynamic-labs/sdk-react-core"),Ye=require("@spicenet-io/spiceflow-core"),Ae=require("wagmi"),Zs=require("./auth-dynamic.cjs.js"),Gs=require("./auth-privy.cjs.js"),es=require("@tanstack/react-query"),ts=require("wagmi/chains"),ss=require("wagmi/connectors"),ct=[{constant:!0,inputs:[],name:"name",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_spender",type:"address"},{name:"_value",type:"uint256"}],name:"approve",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[],name:"totalSupply",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transferFrom",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[],name:"decimals",outputs:[{name:"",type:"uint8"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[{name:"_owner",type:"address"}],name:"balanceOf",outputs:[{name:"balance",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{constant:!0,inputs:[],name:"symbol",outputs:[{name:"",type:"string"}],payable:!1,stateMutability:"view",type:"function"},{constant:!1,inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],name:"transfer",outputs:[{name:"",type:"bool"}],payable:!1,stateMutability:"nonpayable",type:"function"},{constant:!0,inputs:[{name:"_owner",type:"address"},{name:"_spender",type:"address"}],name:"allowance",outputs:[{name:"",type:"uint256"}],payable:!1,stateMutability:"view",type:"function"},{payable:!0,stateMutability:"payable",type:"fallback"},{anonymous:!1,inputs:[{indexed:!0,name:"owner",type:"address"},{indexed:!0,name:"spender",type:"address"},{indexed:!1,name:"value",type:"uint256"}],name:"Approval",type:"event"},{anonymous:!1,inputs:[{indexed:!0,name:"from",type:"address"},{indexed:!0,name:"to",type:"address"},{indexed:!1,name:"value",type:"uint256"}],name:"Transfer",type:"event"}],os={11155111:{id:11155111,name:"Ethereum Sepolia",displayName:"Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/sepolia/b59c444a55b74d56b3f836d2dd7144eb",blockExplorers:{default:{name:"Etherscan",url:"https://sepolia.etherscan.io"}},viemChain:At.sepolia,delegateContract:"0xDF7d39BB544778F467D10b08B1F5C170fd7fB480",icon:{symbol:"\u039E",backgroundColor:"#627EEA",textColor:"#FFFFFF"},moralisName:"sepolia",supportedTokens:[{address:"0x1c7D4B196Cb0C7B01d743Fbc6116a902379C7238",name:"USD Coin",symbol:"USDC",decimals:6},{address:"0x76f983E0F5a4B72C4bac99Fc9399845a58078787",name:"Mock Tether USD",symbol:"USDT",decimals:6},{address:"0x9Bf2d44887bE65C4f6337B20814eC79197a092aa",name:"Spice USD",symbol:"sUSD",decimals:18},{address:"0x4Fc381B6CC6Df8cF1c1bD46D184475bE5b7A3c62",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},421614:{id:421614,name:"Arbitrum Sepolia",displayName:"Arbitrum Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/arbitrum-sepolia/a3b4b1042f834a959541c96811ef44bb",blockExplorers:{default:{name:"Arbiscan",url:"https://sepolia.arbiscan.io"}},viemChain:At.arbitrumSepolia,delegateContract:"0x151755d1bdFeB6082D141EF86e4291b2e902b43F",icon:{symbol:"A",backgroundColor:"#28A0F0",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0xBeB51deb2018b67b35d5695Fd15bb30D452c7868",name:"USD Coin",symbol:"USDC",decimals:18},{address:"0xf370dC3765f81aC9dD2FEBd59Fb4e710330B0BC8",name:"Spice USD",symbol:"sUSD",decimals:18},{address:"0xBA4c54d4CF10C766c22A08F783998cFaB237F7C9",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},84532:{id:84532,name:"Base Sepolia",displayName:"Base Sepolia",nativeCurrency:{name:"Sepolia Ether",symbol:"ETH",decimals:18},rpc:"https://site1.moralis-nodes.com/base-sepolia/0563a61e273c428f906716cd4befa362",blockExplorers:{default:{name:"Basescan",url:"https://sepolia.basescan.org"}},viemChain:At.baseSepolia,delegateContract:"0xD4C4A222cdd42f5c3219249a083a5aBf1420E9D8",icon:{symbol:"B",backgroundColor:"#0052FF",textColor:"#FFFFFF"},moralisName:"0x14a34",supportedTokens:[{address:"0xf370dC3765f81aC9dD2FEBd59Fb4e710330B0BC8",name:"USD Coin",symbol:"USDC",decimals:18},{address:"0xBeB51deb2018b67b35d5695Fd15bb30D452c7868",name:"Spice USD",symbol:"sUSD",decimals:18},{address:"0x16DD3a855433059Be478FAcb416D9aFed6CA96Ec",name:"Mock Wrapped BTC",symbol:"WBTC",decimals:8}]},5115:{id:5115,name:"Citrea Testnet",displayName:"Citrea Testnet",nativeCurrency:{name:"cBTC",symbol:"cBTC",decimals:18},rpc:"https://rpc.testnet.citrea.xyz",blockExplorers:{default:{name:"Citrea Explorer",url:"https://explorer.testnet.citrea.xyz"}},viemChain:At.citreaTestnet,delegateContract:"0x9DE3D53419a8F821b6E2039A7249c5738004FB94",icon:{symbol:"C",backgroundColor:"#EA4B4B",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0xf19308F923582A6f7c465e5CE7a9Dc1BEC6665B1",name:"USD Coin",symbol:"USD",decimals:18},{address:"0x2876a1fb400c238b0a9e4edd2e7e03d3cf9b53c2",name:"CBTC Vault",symbol:"eCBTC",decimals:18,logoURI:"https://citrea.elitra.xyz/images/tokens/cbtc.jpg"},{address:"0x2d41d86bb9e7161561fa3186b47d160467efcee3",name:"NUSD Vault",symbol:"eNUSD",decimals:18,logoURI:"https://www.satsuma.exchange/nusd-icon.svg"},{address:"0x8d0c9d1c17aE5e40ffF9bE350f57840E9E66Cd93",name:"Wrapped Citrea BTC",symbol:"WCBTC",decimals:18,logoURI:"https://citrea.elitra.xyz/images/tokens/cbtc.jpg"}]},123420001114:{id:123420001114,name:"Base Camp",displayName:"Base Camp",nativeCurrency:{name:"Ethereum",symbol:"ETH",decimals:18},rpc:"https://rpc.basecamp.t.raas.gelato.cloud",blockExplorers:{default:{name:"Base Camp Explorer",url:"https://basecamp.gelato.network"}},viemChain:At.basecampTestnet,delegateContract:"0xA15BFeD4eC0BEdd36b00b9856aFa1C6BCFE61574",icon:{symbol:"B",backgroundColor:"#0052FF",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[]},688688:{id:688688,name:"Pharos Testnet",displayName:"Pharos Testnet",nativeCurrency:{name:"PHRS",symbol:"PHRS",decimals:18},rpc:"https://testnet.dplabs-internal.com",blockExplorers:{default:{name:"Pharos Explorer",url:"https://testnet.pharosscan.xyz"}},viemChain:re.defineChain({id:688688,name:"Pharos Testnet",nativeCurrency:{decimals:18,name:"PHRS",symbol:"PHRS"},rpcUrls:{default:{http:["https://testnet.dplabs-internal.com"]}},blockExplorers:{default:{name:"Pharos Explorer",url:"https://testnet.pharosscan.xyz"}},testnet:!0}),delegateContract:"0xAd45b774C4c632540d36f2105889C0E6aC28b504",icon:{symbol:"P",backgroundColor:"#4A90E2",textColor:"#FFFFFF"},moralisName:""},688689:{id:688689,name:"Pharos Testnet",displayName:"Pharos Testnet",nativeCurrency:{name:"PHRS",symbol:"PHRS",decimals:18},rpc:"https://atlantic.dplabs-internal.com",blockExplorers:{default:{name:"Pharos Atlantic Explorer",url:"https://atlantic.pharosscan.xyz/"}},viemChain:re.defineChain({id:688689,name:"Pharos Testnet",nativeCurrency:{decimals:18,name:"PHRS",symbol:"PHRS"},rpcUrls:{default:{http:["https://atlantic.dplabs-internal.com"]}},blockExplorers:{default:{name:"Pharos Atlantic Explorer",url:"https://atlantic.pharosscan.xyz/"}},testnet:!0}),delegateContract:"0xAd45b774C4c632540d36f2105889C0E6aC28b504",icon:{symbol:"P",backgroundColor:"#4A90E2",textColor:"#FFFFFF"},moralisName:"",supportedTokens:[{address:"0x16b90aeb3de140dde993da1d5734bca28574702b",name:"USD Stable Coin",symbol:"USD",decimals:6}]}},fe=t=>os[t],st=t=>fe(t)?.name||`Chain ${t}`,pt=t=>{const o=fe(t);if(!o)throw new Error(`Unsupported chain ID: ${t}`);return o.delegateContract},Wt=(t,o,r)=>{const n=fe(t);return n?.blockExplorers?.default?.url?`${n.blockExplorers.default.url}/tx/${o}`:"#"},Ve=t=>{const o=fe(t);if(!o)throw new Error(`Unsupported chain ID: ${t}`);return re.createPublicClient({chain:o.viemChain,transport:re.http(o.rpc)})},Ks=t=>{const o=fe(t);if(o)return{icon:o.icon.symbol,bg:o.icon.backgroundColor,text:o.icon.textColor};const r=`Chain ${t}`,n=r.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:r.charAt(0).toUpperCase()}},Os=()=>{const t={};return Object.values(os).forEach(o=>{t[o.id]={name:o.name,moralisName:o.moralisName||"",chain:o.viemChain,rpcUrl:o.rpc}}),t},Xs=t=>{const o=fe(t);if(!o)throw new Error(`Chain ${t} not supported`);return re.createPublicClient({chain:o.viemChain,transport:re.http(o.rpc)})},$s=(t,o,r=BigInt(0),n=0)=>({address:o.address,name:o.name,symbol:o.symbol,decimals:o.decimals,balance:r,balanceFormatted:n,balanceUsd:0,logoURI:o.logoURI,isNative:!1,chainId:t}),_s=(t,o=BigInt(0),r=0)=>{const n=fe(t);return n?{address:"0x0000000000000000000000000000000000000000",name:n.nativeCurrency.name,symbol:n.nativeCurrency.symbol,decimals:n.nativeCurrency.decimals,balance:o,balanceFormatted:r,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:t}:null},Rt=(t,o=[])=>{const r=fe(t);if(!r)return[];const n=[];if(![11155111,421614,84532,688689].includes(t)){const s=o.find(c=>c.chainId===t&&c.isNative);s?n.push(s):n.push(_s(t))}return r.supportedTokens&&r.supportedTokens.forEach(s=>{const c=o.find(i=>i.chainId===t&&i.address.toLowerCase()===s.address.toLowerCase());c?n.push(c):n.push($s(t,s))}),n},Dt=t=>{const o=t.toLowerCase();return o==="0x0"||o==="0x0000000000000000000000000000000000000000"||o==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"},wt=t=>Dt(t)?"0x0":t,ns=async(t,o)=>{const r=fe(t);if(!r)throw new Error(`Unsupported chain ID: ${t}`);const n=o.toLowerCase();if(Dt(n)){if(!r.nativeCurrency?.decimals)throw new Error(`Native currency decimals not configured for chain ${t}`);return r.nativeCurrency.decimals}if(r.supportedTokens){const s=r.supportedTokens.find(c=>c.address.toLowerCase()===n);if(s)return s.decimals}try{if(!re.isAddress(o))throw new Error(`Invalid token address: ${o}`);const s=re.getAddress(o),c=Ve(t),i=await Tt.readContract(c,{address:s,abi:ct,functionName:"decimals"});return Number(i)}catch(s){throw console.error(`Failed to fetch decimals for token ${o} on chain ${t}:`,s),new Error(`Could not determine decimals for token ${o} on chain ${t}`)}},eo=(t,o,r)=>{if(o===r)return t;if(o<r){const n=BigInt(10)**BigInt(r-o);return t*n}else{const n=BigInt(10)**BigInt(o-r);return t/n}},to="eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJub25jZSI6ImVmMWEzZDM1LTYwMGUtNDcwNC04MTk3LTIzODc2NWNlYmQ2NCIsIm9yZ0lkIjoiNDY2Nzk0IiwidXNlcklkIjoiNDgwMjI3IiwidHlwZUlkIjoiMTk3YWMxMzMtNDY3ZS00YWIyLWFlZmUtM2VlMjU0NGNjM2NiIiwidHlwZSI6IlBST0pFQ1QiLCJpYXQiOjE3NTU5NjY3MjIsImV4cCI6NDkxMTcyNjcyMn0.7KHx_SwI89GVKFkgqtl-sUV9CUKWkDjZbkBAVAX2Djk",so="https://deep-index.moralis.io/api/v2.2",St=Os(),rs=Xs,as=async(t,o)=>{try{const r=rs(o),n=await Tt.getBalance(r,{address:t}),s=St[o],c=parseFloat((Number(n)/Math.pow(10,18)).toFixed(6));return{address:"0x0000000000000000000000000000000000000000",name:s.chain.nativeCurrency.name,symbol:s.chain.nativeCurrency.symbol,decimals:s.chain.nativeCurrency.decimals,balance:n,balanceFormatted:c,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:o}}catch(r){return console.error(`Error fetching native balance for ${o}:`,r),{address:"0x0000000000000000000000000000000000000000",name:St[o].chain.nativeCurrency.name,symbol:St[o].chain.nativeCurrency.symbol,decimals:18,balance:BigInt(0),balanceFormatted:0,balanceUsd:0,logoURI:void 0,isNative:!0,chainId:o}}},is=async(t,o,r,n,s,c)=>{try{if(!re.isAddress(r))return console.warn(`Invalid token address ${r} for chain ${o}, skipping...`),null;const i=re.getAddress(r),d=re.isAddress(t)?re.getAddress(t):t,g=rs(o),f=await Tt.readContract(g,{address:i,abi:ct,functionName:"balanceOf",args:[d]}),u=parseFloat((Number(f)/Math.pow(10,c)).toFixed(6));return u>0?{address:i,name:n,symbol:s,decimals:c,balance:f,balanceFormatted:u,balanceUsd:0,logoURI:void 0,isNative:!1,chainId:o}:null}catch(i){return i?.message?.includes("checksum")||i?.message?.includes("Address")||i?.message?.includes("invalid")||console.error(`Error fetching ERC20 balance for ${r} on chain ${o}:`,i),null}},ut=async(t,o)=>{try{const r=St[o];if(!r.moralisName){const i=[],d=await as(t,o);d.balanceFormatted>0&&i.push(d);const g=fe(o);if(g?.supportedTokens&&g.supportedTokens.length>0){const f=g.supportedTokens.map(u=>is(t,o,u.address,u.name,u.symbol,u.decimals));(await Promise.allSettled(f)).forEach(u=>{u.status==="fulfilled"&&u.value&&i.push(u.value)})}return{tokens:i,chainId:o}}const n=await(await import("axios")).default.get(`${so}/wallets/${t}/tokens`,{params:{chain:r.moralisName},headers:{"X-API-Key":to}}),s=[],c=n.data?.result||[];console.log("allTokens",c);for(const i of c){const d=parseFloat(i.balance_formatted||"0");if(d>0){const g={address:i.token_address,name:i.name||"Unknown",symbol:i.symbol||"UNKNOWN",decimals:parseInt(i.decimals)||18,balance:BigInt(i.balance||"0"),balanceFormatted:d,balanceUsd:parseFloat(i.usd_value||"0"),logoURI:i.logo,isNative:i.native_token||!1,chainId:o};s.push(g)}}return{tokens:s,chainId:o}}catch(r){if(console.error(`Error fetching tokens for ${o}:`,r),!St[o].moralisName)try{const n=[],s=await as(t,o);s.balanceFormatted>0&&n.push(s);const c=fe(o);if(c?.supportedTokens&&c.supportedTokens.length>0){const i=c.supportedTokens.map(d=>is(t,o,d.address,d.name,d.symbol,d.decimals));(await Promise.allSettled(i)).forEach(d=>{d.status==="fulfilled"&&d.value&&n.push(d.value)})}return{tokens:n,chainId:o}}catch(n){console.error(`Fallback balance fetch failed for ${o}:`,n)}return{tokens:[],chainId:o}}},zt=async t=>{if(!t)throw new Error("Wallet address is required");console.log("Fetching multi-chain balances for:",t);const[o,r,n,s,c,i]=await Promise.allSettled([ut(t,11155111),ut(t,5115),ut(t,123420001114),ut(t,84532),ut(t,688689),ut(t,421614)]),d={};return o.status==="fulfilled"&&(d[11155111]=o.value),r.status==="fulfilled"&&(d[5115]=r.value),n.status==="fulfilled"&&(d[123420001114]=n.value),s.status==="fulfilled"&&(d[84532]=s.value),c.status==="fulfilled"&&(d[688689]=c.value),i.status==="fulfilled"&&(d[421614]=i.value),console.log("Balances:",d),d},Vt=({address:t,supportedChains:o,fetchBalances:r,refreshInterval:n=8e3})=>{const[s,c]=a.useState([]),[i,d]=a.useState(!1),[g,f]=a.useState(null),u=a.useRef(!0),l=a.useRef(t),C=a.useRef(o),A=a.useRef(r);a.useEffect(()=>{l.current=t,C.current=o,A.current=r},[t,o,r]);const w=a.useCallback(async()=>{const b=l.current,m=C.current,j=A.current;if(!b){c([]);return}u.current&&d(!0),f(null);try{const y=await j(b),h=Object.values(y).flatMap(x=>x.tokens.map(S=>({...S,chainId:x.chainId}))).filter(x=>m.includes(x.chainId));c(h)}catch(y){const h=y instanceof Error?y.message:"Failed to fetch assets";f(h),console.error("Error fetching assets:",y)}finally{u.current&&(d(!1),u.current=!1)}},[]),k=a.useCallback(b=>s.filter(m=>m.chainId===b),[s]),p=a.useCallback(()=>s.filter(b=>b.isNative),[s]);return a.useEffect(()=>{t&&(u.current=!0,w())},[t,w]),a.useEffect(()=>{if(!t||!n)return;const b=setInterval(()=>{w()},n);return()=>clearInterval(b)},[t,n]),{assets:s,loading:i,error:g,refreshAssets:w,getAssetsByChain:k,getNativeAssets:p}},kt=({checkStepStatus:t,pollingInterval:o=4e3})=>{const[r,n]=a.useState(null),[s,c]=a.useState(null),i=a.useRef(!1),d=a.useCallback(()=>{s&&(clearInterval(s),c(null))},[s]),g=a.useCallback(()=>{n(null),d()},[d]),f=a.useCallback((u,l)=>{d(),i.current=!1;const C={intentId:u,steps:l.map(k=>({...k,status:"pending"})),overallStatus:"processing"};n(C);const A=async()=>{i.current||n(k=>k?((async()=>{const p=[...k.steps];let b=!0,m=!1;for(let y=0;y<p.length;y++){const h=p[y];if(h.status!=="success"){if((h.stepId===0||y>0&&p[y-1].status==="success")&&(h.status==="pending"||h.status==="processing"))try{const x=await t(u,h.stepId);x.data.status==="success"?(p[y]={...h,status:"success",transactionHash:x.data.transactionHash},y+1<p.length&&p[y+1].status==="pending"&&(p[y+1]={...p[y+1],status:"processing"})):x.data.status==="executing"||x.data.status==="created"?p[y]={...h,status:"processing"}:x.data.status==="reverted"&&(p[y]={...h,status:"failed",transactionHash:x.data.transactionHash},m=!0)}catch(x){console.error(`Error checking step ${h.stepId}:`,x)}p[y].status!=="success"&&(b=!1)}}const j=m?"failed":b?"success":"processing";n(y=>y?{...y,steps:p,overallStatus:j}:null),(b||m)&&(i.current=!0,d())})().catch(()=>{}),k):null)};A();const w=setInterval(A,o);c(w)},[t,o,d]);return a.useEffect(()=>()=>{d()},[d]),{intentStatus:r,startStatusPolling:f,stopStatusPolling:d,clearStatus:g}},It=(t,o=4)=>t===0?"0":t<1e-4?"< 0.0001":t.toFixed(o),oo=(t,o=6,r=4)=>t.length<=o+r?t:`${t.slice(0,o)}...${t.slice(-r)}`,no=t=>oo(t,8,8),ls=t=>{const o=t.replace(/[^0-9.]/g,""),r=o.split(".");return r.length>2?r[0]+"."+r.slice(1).join(""):o},ro=async t=>{try{return await navigator.clipboard.writeText(t),!0}catch(o){return console.error("Failed to copy to clipboard:",o),!1}};var rt="",ao="";const io={sUSD:rt,USDC:rt,WBTC:ao},ot=({symbol:t,logoURI:o,size:r=20,theme:n})=>{const s=n||de.createTheme("dark"),c={width:`${r}px`,height:`${r}px`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${r*.4}px`,fontWeight:s.typography.fontWeight.bold,flexShrink:0,overflow:"hidden",backgroundColor:"#ffffff"},i=t.toUpperCase(),d=o||io[i];if(d)return e.jsx("img",{src:d,alt:t,style:{...c,objectFit:"cover"},onError:f=>{const u=f.target;u.style.display="none";const l=u.parentElement;l&&(l.innerHTML=Nt(t).icon,Object.assign(l.style,Nt(t).style))}});const g=Nt(t);return e.jsx("div",{style:{...c,...g.style},children:g.icon})},Nt=t=>{const o=t.toUpperCase(),r={ETH:{bg:"#627EEA",text:"#FFFFFF",icon:"\u039E"},BTC:{bg:"#F7931A",text:"#FFFFFF",icon:"\u20BF"},USDC:{bg:"#2775CA",text:"#FFFFFF"},USDT:{bg:"#26A17B",text:"#FFFFFF"},DAI:{bg:"#F5AC37",text:"#FFFFFF"},WETH:{bg:"#627EEA",text:"#FFFFFF",icon:"\u039E"},WBTC:{bg:"#F09242",text:"#FFFFFF",icon:"\u20BF"},CBTC:{bg:"#F7931A",text:"#FFFFFF",icon:"\u20BF"},USD:{bg:"#26A17B",text:"#FFFFFF",icon:"$"},MATIC:{bg:"#8247E5",text:"#FFFFFF"},AVAX:{bg:"#E84142",text:"#FFFFFF"},SOL:{bg:"#9945FF",text:"#FFFFFF"},DOT:{bg:"#E6007A",text:"#FFFFFF"},ADA:{bg:"#0033AD",text:"#FFFFFF"},LINK:{bg:"#375BD2",text:"#FFFFFF"},UNI:{bg:"#FF007A",text:"#FFFFFF"},AAVE:{bg:"#B6509E",text:"#FFFFFF"},CRV:{bg:"#40E0D0",text:"#000000"}}[o];if(r)return{style:{backgroundColor:r.bg,color:r.text},icon:r.icon||o.charAt(0)};const n=o.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:o.charAt(0)}},Ft=({chainId:t,name:o,size:r=16,theme:n})=>{const s=n||de.createTheme("dark"),c={width:`${r}px`,height:`${r}px`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:`${r*.5}px`,fontWeight:s.typography.fontWeight.bold,flexShrink:0},i=lo(t,o);return e.jsx("div",{style:{...c,backgroundColor:"style"in i?i.style?.backgroundColor:i.bg,color:"style"in i?i.style?.color:i.text},children:i.icon})},lo=(t,o)=>{if(t)return Ks(t);const r=o||"Unknown Chain",n=r.split("").reduce((d,g)=>g.charCodeAt(0)+((d<<5)-d),0),s=Math.abs(n)%360,c=`hsl(${s}, 60%, 50%)`,i=s>180?"#FFFFFF":"#000000";return{style:{backgroundColor:c,color:i},icon:r.charAt(0).toUpperCase()}},ds=t=>{switch(t){case 11155111:return"Sepolia";case 421614:return"Arbitrum Sepolia";case 5115:return"Citrea Testnet";case 123420001114:return"Basecamp Testnet";case 84532:return"Base Sepolia";case 688689:return"Pharos Atlantic";default:return`Chain ${t}`}},cs=({selectedAsset:t,assets:o,onAssetSelect:r,showDropdown:n,onToggleDropdown:s,disabled:c=!1,theme:i})=>{const d=i||de.createTheme("dark"),g=a.useRef(null),f=a.useRef(null),u=a.useRef(null),[l,C]=a.useState(null);a.useEffect(()=>{if(n&&f.current){const I=()=>{if(f.current){const G=f.current.getBoundingClientRect();C({top:G.bottom+6,right:window.innerWidth-G.right})}};return I(),window.addEventListener("scroll",I,!0),window.addEventListener("resize",I),()=>{window.removeEventListener("scroll",I,!0),window.removeEventListener("resize",I)}}else C(null)},[n]),a.useEffect(()=>{const I=G=>{g.current&&!g.current.contains(G.target)&&u.current&&!u.current.contains(G.target)&&n&&s()};return n&&document.addEventListener("mousedown",I),()=>{document.removeEventListener("mousedown",I)}},[n,s]);const[A,w]=a.useState(!1),[k,p]=a.useState(!1),b={backgroundColor:"transparent",border:A?"1px solid #F4A5A5":"1px solid #CDCFD1",borderRadius:"6px",color:"#3c3e42",cursor:c?"not-allowed":"pointer",padding:"8px 12px 8px 8px",width:"100%",display:"flex",flexDirection:"column",gap:"4px",opacity:c?.6:1,transition:"all 0.15s ease",transform:k?"scale(0.98)":"scale(1)"},m={display:"flex",justifyContent:"space-between",alignItems:"center"},j={display:"flex",alignItems:"center",gap:"4px",paddingTop:"4px",borderTop:"1px solid #e5e7eb"},y=()=>l?{position:"fixed",top:`${l.top}px`,right:`${l.right}px`,backgroundColor:d.colors.secondary,border:`1px solid ${d.colors.border}`,borderRadius:d.borderRadius.md,boxShadow:d.shadows.lg,zIndex:100,width:"200px",maxHeight:"300px",overflow:"auto"}:{},h={backgroundColor:"transparent",border:"none",color:d.colors.text,cursor:"pointer",padding:d.spacing.sm,width:"100%",display:"flex",alignItems:"center",gap:d.spacing.sm,transition:`background-color ${d.animation.normal}`,":hover":{backgroundColor:d.colors.surfaceHover}},x={display:"flex",flexDirection:"column",alignItems:"flex-start",flex:1},S={fontSize:d.typography.fontSize.sm,fontWeight:d.typography.fontWeight.medium},F={fontSize:d.typography.fontSize.xs,color:d.colors.textMuted},B={transition:`transform ${d.animation.normal}`,transform:n?"rotate(180deg)":"rotate(0deg)"};return e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{position:"relative"},ref:g,children:e.jsxs("div",{ref:f,style:b,onClick:c?void 0:s,onMouseEnter:()=>w(!0),onMouseLeave:()=>{w(!1),p(!1)},onMouseDown:()=>p(!0),onMouseUp:()=>p(!1),children:[e.jsxs("div",{style:m,children:[e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(ot,{symbol:t.asset.symbol,logoURI:t.asset.logoURI,theme:d,size:30}),e.jsx("span",{style:{fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.asset.symbol})]}):e.jsx("span",{style:{fontSize:"14px",color:"#71757a"},children:"Select"})}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 24 24",fill:"none",stroke:"#71757a",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",style:B,children:e.jsx("path",{d:"M6 9l6 6 6-6"})})]}),t?.asset&&e.jsxs("div",{style:j,children:[e.jsx(Ft,{chainId:t.asset.chainId,theme:d}),e.jsx("span",{style:{fontSize:"11px",color:"#71757a"},children:ds(t.asset.chainId)})]})]})}),n&&l&&Js.createPortal(e.jsx("div",{ref:u,style:y(),children:o.map(I=>e.jsxs("button",{style:h,onClick:()=>{r(I),s()},children:[e.jsx(ot,{symbol:I.symbol,logoURI:I.logoURI,theme:d},`${I.address}-${I.chainId}`),e.jsxs("div",{style:x,children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:d.spacing.xs},children:[e.jsx("span",{style:S,children:I.symbol}),e.jsx(Ft,{chainId:I.chainId,theme:d})]}),e.jsxs("span",{style:F,children:[It(I.balanceFormatted)," \u2022"," ",ds(I.chainId)]})]})]},`${I.address}-${I.chainId}`))}),document.body)]})},co=({assets:t,selectedAsset:o,onAssetSelect:r,onAmountChange:n,disabled:s=!1,loading:c=!1,label:i="Select Asset",showBalance:d=!0,showMaxButton:g=!0,placeholder:f="0.0",theme:u,styles:l,allowSecondAsset:C=!1,onAddAsset:A,canAddAsset:w=!1})=>{const k=u||de.createTheme("dark"),[p,b]=a.useState(!1),[m,j]=a.useState(null),[y,h]=a.useState(null),[x,S]=a.useState(o?.amount||""),F=a.useRef(null),B=a.useRef("");a.useEffect(()=>{const M=o?.asset?`${o.asset.chainId}-${o.asset.address}`:"";M!==B.current&&(S(o?.amount||""),B.current=M)},[o?.asset?.chainId,o?.asset?.address,o?.amount]);const I=M=>{const z=ls(M);if(!z){S(z),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(z)},300);return}if(o?.asset){const E=parseFloat(z),H=o.asset.balanceFormatted;if(!isNaN(E)&&E>H){const X=H.toString();S(X),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(X)},300);return}}S(z),F.current&&clearTimeout(F.current),F.current=setTimeout(()=>{n(z)},300)},G=M=>{if(o?.asset){const z=(o.asset.balanceFormatted*M/100).toString();S(z),F.current&&clearTimeout(F.current),n(z)}},P=o?.asset?.balanceFormatted??0,_=parseFloat(x)||0,$=P>0?_/P*100:0;a.useEffect(()=>()=>{F.current&&clearTimeout(F.current)},[]);const J={backgroundColor:l?.assetSelector?.backgroundColor||l?.secondaryBackground||"#e9e9e9",border:"0.5px solid #A8A8A7",borderRadius:l?.assetSelector?.borderRadius||"6px",padding:l?.assetSelector?.padding||"16px",height:"auto",minHeight:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative",opacity:s?.6:1};return c?e.jsx("div",{style:J,children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"16px",width:"60px"}}),e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"40px",width:"150px"}})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",gap:"8px"},children:[e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"4px",height:"12px",width:"80px"}}),e.jsx("div",{style:{backgroundColor:"#d1d5db",borderRadius:"6px",height:"46px",width:"128px"}})]})]})}):e.jsxs("div",{style:J,children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:i}),d&&o?.asset&&e.jsxs("span",{style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:["Balance: ",It(o.asset.balanceFormatted)]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",flex:1},children:[e.jsx("input",{type:"text",value:x,onChange:M=>I(M.target.value),placeholder:f,disabled:s||!o?.asset,style:{fontFamily:l?.fontFamily||k.typography.fontFamily,fontSize:"40px",fontWeight:700,color:s?"rgba(14, 13, 11, 0.16)":x?"#0e0d0b":"#d1d5db",lineHeight:"1.08",letterSpacing:"-1.2px",backgroundColor:"transparent",border:"none",outline:"none",padding:0,width:"100%",maxWidth:"200px"}}),e.jsx("div",{style:{width:"128px",position:"relative",flexShrink:0},children:e.jsx(cs,{selectedAsset:o,assets:t,onAssetSelect:r,showDropdown:p,onToggleDropdown:()=>b(!p),disabled:s,theme:k})})]}),e.jsx("div",{style:{display:"flex",justifyContent:"flex-end",alignItems:"center",gap:"10px",height:"14px"},children:[0,25,50,75,100].map((M,z)=>{const E=Math.abs($-M)<1,H=z===4,X=M/100,ee=m===M,U=y===M;return e.jsx("button",{onClick:()=>G(M),onMouseEnter:()=>j(M),onMouseLeave:()=>{j(null),h(null)},onMouseDown:()=>h(M),onMouseUp:()=>h(null),disabled:s||!o?.asset,title:`${M}%`,style:{width:"14px",height:"14px",padding:0,border:"none",backgroundColor:"transparent",cursor:s||!o?.asset?"not-allowed":"pointer",opacity:E?1:ee?.8:.5,transform:U?"scale(0.85)":ee?"scale(1.15)":"scale(1)",transition:"all 0.15s ease"},children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:H?"#ea4b4b":"none",stroke:H?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!H&&X>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${X>.5?1:0} 1 ${7+6.84375*Math.sin(X*2*Math.PI)} ${7-6.84375*Math.cos(X*2*Math.PI)} Z`,fill:"#3C3E42"})]})},M)})})]})},ht=co,ps=({status:t,size:o=20,theme:r})=>{const n=r||de.createTheme("dark"),s={width:`${o}px`,height:`${o}px`,display:"flex",alignItems:"center",justifyContent:"center"};return(()=>{switch(t){case"success":return e.jsx("svg",{style:{...s,color:n.colors.success},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 13l4 4L19 7"})});case"failed":return e.jsx("svg",{style:{...s,color:n.colors.error},fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M6 18L18 6M6 6l12 12"})});case"processing":return e.jsx("div",{style:{...s,border:`2px solid ${n.colors.primary}`,borderTop:"2px solid transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}});case"pending":default:return e.jsx("div",{style:{...s,border:`2px solid ${n.colors.textMuted}`,borderRadius:"50%",backgroundColor:n.colors.surface}})}})()},po=({step:t,explorerUrlBuilder:o,animationDelay:r=0,theme:n})=>{const s=n||de.createTheme("dark"),c=(()=>{switch(t.status){case"success":return{bg:`${s.colors.success}20`,border:s.colors.success};case"failed":return{bg:`${s.colors.error}20`,border:s.colors.error};case"processing":return{bg:`${s.colors.info}20`,border:s.colors.info};default:return{bg:s.colors.surface,border:s.colors.border}}})(),i=t.transactionHash&&o?o(t.chainId,t.transactionHash):null,d={display:"flex",alignItems:"center",gap:s.spacing.md,padding:s.spacing.md,borderRadius:s.borderRadius.lg,border:`1px solid ${c.border}`,backgroundColor:c.bg,transition:`all ${s.animation.normal}`,animation:t.status==="processing"?"pulse 2s infinite":void 0,animationDelay:`${r}ms`},g={flex:1,minWidth:0},f={display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:s.spacing.xs},u={fontSize:s.typography.fontSize.sm,fontWeight:s.typography.fontWeight.medium,color:s.colors.text},l={fontSize:s.typography.fontSize.xs,fontWeight:s.typography.fontWeight.medium,padding:`${s.spacing.xs} ${s.spacing.sm}`,borderRadius:s.borderRadius.full,backgroundColor:`${c.border}20`,color:c.border},C={fontSize:s.typography.fontSize.xs,color:s.colors.textMuted,marginBottom:s.spacing.xs},A={fontSize:s.typography.fontSize.xs,color:s.colors.textMuted,fontFamily:"IBM Plex Mono",marginTop:s.spacing.xs},w={fontSize:s.typography.fontSize.xs,backgroundColor:`${s.colors.info}20`,color:s.colors.info,border:"none",borderRadius:s.borderRadius.full,padding:`${s.spacing.xs} ${s.spacing.sm}`,cursor:"pointer",textDecoration:"none",display:"inline-flex",alignItems:"center",gap:s.spacing.xs,transition:`all ${s.animation.normal}`,":hover":{backgroundColor:`${s.colors.info}30`,color:s.colors.info}};return e.jsxs("div",{style:d,children:[e.jsx("div",{style:{flexShrink:0},children:e.jsx(ps,{status:t.status,theme:s})}),e.jsxs("div",{style:g,children:[e.jsxs("div",{style:f,children:[e.jsx("span",{style:u,children:t.chainName}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:s.spacing.sm},children:[e.jsx("span",{style:l,children:t.status.charAt(0).toUpperCase()+t.status.slice(1)}),t.status==="success"&&i&&e.jsxs("a",{href:i,target:"_blank",rel:"noopener noreferrer",style:w,title:"View on explorer",children:[e.jsx("svg",{width:"12",height:"12",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M10 6H6a2 2 0 00-2 2v10a2 2 0 002 2h10a2 2 0 002-2v-4M14 4h6m0 0v6m0-6L10 14"})}),"Explorer"]})]})]}),e.jsx("p",{style:C,children:t.description}),t.transactionHash&&e.jsx("p",{className:"ibm-plex-mono",style:A,children:no(t.transactionHash)})]})]})},uo=({intentStatus:t,onClose:o,onRetry:r,txType:n,onNewTx:s,explorerUrlBuilder:c,theme:i})=>{const d=i||de.createTheme("dark"),g={width:"100%",maxWidth:"28rem",margin:"0 auto",backgroundColor:d.colors.background,border:`1px solid ${d.colors.border}`,borderRadius:d.borderRadius.lg,padding:d.spacing.lg,color:d.colors.text},f={textAlign:"center",marginBottom:d.spacing.lg},u={width:"4rem",height:"4rem",margin:"0 auto",backgroundColor:d.colors.surface,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",border:`2px solid ${d.colors.border}`,marginBottom:d.spacing.md},l={fontSize:d.typography.fontSize.lg,fontWeight:d.typography.fontWeight.semibold,color:d.colors.text,marginBottom:d.spacing.sm},C={fontSize:d.typography.fontSize.sm,color:d.colors.textMuted},A={display:"flex",flexDirection:"column",gap:d.spacing.md,marginBottom:d.spacing.lg},w={padding:d.spacing.md,borderRadius:d.borderRadius.lg,marginBottom:d.spacing.lg},k={display:"flex",flexDirection:"column",gap:d.spacing.sm},p=(()=>{switch(t.overallStatus){case"success":return{title:`${n.charAt(0).toUpperCase()+n.slice(1)} completed successfully!`,description:"Your tokens are now available in your wallet",style:{...w,background:`linear-gradient(to right, ${d.colors.success}20, ${d.colors.success}10)`,border:`1px solid ${d.colors.success}`},icon:e.jsx("svg",{className:"w-4 h-4",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M5 13l4 4L19 7"})}),iconColor:d.colors.success};case"failed":return{title:"Transaction failed",description:"Please try again or contact support if the issue persists",style:{...w,background:`linear-gradient(to right, ${d.colors.error}20, ${d.colors.error}10)`,border:`1px solid ${d.colors.error}`},icon:e.jsx("svg",{className:"w-4 h-4",fill:"none",stroke:"currentColor",viewBox:"0 0 24 24",children:e.jsx("path",{strokeLinecap:"round",strokeLinejoin:"round",strokeWidth:2,d:"M12 9v2m0 4h.01m-6.938 4h13.856c1.54 0 2.502-1.667 1.732-2.5L13.732 4c-.77-.833-1.964-.833-2.732 0L3.732 16.5c-.77.833.192 2.5 1.732 2.5z"})}),iconColor:d.colors.error};default:return{title:`Processing your ${n}...`,description:"This may take a few seconds to complete",style:{...w,background:`linear-gradient(to right, ${d.colors.primary}20, ${d.colors.primary}10)`,border:`1px solid ${d.colors.primary}`},icon:e.jsx("div",{style:{width:"1rem",height:"1rem",border:`2px solid ${d.colors.primary}`,borderTop:"2px solid transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),iconColor:d.colors.primary}}})();return e.jsxs("div",{style:g,children:[e.jsxs("div",{style:f,children:[e.jsx("div",{style:u,children:e.jsx(ps,{status:t.overallStatus,size:32,theme:d})}),e.jsx("h3",{style:l,children:t.overallStatus==="success"?`${n.charAt(0).toUpperCase()+n.slice(1)} Completed!`:t.overallStatus==="failed"?"Transaction Failed":`Processing ${n}`}),e.jsx("p",{style:C,children:t.overallStatus==="success"?`Your tokens have been successfully ${n}`:t.overallStatus==="failed"?"Something went wrong with your transaction":`Please wait while we process your ${n} across chains`})]}),e.jsx("div",{style:A,children:t.steps.map((b,m)=>e.jsx(po,{step:b,explorerUrlBuilder:c,animationDelay:m*100,theme:d},b.stepId))}),e.jsx("div",{style:p.style,children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:d.spacing.md},children:[e.jsx("div",{style:{width:"2rem",height:"2rem",backgroundColor:`${p.iconColor}20`,borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",color:p.iconColor},children:p.icon}),e.jsxs("div",{children:[e.jsx("p",{style:{color:p.iconColor,fontWeight:d.typography.fontWeight.medium,fontSize:d.typography.fontSize.sm,margin:0},children:p.title}),e.jsx("p",{style:{color:`${p.iconColor}CC`,fontSize:d.typography.fontSize.xs,margin:`${d.spacing.xs} 0 0 0`},children:p.description})]})]})}),e.jsxs("div",{style:k,children:[t.overallStatus==="success"&&s&&e.jsxs(de.Button,{variant:"success",fullWidth:!0,onClick:s,theme:d,children:["Start New ",n]}),t.overallStatus==="failed"&&r&&e.jsx(de.Button,{variant:"error",fullWidth:!0,onClick:r,theme:d,children:"Try Again"}),t.overallStatus==="processing"&&e.jsx(de.Button,{variant:"ghost",fullWidth:!0,onClick:o,theme:d,children:"Cancel & Close"})]})]})},ho=({config:t,onChange:o,theme:r,styles:n})=>{const s=r||de.createTheme("dark"),c=["0%","0.1%","0.5%","1%"],i=p=>{o({...t,slippage:p,customSlippage:p==="custom"?t.customSlippage:void 0})},d=p=>{o({...t,slippage:"custom",customSlippage:p})},g={backgroundColor:n?.slippageSettings?.backgroundColor,border:n?.slippageSettings?.borderColor?`1px solid ${n.slippageSettings.borderColor}`:void 0,borderRadius:n?.slippageSettings?.borderRadius,padding:n?.slippageSettings?.padding,marginBottom:s.spacing.sm},f={fontSize:n?.slippageSettings?.label?.fontSize||s.typography.fontSize.xs,color:n?.slippageSettings?.label?.color||s.colors.textMuted,fontWeight:n?.slippageSettings?.label?.fontWeight,fontFamily:n?.slippageSettings?.label?.fontFamily||n?.fontFamily||s.typography.fontFamily,marginBottom:"4px"},u={display:"grid",gridTemplateColumns:"repeat(5, 1fr)",gap:"6px",alignItems:"center"},l={backgroundColor:n?.slippageSettings?.presetButton?.backgroundColor||s.colors.secondary,border:`1px solid ${n?.slippageSettings?.presetButton?.borderColor||s.colors.border}`,borderRadius:n?.slippageSettings?.presetButton?.borderRadius||s.borderRadius.md,color:n?.slippageSettings?.presetButton?.color||s.colors.textSecondary,cursor:"pointer",fontSize:n?.slippageSettings?.presetButton?.fontSize||s.typography.fontSize.xs,fontWeight:n?.slippageSettings?.presetButton?.fontWeight,fontFamily:n?.slippageSettings?.presetButton?.fontFamily||n?.fontFamily||s.typography.fontFamily,padding:n?.slippageSettings?.presetButton?.padding||`${s.spacing.xs} 0`,textAlign:"center",transition:`all ${s.animation.normal}`,":hover":{backgroundColor:n?.slippageSettings?.presetButton?.hoverBackgroundColor||s.colors.surfaceHover,borderColor:s.colors.borderHover}},C={...l,backgroundColor:n?.slippageSettings?.presetButton?.activeBackgroundColor||n?.primaryColor||s.colors.primary,borderColor:n?.slippageSettings?.presetButton?.activeBorderColor||n?.primaryColor||s.colors.primary,color:n?.slippageSettings?.presetButton?.activeColor||s.colors.text},A={backgroundColor:n?.slippageSettings?.customInput?.backgroundColor||"transparent",border:`1px solid ${t.slippage==="custom"?n?.slippageSettings?.customInput?.focusBorderColor||n?.primaryColor||s.colors.primary:n?.slippageSettings?.customInput?.borderColor||s.colors.border}`,borderRadius:n?.slippageSettings?.customInput?.borderRadius||s.borderRadius.md,color:n?.slippageSettings?.customInput?.color||s.colors.text,fontSize:n?.slippageSettings?.customInput?.fontSize||s.typography.fontSize.xs,fontWeight:n?.slippageSettings?.customInput?.fontWeight,fontFamily:n?.slippageSettings?.customInput?.fontFamily||n?.fontFamily||s.typography.fontFamily,padding:n?.slippageSettings?.customInput?.padding||s.spacing.sm,textAlign:"center",paddingRight:"1.5rem",width:"100%",outline:"none","::placeholder":{color:s.colors.textMuted}},w={position:"relative",display:"flex",alignItems:"center"},k={position:"absolute",right:s.spacing.xs,fontSize:n?.slippageSettings?.customInput?.fontSize||s.typography.fontSize.xs,fontFamily:n?.slippageSettings?.customInput?.fontFamily||n?.fontFamily||s.typography.fontFamily,color:s.colors.textMuted,pointerEvents:"none"};return e.jsxs("div",{style:g,children:[e.jsx("div",{style:f,children:"Slippage Tolerance"}),e.jsxs("div",{style:u,children:[c.map(p=>e.jsx("button",{style:t.slippage===p?C:l,onClick:()=>i(p),children:p},p)),e.jsxs("div",{style:w,children:[e.jsx("input",{type:"text",style:A,placeholder:"Custom",value:t.customSlippage||"",onFocus:()=>i("custom"),onChange:p=>d(p.target.value)}),t.slippage==="custom"&&e.jsx("span",{style:k,children:"%"})]})]})]})},go=({assets:t,selectedAsset:o,onAssetSelect:r,onAmountChange:n,amount:s="",disabled:c=!1,loading:i=!1,label:d="Collateral",placeholder:g="0.0",theme:f,styles:u})=>{const l=f||de.createTheme("dark"),[C,A]=a.useState(!1),w=a.useCallback(()=>{A(B=>!B)},[]),k=a.useCallback(B=>{const I=ls(B);n?.(I)},[n]),p=a.useCallback(()=>{o&&n&&n(o.balanceFormatted.toString())},[o,n]),b={backgroundColor:u?.assetSelector?.backgroundColor||u?.secondaryBackground||l.colors.surface,border:`1px solid ${u?.assetSelector?.borderColor||l.colors.border}`,borderRadius:u?.assetSelector?.borderRadius||l.borderRadius.md,padding:u?.assetSelector?.padding||`${l.spacing.sm} ${l.spacing.md}`,transition:`border-color ${l.animation.normal}`,opacity:c?.6:1,color:l.colors.text},m={display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"6px"},j={fontSize:u?.assetSelector?.label?.fontSize||l.typography.fontSize.xs,color:u?.assetSelector?.label?.color||l.colors.textMuted,fontWeight:u?.assetSelector?.label?.fontWeight,fontFamily:u?.assetSelector?.label?.fontFamily||u?.fontFamily||l.typography.fontFamily},y={fontSize:u?.assetSelector?.balance?.fontSize||l.typography.fontSize.xs,color:u?.assetSelector?.balance?.color||l.colors.textMuted,fontWeight:u?.assetSelector?.balance?.fontWeight,fontFamily:u?.assetSelector?.balance?.fontFamily||u?.fontFamily||l.typography.fontFamily},h={display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"6px"},x={background:u?.assetSelector?.amountInput?.backgroundColor||"transparent",border:"none",outline:"none",fontSize:u?.assetSelector?.amountInput?.fontSize||l.typography.fontSize.xl,fontWeight:u?.assetSelector?.amountInput?.fontWeight||l.typography.fontWeight.medium,color:u?.assetSelector?.amountInput?.color||l.colors.text,fontFamily:u?.assetSelector?.amountInput?.fontFamily||u?.fontFamily||l.typography.fontFamily,width:"50%","::placeholder":{color:l.colors.textMuted}},S={display:"flex",justifyContent:"space-between",alignItems:"center"},F={background:u?.button?.backgroundColor||l.colors.secondary,border:"none",borderRadius:u?.button?.borderRadius||l.borderRadius.sm,color:u?.button?.color||l.colors.textMuted,cursor:"pointer",fontSize:u?.button?.fontSize||l.typography.fontSize.xs,fontWeight:u?.button?.fontWeight,fontFamily:u?.button?.fontFamily||u?.fontFamily||l.typography.fontFamily,padding:u?.button?.padding||`4px ${l.spacing.xs}`,transition:`color ${l.animation.normal}`,":hover":{color:l.colors.text}};return i?e.jsxs("div",{style:b,children:[e.jsxs("div",{style:m,children:[e.jsx("div",{style:{...j,backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"60px"}}),e.jsx("div",{style:{...y,backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"80px"}})]}),e.jsxs("div",{style:h,children:[e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"32px",width:"100px"}}),e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"40px",width:"120px"}})]}),e.jsx("div",{style:S,children:e.jsx("div",{style:{backgroundColor:l.colors.border,borderRadius:l.borderRadius.sm,height:"12px",width:"50px"}})})]}):e.jsxs("div",{style:b,children:[e.jsxs("div",{style:m,children:[e.jsx("span",{style:j,children:d}),o&&e.jsxs("span",{style:y,children:["Balance: ",It(o.balanceFormatted)," ",o.symbol]})]}),e.jsxs("div",{style:h,children:[e.jsx("input",{type:"text",style:x,value:s,onChange:B=>k(B.target.value),placeholder:g,disabled:c||!o}),e.jsx("div",{style:{position:"relative",width:"120px"},children:e.jsx(cs,{selectedAsset:o?{asset:o,amount:""}:void 0,assets:t,onAssetSelect:r,showDropdown:C,onToggleDropdown:w,disabled:c,theme:l})})]}),e.jsxs("div",{style:S,children:[e.jsx("span",{style:y,children:o?`${It(o.balanceFormatted)} ${o.symbol}`:""}),o&&!c&&n&&e.jsx("button",{style:F,onClick:p,title:`Max: ${It(o.balanceFormatted,6)} ${o.symbol}`,children:"MAX"})]})]})},He=a.createContext(null),xo=({children:t,appId:o,supportedViemChains:r})=>{const[n,s]=a.useState(null),[c,i]=a.useState(!1);return a.useEffect(()=>{i(!0),typeof window<"u"&&import("@privy-io/react-auth").then(d=>{s(()=>d.PrivyProvider)}).catch(d=>{console.error("Failed to load Privy SDK:",d)})},[]),!c||!n?e.jsx(e.Fragment,{children:t}):e.jsx(n,{appId:o,config:{supportedChains:r,appearance:{loginMessage:"Log in or create your Spicenet account",accentColor:"#ea4b4b",theme:"#fafafa",showWalletLoginFirst:!1,walletChainType:"ethereum-only",walletList:["detected_ethereum_wallets","metamask","coinbase_wallet","base_account","rainbow","wallet_connect"]},loginMethods:["google","email","passkey"],fundingMethodConfig:{moonpay:{useSandbox:!0}},embeddedWallets:{requireUserPasswordOnCreate:!1,showWalletUIs:!0,ethereum:{createOnLogin:"users-without-wallets"},solana:{createOnLogin:"off"}},mfa:{noPromptOnMfaRequired:!1},externalWallets:{}},children:t})},fo=({children:t,environmentId:o})=>{const[r,n]=a.useState(null),[s,c]=a.useState(!1);return a.useEffect(()=>{c(!0),typeof window<"u"&&Promise.all([import("@dynamic-labs/sdk-react-core"),import("@dynamic-labs/ethereum")]).then(([i,d])=>{n({DynamicContextProvider:i.DynamicContextProvider,EthereumWalletConnectors:d.EthereumWalletConnectors})}).catch(i=>{})},[]),!s||!r?e.jsx(e.Fragment,{children:t}):e.jsx(r.DynamicContextProvider,{settings:{environmentId:o,walletConnectors:[r.EthereumWalletConnectors]},children:t})},mo=({children:t,provider:o,privyAppId:r,dynamicEnvironmentId:n,supportedChainIds:s=[11155111,421614,5115,123420001114],mode:c="7702",nativeChainId:i,appName:d="Spicenet"})=>{const g=s.map(f=>fe(f)?.viemChain).filter(Boolean);return c!=="7702"?(console.log(`[SpiceFlow] Running in ${c} mode - skipping embedded wallet providers`),e.jsx(He.Provider,{value:{provider:o,supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:t})):o==="privy"?r?e.jsx(He.Provider,{value:{provider:"privy",supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:e.jsx(xo,{appId:r,supportedViemChains:g,children:t})}):(console.warn("[SpiceFlow] Privy provider selected but no appId provided"),e.jsx(e.Fragment,{children:t})):o==="dynamic"?n?e.jsx(He.Provider,{value:{provider:"dynamic",supportedChainIds:s,mode:c,nativeChainId:i,appName:d},children:e.jsx(fo,{environmentId:n,children:t})}):(console.warn("[SpiceFlow] Dynamic provider selected but no environmentId provided"),e.jsx(e.Fragment,{children:t})):(console.warn("[SpiceFlow] No valid provider configuration found"),e.jsx(e.Fragment,{children:t}))},yo=()=>{const[t,o]=a.useState(!1);let r=null,n=null;try{r=_t.useDynamicContext()}catch(g){n=g instanceof Error?g.message:String(g),console.log("Dynamic context error in useWallet:",n)}if(a.useEffect(()=>{o(!0)},[]),n)return{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:"dynamic",actions:{signAuthorization:async()=>{throw new Error("Dynamic context not available")},signMessage:async()=>{throw new Error("Dynamic context not available")}}};const{user:s,primaryWallet:c}=r||{},i=!!s,d=c?.address;return{isReady:t&&!!r,isAuthenticated:i,isConnected:i&&!!d,address:d,provider:"dynamic",actions:{signAuthorization:async g=>{if(!c)throw new Error("Dynamic primary wallet not available");const{isEthereumWallet:f}=await import("@dynamic-labs/ethereum");throw f(c)?new Error("Dynamic EIP-7702 authorization not yet implemented - check Dynamic docs for your version"):new Error("Primary wallet is not an Ethereum wallet")},signMessage:async g=>{if(!c)throw new Error("Dynamic primary wallet not available");const{isEthereumWallet:f}=await import("@dynamic-labs/ethereum");if(!f(c))throw new Error("Primary wallet is not an Ethereum wallet");const u=typeof g=="object"&&"raw"in g?{raw:g.raw}:g;return{signature:await(await c.getWalletClient()).signMessage({message:u,account:c.address})}}}}},gt=()=>{const t=a.useContext(He),o=t?.mode||"7702";let r=null;try{r=Je.useWallets()}catch{r=null}const n=r?.wallets?.find(i=>i.connectorType==="embedded")?.address;let s=null;try{s=_t.useDynamicContext()}catch{s=null}const c=s?.primaryWallet?.address;if(!(!t||o!=="7702"))return t.provider==="privy"?n:t.provider==="dynamic"?c:n??c},bo=()=>{const[t,o]=a.useState(!1);let r=null,n=null,s=null,c=null;try{r=Je.usePrivy(),n=Je.useSign7702Authorization(),s=Je.useSignMessage(),c=Je.useWallets()}catch{return{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:null,actions:{signAuthorization:async()=>{throw new Error("Privy not available")},signMessage:async()=>{throw new Error("Privy not available")}}}}a.useEffect(()=>{o(!0)},[]);const{ready:i=!1,authenticated:d=!1}=r||{},g=gt(),f=c?.wallets?.find(u=>u.connectorType==="embedded");return{isReady:i,isAuthenticated:d,isConnected:i&&d&&!!g,address:g,provider:"privy",actions:{signAuthorization:async u=>{if(!n)throw new Error("Privy sign authorization not available");try{const l=await n.signAuthorization({contractAddress:u.contractAddress,chainId:u.chainId,nonce:u.nonce},{address:g});return delete l.v,l}catch(l){const C=l?.message||String(l);throw C.includes("not configured")||C.includes("chain")?new Error(`Chain ${u.chainId} is not configured in PrivyProvider. Add this chain to your Privy dashboard or supportedChainIds.`):l}},signMessage:async u=>{if(typeof u=="object"&&"raw"in u){if(!f)throw new Error("Embedded wallet not available for raw signing");const l=await f.getEthereumProvider();return{signature:await re.createWalletClient({account:f.address,transport:re.custom(l)}).signMessage({account:f.address,message:{raw:u.raw}})}}if(!s)throw new Error("Privy sign message not available");return{signature:(await s.signMessage({message:u})).signature}}}}},Lt=()=>{const t=a.useContext(He)?.provider;return t==="privy"?bo():t==="dynamic"?yo():{isReady:!1,isAuthenticated:!1,isConnected:!1,provider:null,actions:{signAuthorization:async()=>{throw new Error("No wallet provider available")},signMessage:async()=>{throw new Error("No wallet provider available")}}}},Yt=process.env.NEXT_PUBLIC_RELAYER_API_URL||"https://tx-submission-api-dev.spicenet.io";class Co{constructor(){this.baseUrl=Yt}async createAction(o){const r=await fetch(`${this.baseUrl}/actions`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o,(n,s)=>typeof s=="bigint"?s.toString():s)});if(!r.ok){const n=await r.text();throw new Error(`Relayer API error: ${r.status} - ${n}`)}return r.json()}async executeStep(o,r,n,s){const c=await fetch(`${this.baseUrl}/actions/${o}/intents/${r}/steps/${n}`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(s)});if(!c.ok){const i=await c.text();throw new Error(`Execute step error: ${c.status} - ${i}`)}return{success:!0}}async checkStepStatus(o,r){const n=o.split("/");let s="";if(n.length>=2){const d=n[0],g=n[1];s=`${this.baseUrl}/actions/${d}/intents/${g}/steps/${r}`}else s=`${this.baseUrl}/actions/${o}/intents/0/steps/${r}`;const c=await fetch(s);if(!c.ok)throw new Error(`Intent step status check failed: ${c.status}`);const i=await c.json();return{success:!0,data:{status:i.status==="error"?"reverted":i.status,transactionHash:i.txid}}}async submitSpiceDeposit(o){const r=o.isDeposit?"deposit":"withdrawal";try{const n=await fetch(`${this.baseUrl}/spicedeposit`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(o)}),s=await n.json();return!n.ok||!s.success?(console.error(`Failed to submit ${r} request to API:`,s.error?.message),{success:!1,error:s.error}):s}catch(n){return console.error(`Error submitting ${r} request to API:`,n),{success:!1,error:{message:n instanceof Error?n.message:"Unknown error"}}}}async requestSpiceUsdAirdrop(o){try{const r=await fetch(`${this.baseUrl}/airdrop/${o.chainId}/spiceUsd`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({wallet:o.address})}),n=await r.json().catch(()=>({}));if(!r.ok){const s=n&&(n.error||n.message)||"Failed to request airdrop";return{success:!1,errorMessage:String(s)}}return n&&typeof n.error=="string"?{success:!1,errorMessage:n.error}:n&&(n.txHash||n.amount)?{success:!0,txHash:n.txHash,amount:n.amount}:{success:!0}}catch(r){return{success:!1,errorMessage:r?.message&&typeof r.message=="string"?r.message:"Failed to request airdrop"}}}}const we=new Co,Et=(t,o)=>{const r=s=>o?o(s):st(s),n=[];return t.forEach((s,c)=>{if(s.calls&&s.calls.length>0){const i={stepId:c,status:c===0?"processing":"pending",chainId:s.chainId,chainName:r(s.chainId),description:"Processing transaction"};n.push(i)}}),n},Ao=({swapBatches:t,tokenAddress:o="0x0",supportedChains:r,theme:n="light",styles:s,className:c="",showSlippageSettings:i=!0,enableFlipSwap:d=!0,fromInputHook:g,toInputUpdateHook:f})=>{const u=de.createTheme(n),l={...u,typography:{...u.typography,fontFamily:s?.fontFamily||u.typography.fontFamily},colors:{...u.colors,primary:s?.primaryColor||u.colors.primary,primaryHover:s?.primaryColor?`${s.primaryColor}dd`:u.colors.primaryHover}},C=Lt(),{isReady:A,isAuthenticated:w,isConnected:k,address:p,provider:b,actions:m}=C,j=a.useContext(He),[y,h]=a.useState(null),[x,S]=a.useState(null),[F,B]=a.useState(null),[I,G]=a.useState(""),[P,_]=a.useState({slippage:"0.5%"}),[$,J]=a.useState(!1),[M,z]=a.useTransition(),{assets:E,loading:H,error:X,refreshAssets:ee}=Vt({address:p,supportedChains:r,fetchBalances:zt}),[U,ne]=a.useState(!1),[xe,ue]=a.useState(null),{intentStatus:Ee,startStatusPolling:R,clearStatus:q}=kt({checkStepStatus:(W,K)=>we.checkStepStatus(W,K)}),pe=a.useCallback(()=>{if(E.length===0||F)return;const W=E.filter(ie=>ie.isNative),K=W.length>0?W[0]:E[0];K&&B(K)},[E,F]);a.useEffect(()=>{pe()},[pe]),a.useEffect(()=>{f&&f.toAmount!==x?.amount&&x&&S({...x,amount:f.toAmount})},[f?.toAmount,x]);const v=a.useCallback(()=>{ue(null)},[]),N=(W,K)=>W.chainId===K.chainId&&W.address.toLowerCase()===K.address.toLowerCase(),O=(W,K)=>{if(K==="collateral"){const ie=E.filter(me=>!N(me,W));return ie.length>0?ie[0]:null}else{const ie=r.flatMap(me=>Rt(me,E)).filter(me=>!N(me,W));return ie.length>0?ie[0]:null}},se=W=>{if(x&&N(x.asset,W)){const K=O(W,"fromTo");S(K?{asset:K,amount:""}:null)}if(F&&N(F,W)){const K=O(W,"collateral");B(K)}h({asset:W,amount:y?.amount||""}),v()},ae=W=>{if(y&&N(y.asset,W)){const K=O(W,"fromTo");h(K?{asset:K,amount:""}:null)}if(F&&N(F,W)){const K=O(W,"collateral");B(K)}S({asset:W,amount:x?.amount||""}),v()},Z=W=>{if(y&&N(y.asset,W)){const K=O(W,"fromTo");h(K?{asset:K,amount:""}:null)}if(x&&N(x.asset,W)){const K=O(W,"fromTo");S(K?{asset:K,amount:""}:null)}B(W),v()},he=a.useCallback(W=>{y&&(z(()=>{h({...y,amount:W}),x&&S({...x,amount:W}),G(W),v()}),g&&g.setFromAmount(W))},[y,x,g,v]),Ce=a.useCallback(W=>{x&&z(()=>{S({...x,amount:W}),y&&h({...y,amount:W}),G(W),v()})},[x,y,v]),T=a.useCallback(W=>{z(()=>{G(W),y&&h({...y,amount:W}),x&&S({...x,amount:W}),v()})},[y,x,v]),oe=a.useCallback(()=>{if(d&&y&&x){const W=y.amount;z(()=>{h({asset:x.asset,amount:W}),S({asset:y.asset,amount:W}),G(W),J(!$),v()})}},[d,y,x,$,v]),le=async()=>{if(!y||!x||!F||!p||t.length===0)return;const W=j?.mode||"7702";if(W==="7702"&&(!A||!w)){ue(`Please authenticate with ${b||"wallet provider"} to continue`);return}if(W!=="7702"){ue("Only EIP-7702 mode is currently supported for Swaps.");return}ne(!0),ue(null);try{const K=await Ve(F.chainId).getBlockNumber(),ie=[{chainId:F.chainId,recentBlock:K,calls:[{to:"0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",value:re.parseEther(I),data:"0x"}]},...t],me=[...new Set(ie.map(be=>be.chainId))],$e=[];for(const be of me){const Re=Ve(be),ge=pt(be),nt=await Ye.getAccountNonce(p,Re),tt=await m.signAuthorization({contractAddress:ge,chainId:be,nonce:Number(nt)});$e.push(tt)}const Y=Ye.hashChainBatches(ie),te=Math.floor(Date.now()/1e3)+60*10,Fe=Ye.getIntentHash(BigInt(0),BigInt(te),Y),De=await m.signMessage({raw:Fe}),_e=typeof De=="string"?De:De.signature;if(!_e)throw new Error("Failed to sign intent authorization");const it={mode:"7702",signatureType:"ecdsa",signature:_e,nbf:0,exp:te,chainBatches:Y.map(be=>({hash:be.hash,chainId:Number(be.chainId),tokenTransfers:[],calls:be.calls}))},et={user:p,chainAuthorizations:$e.map(be=>({...be,r:be.r,s:be.s,nonce:Number(be.nonce),chainId:Number(be.chainId)})),intents:[it]},Ze=await we.createAction(et);if(Ze){const be=Et(ie,Re=>`Chain ${Re}`);R(Ze.intentIds[0],be);for(let Re=0;Re<ie.length;Re++)console.log(`[SwapWidget] Executing step ${Re}...`),await we.executeStep(Ze.actionId,0,Re,{action:"execute"}),console.log(`[SwapWidget] Step ${Re} completed`);console.log("[SwapWidget] All steps executed"),ee()}}catch(K){const ie=K instanceof Error?K.message:"Swap failed";ue(ie)}finally{ne(!1)}},Se=r.flatMap(W=>Rt(W,E)),ve=r.flatMap(W=>Rt(W,E)),ke=E.filter(W=>r.includes(W.chainId)),Ie=y&&x&&F&&y.amount&&parseFloat(y.amount)>0&&parseFloat(y.amount)<=y.asset.balanceFormatted&&I&&parseFloat(I)>0&&parseFloat(I)<=F.balanceFormatted&&k&&!U&&t.length>0,ce=X||xe,ze={backgroundColor:s?.container?.backgroundColor||s?.primaryBackground||l.colors.background,border:`1px solid ${s?.container?.borderColor||l.colors.border}`,borderRadius:s?.container?.borderRadius||l.borderRadius.lg,padding:s?.container?.padding||l.spacing.md,width:s?.container?.width||"100%",maxWidth:"28rem",margin:"0 auto",color:l.colors.text,fontFamily:l.typography.fontFamily,boxShadow:s?.container?.boxShadow||(l.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")};return Ee?e.jsx("div",{className:c,children:e.jsx(uo,{intentStatus:Ee,onClose:q,onRetry:()=>{q(),le()},txType:"swap",onNewTx:()=>{q(),h(null),S(null),B(null),G(""),ee()},explorerUrlBuilder:(W,K)=>Wt(W,K),theme:l})}):e.jsxs("div",{style:ze,className:c,children:[e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsxs("div",{style:{padding:s?.statusDisplay?.padding||"8px",backgroundColor:s?.statusDisplay?.backgroundColor||s?.tertiaryBackground||(l.mode==="light"?"#f9fafb":l.colors.surface),border:`1px solid ${s?.statusDisplay?.borderColor||(l.mode==="light"?"#e5e7eb":l.colors.border)}`,borderRadius:s?.statusDisplay?.borderRadius||l.borderRadius.md},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("span",{style:{fontSize:s?.statusDisplay?.text?.fontSize||l.typography.fontSize.xs,fontWeight:s?.statusDisplay?.text?.fontWeight||l.typography.fontWeight.medium,color:s?.statusDisplay?.text?.color||l.colors.text,fontFamily:s?.statusDisplay?.text?.fontFamily||l.typography.fontFamily},children:[j?.provider==="privy"?"Privy":j?.provider==="dynamic"?"Dynamic":"Wallet"," ","Status"]}),e.jsx("span",{style:{fontSize:s?.statusDisplay?.text?.fontSize||l.typography.fontSize.xs,padding:`2px ${l.spacing.xs}`,borderRadius:l.borderRadius.sm,border:`1px solid ${k?s?.statusDisplay?.successColor||l.colors.success:s?.statusDisplay?.warningColor||l.colors.warning}`,backgroundColor:k?l.mode==="light"?"#dcfce7":`${s?.statusDisplay?.successColor||l.colors.success}20`:l.mode==="light"?"#fef3c7":`${s?.statusDisplay?.warningColor||l.colors.warning}20`,color:k?s?.statusDisplay?.successColor||l.colors.success:s?.statusDisplay?.warningColor||l.colors.warning,fontFamily:s?.statusDisplay?.text?.fontFamily||l.typography.fontFamily},children:k?"Connected":"Disconnected"})]}),k&&p&&e.jsxs("div",{className:"ibm-plex-mono",style:{marginTop:"6px",backgroundColor:s?.addressDisplay?.backgroundColor||(l.mode==="light"?"#f3f4f6":l.colors.secondary),border:`1px solid ${s?.addressDisplay?.borderColor||(l.mode==="light"?"#d1d5db":l.colors.borderHover)}`,borderRadius:s?.addressDisplay?.borderRadius||l.borderRadius.sm,padding:s?.addressDisplay?.padding||`${l.spacing.xs} ${l.spacing.sm}`,fontSize:s?.addressDisplay?.fontSize||l.typography.fontSize.xs,fontFamily:s?.addressDisplay?.fontFamily||(s?.fontFamily?`${s.fontFamily}, IBM Plex Mono`:"IBM Plex Mono"),color:s?.addressDisplay?.color||l.colors.text,display:"flex",alignItems:"center",gap:l.spacing.sm},children:[e.jsxs("span",{style:{flex:1},children:[p.slice(0,6),"...",p.slice(-4)]}),e.jsx("button",{style:{fontSize:s?.addressDisplay?.copyButton?.fontSize||l.typography.fontSize.xs,padding:s?.addressDisplay?.copyButton?.padding||`${l.spacing.xs} ${l.spacing.sm}`,backgroundColor:s?.addressDisplay?.copyButton?.backgroundColor||(l.mode==="light"?"#e5e7eb":l.colors.surfaceHover),border:`1px solid ${s?.addressDisplay?.copyButton?.borderColor||(l.mode==="light"?"#d1d5db":l.colors.border)}`,borderRadius:s?.addressDisplay?.copyButton?.borderRadius||l.borderRadius.sm,color:s?.addressDisplay?.copyButton?.color||l.colors.text,fontFamily:s?.addressDisplay?.copyButton?.fontFamily||l.typography.fontFamily,cursor:"pointer",transition:`background-color ${l.animation.normal}`},onClick:()=>ro(p),title:"Copy address",children:"Copy"})]}),!A&&e.jsxs("div",{style:{marginTop:"6px",fontSize:l.typography.fontSize.xs,color:l.colors.textSecondary,fontFamily:l.typography.fontFamily},children:["Loading"," ",j?.provider==="privy"?"Privy":j?.provider==="dynamic"?"Dynamic":"Wallet","..."]})]})]}),e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(go,{assets:ke,selectedAsset:F,onAssetSelect:Z,onAmountChange:T,amount:I,loading:H,label:"Collateral",theme:l,styles:s})]}),e.jsx("div",{style:{marginBottom:0},children:e.jsx(ht,{assets:Se,selectedAsset:y||void 0,onAssetSelect:se,onAmountChange:he,loading:H,label:"From",showBalance:!0,showMaxButton:!0,theme:l,styles:s})}),d&&e.jsx("div",{style:{display:"flex",justifyContent:"center",margin:`-${l.spacing.sm} 0`,position:"relative",zIndex:10},children:e.jsx("button",{onClick:oe,disabled:U||H,style:{backgroundColor:s?.flipButton?.backgroundColor||l.colors.primary,border:`1px solid ${s?.flipButton?.borderColor||l.colors.primary}`,borderRadius:s?.flipButton?.borderRadius||"50%",width:s?.flipButton?.size||"2.5rem",height:s?.flipButton?.size||"2.5rem",display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",color:s?.flipButton?.color||"#ffffff",transition:`all ${l.animation.normal}`,transform:$?"rotate(180deg)":"rotate(0deg)",boxShadow:l.mode==="light"?"0 2px 4px rgba(0, 0, 0, 0.1)":"0 2px 4px rgba(0, 0, 0, 0.3)"},onMouseEnter:W=>{W.currentTarget.style.backgroundColor=s?.flipButton?.hoverBackgroundColor||l.colors.primaryHover,W.currentTarget.style.transform=$?"rotate(360deg) scale(1.1)":"rotate(0deg) scale(1.1)"},onMouseLeave:W=>{W.currentTarget.style.backgroundColor=s?.flipButton?.backgroundColor||l.colors.primary,W.currentTarget.style.transform=$?"rotate(360deg) scale(1)":"rotate(0deg) scale(1)"},children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",children:e.jsx("path",{d:"M6 9l6 6 6-6"})})})}),e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(ht,{assets:ve,selectedAsset:x||void 0,onAssetSelect:ae,onAmountChange:Ce,loading:H,label:"To",theme:l,styles:s})]}),i&&e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsx(ho,{config:P,onChange:_,theme:l,styles:s})]}),t.length>0&&e.jsxs("div",{style:{marginBottom:l.spacing.sm},children:[" ",e.jsxs("div",{style:{backgroundColor:s?.infoCard?.backgroundColor||s?.tertiaryBackground||(l.mode==="light"?"#f9fafb":l.colors.surface),border:`1px solid ${s?.infoCard?.borderColor||(l.mode==="light"?"#e5e7eb":l.colors.border)}`,borderRadius:s?.infoCard?.borderRadius||l.borderRadius.md,padding:s?.infoCard?.padding||l.spacing.sm},children:[e.jsx("div",{style:{fontSize:s?.infoCard?.title?.fontSize||l.typography.fontSize.xs,fontWeight:s?.infoCard?.title?.fontWeight||l.typography.fontWeight.medium,color:s?.infoCard?.title?.color||l.colors.text,fontFamily:s?.infoCard?.title?.fontFamily||l.typography.fontFamily,marginBottom:"4px"},children:"Swap Batches Ready"}),e.jsxs("div",{style:{fontSize:s?.infoCard?.description?.fontSize||l.typography.fontSize.xs,color:s?.infoCard?.description?.color||l.colors.textSecondary,fontFamily:s?.infoCard?.description?.fontFamily||l.typography.fontFamily},children:[t.length," swap batch",t.length>1?"es":""," across chains:"," ",[...new Set(t.map(W=>W.chainId))].join(", ")]})]})]}),ce&&e.jsx("div",{style:{backgroundColor:s?.errorMessage?.backgroundColor||(l.mode==="light"?"#fef2f2":`${s?.statusDisplay?.errorColor||l.colors.error}20`),border:`1px solid ${s?.errorMessage?.borderColor||(l.mode==="light"?"#fecaca":s?.statusDisplay?.errorColor||l.colors.error)}`,borderRadius:s?.errorMessage?.borderRadius||l.borderRadius.md,padding:s?.errorMessage?.padding||l.spacing.md,marginBottom:l.spacing.sm},children:e.jsx("p",{style:{color:s?.errorMessage?.color||s?.statusDisplay?.errorColor||l.colors.error,fontSize:s?.errorMessage?.fontSize||l.typography.fontSize.sm,fontWeight:s?.errorMessage?.fontWeight,fontFamily:s?.errorMessage?.fontFamily||l.typography.fontFamily,margin:0},children:ce})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:l.spacing.sm},children:e.jsx(de.Button,{variant:"primary",fullWidth:!0,onClick:le,loading:U,disabled:!Ie||!k,theme:l,styles:s,children:A?w?k?U?"Executing Swap...":y?x?F?y.amount?I?parseFloat(y.amount)>y.asset.balanceFormatted?"Insufficient From Balance":parseFloat(I)>F.balanceFormatted?"Insufficient Collateral Balance":t.length===0?"No Swap Batches":"Execute Swap":"Enter Collateral Amount":"Enter Amount":"Select Collateral":"Select To Token":"Select From Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})},us=({address:t,supportedChains:o,enabled:r=!0,refetchInterval:n})=>{const[s,c]=a.useState([]),[i,d]=a.useState(!1),[g,f]=a.useState(null),[u,l]=a.useState(!1),C=a.useRef(!1),A=a.useRef(!1),w=o?JSON.stringify([...o].sort()):"",k=a.useCallback(async(m=!1)=>{if(!t||!r){c([]),l(!1),C.current=!1;return}if(!A.current){A.current=!0,!C.current&&!m&&d(!0),f(null);try{const j=await fetch(`${Yt}/spicedeposit/${t}`);if(!j.ok)throw new Error(`Failed to fetch balance: ${j.status}`);const y=await j.json();if(y.success&&y.data?.tokens&&Array.isArray(y.data.tokens)){const h=[];y.data.tokens.forEach(x=>{const S=x.chainId,F=x.tokenAddress,B=x.amount;if(o&&!o.includes(S))return;const I=BigInt(B||"0");if(I>BigInt(0)){const G=fe(S),P=F.toLowerCase()==="0x0"||F.toLowerCase()==="0x0000000000000000000000000000000000000000"||F.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";let _=18,$="TOKEN",J=F.slice(0,6)+"..."+F.slice(-4),M;if(P)_=G?.nativeCurrency?.decimals||18,$=G?.nativeCurrency?.symbol||"ETH",J=G?.nativeCurrency?.name||"Native Token";else{const E=G?.supportedTokens?.find(H=>H.address.toLowerCase()===F.toLowerCase());E&&(_=E.decimals,$=E.symbol,J=E.name,M=E.logoURI)}const z=parseFloat((Number(I)/Math.pow(10,_)).toFixed(6));z>0&&h.push({address:P?"0x0000000000000000000000000000000000000000":F,symbol:$,name:J,decimals:_,chainId:S,balance:I,balanceFormatted:z,balanceUsd:0,isNative:P,logoURI:M})}}),c(h),l(h.length>0),C.current=!0}else c([]),l(!1)}catch(j){const y=j instanceof Error?j.message:"Failed to fetch balance";f(y),console.error("Error fetching Spice assets:",j),C.current||(c([]),l(!1))}finally{d(!1),A.current=!1}}},[t,r,w]);a.useEffect(()=>{r&&t&&(C.current=!1,k(!1))},[t,r,w]),a.useEffect(()=>{if(!r||!t||!n)return;const m=setInterval(()=>{k(!0)},n);return()=>clearInterval(m)},[t,r,n,w]);const p=a.useCallback(m=>s.filter(j=>j.chainId===m),[s]),b=a.useCallback(async()=>{await k(!0)},[k]);return{assets:s,loading:i,error:g,hasBalance:u,refetch:b,getAssetsByChain:p}},hs=({isSuccess:t,type:o,chainName:r,explorerUrl:n,txHash:s})=>e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"14px 16px",borderRadius:"8px",backgroundColor:t?"#d1fae5":"#fee2e2",border:t?"1px solid #6ee7b7":"1px solid #fca5a5"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px"},children:[e.jsx("div",{style:{width:"28px",height:"28px",borderRadius:"50%",backgroundColor:t?"#10b981":"#ef4444",display:"flex",alignItems:"center",justifyContent:"center"},children:t?e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",children:e.jsx("path",{d:"M11.6667 3.5L5.25 9.91667L2.33333 7",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})}):e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 14 14",fill:"none",children:e.jsx("path",{d:"M10.5 3.5L3.5 10.5M3.5 3.5L10.5 10.5",stroke:"white",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})}),e.jsxs("div",{children:[e.jsx("p",{style:{margin:0,fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.5px",color:t?"#065f46":"#dc2626"},children:t?`${o.toUpperCase()} CONFIRMED`:`${o.toUpperCase()} FAILED`}),e.jsxs("p",{style:{margin:"2px 0 0 0",fontSize:"12px",color:"#6b7280"},children:["on ",r]})]})]}),n&&s&&e.jsxs("a",{href:`${n}/tx/${s}`,target:"_blank",rel:"noopener noreferrer",style:{display:"flex",alignItems:"center",gap:"4px",fontSize:"13px",color:"#6b7280",textDecoration:"none",whiteSpace:"nowrap"},children:["View on explorer",e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",children:[e.jsx("path",{d:"M9 6.5V9.5C9 9.76522 8.89464 10.0196 8.70711 10.2071C8.51957 10.3946 8.26522 10.5 8 10.5H2.5C2.23478 10.5 1.98043 10.3946 1.79289 10.2071C1.60536 10.0196 1.5 9.76522 1.5 9.5V4C1.5 3.73478 1.60536 3.48043 1.79289 3.29289C1.98043 3.10536 2.23478 3 2.5 3H5.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M7.5 1.5H10.5V4.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"}),e.jsx("path",{d:"M5 7L10.5 1.5",stroke:"currentColor",strokeLinecap:"round",strokeLinejoin:"round"})]})]})]}),qt=({isOpen:t,onClose:o,onComplete:r,type:n,results:s,chainName:c="Network",explorerUrl:i,theme:d,styles:g,intentStatus:f,onRetry:u,onNewTx:l,onRetryTx:C,asOverlay:A=!1,isProcessing:w=!1})=>{const k=d||de.createTheme("light"),[p,b]=a.useState(!1),[m,j]=a.useState(!0),[y,h]=a.useState(null),[x,S]=a.useState(null);a.useEffect(()=>{!t&&!f&&b(!1)},[t,f]);const F=()=>{b(!0),setTimeout(()=>{r?.()},300)},B=()=>{j(!m)};if(f){const{steps:P,overallStatus:_}=f,$=_==="processing",J=_==="success",M=_==="failed",z=P.find(ee=>ee.transactionHash),E=c!=="Network"?c:P[0]?.chainName||c,H=i||(z?Wt(z.chainId,z.transactionHash||"").replace(/\/tx\/.*$/,""):void 0),X=e.jsxs(e.Fragment,{children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"16px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",cursor:"pointer"},onClick:B,children:[e.jsxs("span",{style:{fontSize:"13px",fontWeight:500,color:"#6b7280",fontFamily:g?.fontFamily||k.typography.fontFamily},children:[$?`Processing ${n.charAt(0).toUpperCase()+n.slice(1)}`:`${n.charAt(0).toUpperCase()+n.slice(1)} results`," "]}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",style:{transform:m?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.3s ease"},children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#6b7280",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]}),!$&&e.jsx("button",{onClick:o,onMouseEnter:()=>h("close"),onMouseLeave:()=>{h(null),S(null)},onMouseDown:()=>S("close"),onMouseUp:()=>S(null),style:{background:x==="close"?"#f3f4f6":y==="close"?"#f9fafb":"none",border:"none",borderRadius:"4px",cursor:"pointer",padding:"4px",display:"flex",alignItems:"center",justifyContent:"center",color:y==="close"||x==="close"?"#374151":"#6b7280",transform:x==="close"?"scale(0.9)":y==="close"?"scale(1.1)":"scale(1)",transition:"all 0.15s ease"},children:e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:e.jsx("path",{d:"M12 4L4 12M4 4L12 12",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})})]}),e.jsx("div",{style:{marginBottom:"16px"},children:$?e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"center",padding:"20px 16px",borderRadius:"8px",backgroundColor:"#f3f4f6",border:"1px solid #e5e7eb",gap:"12px"},children:[e.jsx("div",{style:{width:"24px",height:"24px",border:"3px solid #e5e7eb",borderTopColor:k.colors.primary,borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsxs("div",{children:[e.jsx("p",{style:{margin:0,fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.5px",color:"#374151"},children:"PROCESSING TRANSACTION"}),e.jsxs("p",{style:{margin:"2px 0 0 0",fontSize:"12px",color:"#6b7280"},children:["on ",E]})]})]}):e.jsx(hs,{isSuccess:J,type:n,chainName:E,explorerUrl:H,txHash:z?.transactionHash})}),e.jsx("style",{children:`
|
|
3
3
|
@keyframes spin {
|
|
4
4
|
from { transform: rotate(0deg); }
|
|
5
5
|
to { transform: rotate(360deg); }
|
|
6
6
|
}
|
|
7
|
-
`}),e.jsx("div",{style:{overflow:"hidden",maxHeight:m?"300px":"0px",opacity:m?1:0,transition:"max-height 0.3s ease, opacity 0.3s ease",marginBottom:m?"16px":"0"},children:e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:P.map((ee,
|
|
7
|
+
`}),e.jsx("div",{style:{overflow:"hidden",maxHeight:m?"300px":"0px",opacity:m?1:0,transition:"max-height 0.3s ease, opacity 0.3s ease",marginBottom:m?"16px":"0"},children:e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:P.map((ee,U)=>e.jsxs("div",{style:{padding:"10px 12px",borderRadius:"6px",backgroundColor:"#f9fafb",border:"1px solid #e5e7eb",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("span",{style:{fontSize:"13px",color:"#374151"},children:ee.description||`Step ${U+1}`}),e.jsx("span",{style:{fontSize:"12px",color:ee.status==="success"?"#10b981":ee.status==="failed"?"#ef4444":"#6b7280",fontWeight:500},children:ee.status==="success"?"\u2713":ee.status==="failed"?"\u2717":"\u25CB"})]},U))})}),!$&&e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[M&&u&&e.jsx("button",{onClick:u,onMouseEnter:()=>h("retry"),onMouseLeave:()=>{h(null),S(null)},onMouseDown:()=>S("retry"),onMouseUp:()=>S(null),style:{width:"100%",height:"48px",padding:"14px 24px",borderRadius:"6px",backgroundColor:x==="retry"?"#d43d3d":y==="retry"?"#f05555":"#ea4b4b",border:"1px solid #0e0d0b",color:"#0e0d0b",fontWeight:500,fontSize:"16px",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",transition:"all 0.15s ease",transform:x==="retry"?"scale(0.98)":y==="retry"?"translateY(-2px)":"none",boxShadow:x==="retry"?"1px 1px 0px black":y==="retry"?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:"TRY AGAIN"}),l&&e.jsxs("button",{onClick:l,onMouseEnter:()=>h("new-tx"),onMouseLeave:()=>{h(null),S(null)},onMouseDown:()=>S("new-tx"),onMouseUp:()=>S(null),style:{width:"100%",height:"48px",padding:"14px 24px",borderRadius:"6px",backgroundColor:x==="new-tx"?"#d43d3d":y==="new-tx"?"#f05555":"#ea4b4b",border:"1px solid #0e0d0b",color:"#0e0d0b",fontWeight:500,fontSize:"16px",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",transition:"all 0.15s ease",transform:x==="new-tx"?"scale(0.98)":y==="new-tx"?"translateY(-2px)":"none",boxShadow:x==="continue-intent"?"1px 1px 0px black":y==="new-tx"?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:["NEW ",n," \u2192"]})]})]});return A?e.jsxs("div",{style:{position:"absolute",bottom:0,left:0,right:0,zIndex:10,animation:p?"slideDown 0.3s ease-in forwards":"slideUp 0.3s ease-out forwards",pointerEvents:"auto"},children:[e.jsx("div",{style:{backgroundColor:"#ffffff",borderRadius:"12px 12px 0 0",width:"100%",padding:"18px 24px 24px",boxShadow:"0 -4px 8px -2px rgba(0, 0, 0, 0.15)"},children:X}),e.jsx("style",{children:`
|
|
8
8
|
@keyframes slideUp {
|
|
9
9
|
from { transform: translateY(100%); }
|
|
10
10
|
to { transform: translateY(0); }
|
|
@@ -35,12 +35,12 @@
|
|
|
35
35
|
transform: translateY(100%);
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
|
-
`})]})},gs=({depositBatches:t,tokenAddress:o,tokenDecimals:r,supportedChains:n,supportedTokens:s,theme:c="light",styles:i,className:d="",depositInputHook:g,onDepositSuccess:f,onDepositError:u,onTopUp:l})=>{const C=de.createTheme(c),A={...C,typography:{...C.typography,fontFamily:i?.fontFamily||C.typography.fontFamily},colors:{...C.colors,primary:i?.primaryColor||C.colors.primary,primaryHover:i?.primaryColor?`${i.primaryColor}dd`:C.colors.primaryHover}},w=Lt(),{isReady:k,isAuthenticated:p,isConnected:b,address:m,provider:j,actions:y}=w,[h,x]=a.useState(null),{assets:S,loading:F,error:B,hasBalance:I,refetch:G}=us({address:m,supportedChains:n,enabled:b,refetchInterval:3e4}),[P,_]=a.useState(!1),[$,J]=a.useState(null),[M,z]=a.useState(!1),[E,U]=a.useState(!1),[X,ee]=a.useState(!1),H=a.useRef(null),{intentStatus:ne,startStatusPolling:xe,clearStatus:ue}=kt({checkStepStatus:(Z,he)=>we.checkStepStatus(Z,he)});a.useEffect(()=>{if(ne?.overallStatus==="success"&&ne.intentId&&H.current!==ne.intentId&&h&&m){const Z=ne.steps.find(he=>he.transactionHash);if(Z?.transactionHash){H.current=ne.intentId;const he=re.parseUnits(h.amount,h.asset.decimals);we.submitSpiceDeposit({user:m,txHash:Z.transactionHash,sender:m,tokenAddress:h.asset.address,chainId:h.asset.chainId,amount:he.toString(),isDeposit:!1}).then(()=>{G()}).catch(()=>{H.current=null})}}},[ne,m]),a.useEffect(()=>{g&&g.assetAmount!==h?.amount&&h&&x({...h,amount:g.assetAmount})},[g?.assetAmount,h]);const Ee=a.useCallback(()=>{J(null)},[]),R=Z=>{x({asset:Z,amount:h?.amount||""}),Ee()},q=a.useCallback(Z=>{h&&(a.startTransition(()=>{x({...h,amount:Z}),Ee()}),g&&g.setAssetAmount(Z))},[h,g,Ee]),pe=async()=>{if(!(!h||!m||t.length===0)){if(!k||!p){J(`Please authenticate with ${j||"wallet provider"} to continue`);return}_(!0),J(null),ee(!0);try{const Z=[...t],he=[...new Set(Z.map(ce=>ce.chainId))],Ce=[];for(const ce of he){const ze=Ve(ce),W=ct(ce),K=await Ye.getAccountNonce(m,ze),ie=await y.signAuthorization({contractAddress:W,chainId:ce,nonce:Number(K)});Ce.push(ie)}const T=Ye.hashChainBatches(Z),oe=Math.floor(Date.now()/1e3)+60*10,le=Ye.getIntentHash(0n,BigInt(oe),T),Se=await y.signMessage({raw:le}),ve=typeof Se=="string"?Se:Se.signature;if(!ve)throw new Error("Failed to sign intent authorization");const ke={mode:"7702",signatureType:"ecdsa",signature:ve,nbf:0,exp:oe,chainBatches:T.map(ce=>({hash:ce.hash,chainId:ce.chainId,tokenTransfers:[{from:"solver",to:m,token:"0x0000000000000000000000000000000000000000",amount:re.parseUnits("0.01",18)},{from:"solver",to:m,token:o,amount:re.parseUnits(h.amount,r)}],calls:ce.calls}))},Ie=await we.createAction({user:m,chainAuthorizations:Ce.map(ce=>({...ce,r:ce.r,s:ce.s,yParity:ce.yParity,address:ce.address,chainId:Number(ce.chainId),nonce:Number(ce.nonce)})),intents:[ke]});if(Ie){const ce=Et(Z,ie=>`Chain ${ie}`),[ze,W]=Ie.intentIds[0].split("/"),K=parseInt(W||"0",10);xe(Ie.intentIds[0],ce);for(let ie=0;ie<Z.length;ie++)await we.executeStep(ze,K,ie,{action:"execute"})}}catch(Z){const he=Z instanceof Error?Z.message:"Deposit failed";J(he),u?.(he)}finally{_(!1)}}},v=a.useMemo(()=>s&&s.length>0?S.filter(Z=>s.some(he=>he.toLowerCase()===Z.symbol.toLowerCase())):S,[S,s]),N=h&&h.amount&&parseFloat(h.amount)>0&&parseFloat(h.amount)<=h.asset.balanceFormatted&&b&&!P&&t.length>0,O=B||$,se={backgroundColor:i?.container?.backgroundColor||i?.primaryBackground||A.colors.background,border:`1px solid ${i?.container?.borderColor||A.colors.border}`,borderRadius:i?.container?.borderRadius||A.borderRadius.lg,padding:i?.container?.padding||A.spacing.md,width:i?.container?.width||"100%",maxWidth:"28rem",minHeight:"200px",margin:"0 auto",color:A.colors.text,fontFamily:A.typography.fontFamily,boxShadow:i?.container?.boxShadow||(A.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")},ae=ne?e.jsx(qt,{type:"deposit",isOpen:!!ne&&ne.overallStatus!=="processing",isProcessing:P||ne?.overallStatus==="processing",onRetryTx:()=>{ue(),ee(!1),pe()},onNewTx:()=>{ue(),ee(!1),x(null),H.current=null,G()},onClose:()=>{ue(),ee(!1)},onComplete:()=>{ue(),ee(!1),x(null),H.current=null,G()},results:ne?.overallStatus==="success"||ne?.overallStatus==="failed"?ne.steps.map(Z=>({asset:{symbol:h?.asset.symbol||"Token",address:h?.asset.address||""},txHash:Z.transactionHash||"",success:Z.status==="success",amount:h?.amount})):void 0,chainName:h?st(t[t.length-1].chainId):"Network",explorerUrl:h?Wt(t[t.length-1].chainId,"").replace(/\/tx\/.*$/,""):void 0,theme:A}):null;return e.jsxs("div",{style:{...se,position:"relative"},className:d,children:[ae&&e.jsx("div",{style:{position:"absolute",top:0,left:"-25px",right:"-25px",bottom:"-16px"},children:e.jsx("div",{style:{position:"absolute",width:"100%",height:"100%",pointerEvents:"auto"},children:ae})}),!F&&!I&&e.jsx("div",{style:{backgroundColor:A.mode==="light"?"#fef3c7":`${A.colors.warning||"#f59e0b"}20`,border:`1px solid ${A.mode==="light"?"#fcd34d":A.colors.warning||"#f59e0b"}`,borderRadius:A.borderRadius.md,padding:A.spacing.md,marginBottom:A.spacing.md,textAlign:"center"},children:e.jsxs("p",{style:{color:A.mode==="light"?"#92400e":"#fbbf24",fontSize:A.typography.fontSize.sm,fontFamily:A.typography.fontFamily,margin:0,lineHeight:1.5},children:["You do not have any cross-chain balance."," ",l&&e.jsx("span",{onClick:l,style:{color:A.colors.primary,textDecoration:"underline",cursor:"pointer",fontWeight:600},children:"Top-up here."})]})}),e.jsx("div",{style:{marginBottom:A.spacing.sm},children:e.jsx(ht,{assets:v,selectedAsset:h||void 0,onAssetSelect:R,onAmountChange:q,loading:F,label:"Amount",showBalance:!0,showMaxButton:!0,theme:A,styles:i})}),O&&e.jsx("div",{style:{backgroundColor:i?.errorMessage?.backgroundColor||(A.mode==="light"?"#fef2f2":`${i?.statusDisplay?.errorColor||A.colors.error}20`),border:`1px solid ${i?.errorMessage?.borderColor||(A.mode==="light"?"#fecaca":i?.statusDisplay?.errorColor||A.colors.error)}`,borderRadius:i?.errorMessage?.borderRadius||A.borderRadius.md,padding:i?.errorMessage?.padding||A.spacing.md,marginBottom:A.spacing.sm},children:e.jsx("p",{style:{color:i?.errorMessage?.color||i?.statusDisplay?.errorColor||A.colors.error,fontSize:i?.errorMessage?.fontSize||A.typography.fontSize.sm,fontWeight:i?.errorMessage?.fontWeight,fontFamily:i?.errorMessage?.fontFamily||A.typography.fontFamily,margin:0},children:O})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:A.spacing.sm},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:pe,onMouseEnter:()=>z(!0),onMouseLeave:()=>{z(!1),U(!1)},onMouseDown:()=>U(!0),onMouseUp:()=>U(!1),loading:P,disabled:!N||!b,theme:A,styles:i,style:{width:"100%",padding:"8px",backgroundColor:N?E?"#d43d3d":M?"#f05555":"#ea4b4b":"#d1d5db",color:N?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:N?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:N?E?"scale(0.98)":M?"translateY(-2px)":"none":"none",boxShadow:E?"1px 1px 0px black":M&&N?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:k?p?b?P?"Executing Deposit...":h?h.amount?parseFloat(h.amount)>h.asset.balanceFormatted?"Insufficient Balance":t.length===0?"No Deposit Batches":"Execute Deposit":"Enter Amount":"Select Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})};var xs="data:image/svg+xml,%3csvg width='108' height='22' viewBox='0 0 108 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M1.9916 11.9854V11.2041H3.98379C4.48835 11.2041 4.87897 11.0739 5.15566 10.8135C5.43236 10.5498 5.5707 10.1868 5.5707 9.72461V9.71484C5.5707 9.24935 5.43236 8.88639 5.15566 8.62598C4.87897 8.36556 4.48835 8.23535 3.98379 8.23535H1.9916V7.4541H4.2084C4.65111 7.4541 5.04173 7.5485 5.38027 7.7373C5.71882 7.92611 5.98411 8.18978 6.17617 8.52832C6.37148 8.86686 6.46914 9.25911 6.46914 9.70508V9.71484C6.46914 10.1608 6.37148 10.5547 6.17617 10.8965C5.98411 11.2383 5.71882 11.5052 5.38027 11.6973C5.04173 11.8893 4.65111 11.9854 4.2084 11.9854H1.9916ZM1.55215 14.5V7.4541H2.43106V14.5H1.55215ZM9.51875 14.5928C9.0207 14.5928 8.58939 14.4837 8.2248 14.2656C7.86348 14.0443 7.58353 13.7301 7.38496 13.3232C7.18965 12.9163 7.09199 12.4329 7.09199 11.873V11.8633C7.09199 11.3001 7.18965 10.8151 7.38496 10.4082C7.58353 10.0013 7.86348 9.6888 8.2248 9.4707C8.58939 9.2526 9.0207 9.14355 9.51875 9.14355C10.0201 9.14355 10.4514 9.2526 10.8127 9.4707C11.174 9.6888 11.4523 10.0013 11.6477 10.4082C11.8462 10.8151 11.9455 11.3001 11.9455 11.8633V11.873C11.9455 12.4329 11.8462 12.9163 11.6477 13.3232C11.4523 13.7301 11.174 14.0443 10.8127 14.2656C10.4514 14.4837 10.0201 14.5928 9.51875 14.5928ZM9.51875 13.8408C9.85078 13.8408 10.1324 13.7627 10.3635 13.6064C10.5946 13.4502 10.7704 13.2256 10.8908 12.9326C11.0145 12.6396 11.0764 12.2865 11.0764 11.873V11.8633C11.0764 11.4466 11.0145 11.0918 10.8908 10.7988C10.7704 10.5059 10.5946 10.2829 10.3635 10.1299C10.1324 9.97363 9.85078 9.89551 9.51875 9.89551C9.18672 9.89551 8.90514 9.97363 8.67402 10.1299C8.4429 10.2829 8.26549 10.5059 8.1418 10.7988C8.02135 11.0918 7.96113 11.4466 7.96113 11.8633V11.873C7.96113 12.2865 8.02135 12.6396 8.1418 12.9326C8.26549 13.2256 8.4429 13.4502 8.67402 13.6064C8.90514 13.7627 9.18672 13.8408 9.51875 13.8408ZM13.7842 14.5L12.3096 9.23633H13.1592L14.1943 13.4453H14.2725L15.4492 9.23633H16.2549L17.4316 13.4453H17.5098L18.5449 9.23633H19.3896L17.915 14.5H17.0605L15.8838 10.4277H15.8057L14.6338 14.5H13.7842ZM22.1658 14.5928C21.6645 14.5928 21.2332 14.4821 20.8719 14.2607C20.5138 14.0394 20.2371 13.7269 20.0418 13.3232C19.8497 12.9163 19.7537 12.4378 19.7537 11.8877V11.8828C19.7537 11.3392 19.8497 10.8623 20.0418 10.4521C20.2371 10.042 20.5122 9.72135 20.867 9.49023C21.2218 9.25911 21.6368 9.14355 22.1121 9.14355C22.5906 9.14355 23.0008 9.25423 23.3426 9.47559C23.6876 9.69694 23.9513 10.0062 24.1336 10.4033C24.3191 10.7972 24.4119 11.2562 24.4119 11.7803V12.1123H20.1932V11.4336H23.9773L23.5574 12.0537V11.7168C23.5574 11.3034 23.4956 10.9632 23.3719 10.6963C23.2482 10.4294 23.0773 10.2308 22.8592 10.1006C22.6411 9.96712 22.3904 9.90039 22.1072 9.90039C21.824 9.90039 21.5701 9.97038 21.3455 10.1104C21.1242 10.2471 20.9484 10.4505 20.8182 10.7207C20.688 10.9909 20.6229 11.3229 20.6229 11.7168V12.0537C20.6229 12.4281 20.6863 12.7487 20.8133 13.0156C20.9402 13.2793 21.1209 13.4827 21.3553 13.626C21.5896 13.766 21.8663 13.8359 22.1854 13.8359C22.423 13.8359 22.6297 13.8034 22.8055 13.7383C22.9813 13.6732 23.1261 13.5902 23.24 13.4893C23.354 13.3883 23.4337 13.2858 23.4793 13.1816L23.4988 13.1377H24.3484L24.3387 13.1768C24.2931 13.3558 24.2117 13.5299 24.0945 13.6992C23.9806 13.8652 23.8325 14.0166 23.6502 14.1533C23.4679 14.2868 23.2514 14.3942 23.0008 14.4756C22.7534 14.5537 22.4751 14.5928 22.1658 14.5928ZM25.4303 14.5V9.23633H26.2799V10.0176H26.358C26.4589 9.74089 26.6298 9.52604 26.8707 9.37305C27.1116 9.22005 27.4094 9.14355 27.7643 9.14355C27.8456 9.14355 27.9254 9.14844 28.0035 9.1582C28.0849 9.16471 28.1467 9.17122 28.1891 9.17773V10.0029C28.1012 9.98665 28.0149 9.97526 27.9303 9.96875C27.8489 9.95898 27.761 9.9541 27.6666 9.9541C27.3964 9.9541 27.1572 10.0078 26.9488 10.1152C26.7405 10.2227 26.5761 10.3724 26.4557 10.5645C26.3385 10.7565 26.2799 10.9811 26.2799 11.2383V14.5H25.4303ZM30.9408 14.5928C30.4395 14.5928 30.0082 14.4821 29.6469 14.2607C29.2888 14.0394 29.0121 13.7269 28.8168 13.3232C28.6247 12.9163 28.5287 12.4378 28.5287 11.8877V11.8828C28.5287 11.3392 28.6247 10.8623 28.8168 10.4521C29.0121 10.042 29.2872 9.72135 29.642 9.49023C29.9968 9.25911 30.4118 9.14355 30.8871 9.14355C31.3656 9.14355 31.7758 9.25423 32.1176 9.47559C32.4626 9.69694 32.7263 10.0062 32.9086 10.4033C33.0941 10.7972 33.1869 11.2562 33.1869 11.7803V12.1123H28.9682V11.4336H32.7523L32.3324 12.0537V11.7168C32.3324 11.3034 32.2706 10.9632 32.1469 10.6963C32.0232 10.4294 31.8523 10.2308 31.6342 10.1006C31.4161 9.96712 31.1654 9.90039 30.8822 9.90039C30.599 9.90039 30.3451 9.97038 30.1205 10.1104C29.8992 10.2471 29.7234 10.4505 29.5932 10.7207C29.463 10.9909 29.3979 11.3229 29.3979 11.7168V12.0537C29.3979 12.4281 29.4613 12.7487 29.5883 13.0156C29.7152 13.2793 29.8959 13.4827 30.1303 13.626C30.3646 13.766 30.6413 13.8359 30.9604 13.8359C31.198 13.8359 31.4047 13.8034 31.5805 13.7383C31.7563 13.6732 31.9011 13.5902 32.015 13.4893C32.129 13.3883 32.2087 13.2858 32.2543 13.1816L32.2738 13.1377H33.1234L33.1137 13.1768C33.0681 13.3558 32.9867 13.5299 32.8695 13.6992C32.7556 13.8652 32.6075 14.0166 32.4252 14.1533C32.2429 14.2868 32.0264 14.3942 31.7758 14.4756C31.5284 14.5537 31.2501 14.5928 30.9408 14.5928ZM36.1486 14.5928C35.7059 14.5928 35.3186 14.4805 34.9865 14.2559C34.6545 14.0312 34.3973 13.7155 34.215 13.3086C34.0328 12.8984 33.9416 12.4199 33.9416 11.873V11.8633C33.9416 11.3132 34.0328 10.8346 34.215 10.4277C34.3973 10.0208 34.6529 9.70508 34.9816 9.48047C35.3137 9.25586 35.7027 9.14355 36.1486 9.14355C36.3895 9.14355 36.6158 9.18262 36.8273 9.26074C37.0422 9.33561 37.2326 9.44141 37.3986 9.57812C37.5647 9.71484 37.6949 9.8776 37.7893 10.0664H37.8674V7.14648H38.717V14.5H37.8674V13.6602H37.7893C37.6818 13.8555 37.5467 14.0231 37.384 14.1631C37.2212 14.2998 37.0357 14.4056 36.8273 14.4805C36.619 14.5553 36.3928 14.5928 36.1486 14.5928ZM36.3439 13.8408C36.663 13.8408 36.938 13.7611 37.1691 13.6016C37.4003 13.4421 37.5777 13.2158 37.7014 12.9229C37.8251 12.6266 37.8869 12.2767 37.8869 11.873V11.8633C37.8869 11.4564 37.8251 11.1064 37.7014 10.8135C37.5777 10.5205 37.4003 10.2943 37.1691 10.1348C36.938 9.97526 36.663 9.89551 36.3439 9.89551C36.0249 9.89551 35.7499 9.97526 35.5188 10.1348C35.2909 10.291 35.1151 10.5156 34.9914 10.8086C34.871 11.1016 34.8107 11.4531 34.8107 11.8633V11.873C34.8107 12.2799 34.871 12.6315 34.9914 12.9277C35.1151 13.2207 35.2909 13.4469 35.5188 13.6064C35.7499 13.7627 36.0249 13.8408 36.3439 13.8408ZM45.1775 14.5928C44.9334 14.5928 44.7072 14.5553 44.4988 14.4805C44.2905 14.4056 44.1049 14.2998 43.9422 14.1631C43.7794 14.0231 43.6443 13.8555 43.5369 13.6602H43.4588V14.5H42.6092V7.14648H43.4588V10.0664H43.5369C43.6346 9.8776 43.7648 9.71484 43.9275 9.57812C44.0936 9.44141 44.2824 9.33561 44.4939 9.26074C44.7088 9.18262 44.9367 9.14355 45.1775 9.14355C45.6235 9.14355 46.0109 9.25586 46.3396 9.48047C46.6717 9.70508 46.9288 10.0208 47.1111 10.4277C47.2934 10.8346 47.3846 11.3132 47.3846 11.8633V11.873C47.3846 12.4199 47.2934 12.8984 47.1111 13.3086C46.9288 13.7155 46.6717 14.0312 46.3396 14.2559C46.0109 14.4805 45.6235 14.5928 45.1775 14.5928ZM44.9822 13.8408C45.3045 13.8408 45.5796 13.7627 45.8074 13.6064C46.0353 13.4469 46.2094 13.2207 46.3299 12.9277C46.4536 12.6315 46.5154 12.2799 46.5154 11.873V11.8633C46.5154 11.4531 46.4536 11.1016 46.3299 10.8086C46.2094 10.5156 46.0353 10.291 45.8074 10.1348C45.5796 9.97526 45.3045 9.89551 44.9822 9.89551C44.6632 9.89551 44.3881 9.97526 44.157 10.1348C43.9259 10.2943 43.7485 10.5205 43.6248 10.8135C43.5011 11.1064 43.4393 11.4564 43.4393 11.8633V11.873C43.4393 12.2767 43.5011 12.6266 43.6248 12.9229C43.7485 13.2158 43.9259 13.4421 44.157 13.6016C44.3881 13.7611 44.6632 13.8408 44.9822 13.8408ZM48.6568 16.3457C48.6015 16.3457 48.5396 16.3424 48.4713 16.3359C48.4029 16.3327 48.3395 16.3262 48.2809 16.3164V15.6182C48.3329 15.6279 48.3899 15.6344 48.4518 15.6377C48.5136 15.641 48.5738 15.6426 48.6324 15.6426C48.8733 15.6426 49.0702 15.5807 49.2232 15.457C49.3795 15.3333 49.5048 15.1201 49.5992 14.8174L49.6969 14.5049L47.7486 9.23633H48.6568L50.2779 14.0996L49.941 13.5674H50.3414L50.0045 14.0996L51.6207 9.23633H52.5143L50.4586 14.8223C50.3154 15.2161 50.164 15.5238 50.0045 15.7451C49.845 15.9665 49.6578 16.1211 49.443 16.209C49.2314 16.3001 48.9693 16.3457 48.6568 16.3457Z' fill='%230E0D0B'/%3e%3cpath d='M62.7081 13.27C62.742 13.27 62.7642 13.3057 62.7491 13.3362V13.336L61.1229 16.6083C61.0892 16.6761 60.9926 16.6759 60.959 16.6083L59.3382 13.336C59.3232 13.3057 59.3453 13.27 59.3792 13.27H62.7081Z' fill='%23EA4B4B'/%3e%3cpath d='M61.0026 9.71913C61.0194 9.68524 61.0678 9.68524 61.0845 9.71913L62.747 13.0897C62.762 13.12 62.7399 13.1557 62.706 13.1557H59.3763C59.3424 13.1557 59.3203 13.12 59.3353 13.0897L61.0026 9.71913Z' fill='%23EA4B4B'/%3e%3cpath d='M60.8426 9.63827C60.8766 9.63827 60.8987 9.6741 60.8835 9.70444L59.2164 13.0594C59.1995 13.0932 59.1513 13.0932 59.1345 13.0594L57.5001 9.77047C57.47 9.70962 57.5142 9.63827 57.5821 9.63827H60.8426Z' fill='%23EA4B4B'/%3e%3cpath d='M64.5036 9.63617C64.5715 9.63618 64.6157 9.70753 64.5855 9.76838H64.5854L62.9512 13.0573C62.9344 13.0911 62.8862 13.0912 62.8692 13.0573L61.2021 9.70235C61.187 9.672 61.2091 9.63617 61.2431 9.63617H64.5036Z' fill='%23EA4B4B'/%3e%3cpath d='M62.8284 6.18281C62.862 6.11518 62.9586 6.11518 62.9922 6.18281L64.5855 9.38969C64.6157 9.45054 64.5715 9.52189 64.5036 9.52189H61.2431C61.2091 9.52189 61.187 9.48605 61.2021 9.45571L62.8283 6.18265L62.8284 6.18281Z' fill='%23EA4B4B'/%3e%3cpath d='M62.3131 6.13196C62.381 6.13196 62.4252 6.20331 62.3951 6.26416C62.154 6.74935 61.9128 7.23455 61.6718 7.71975H61.6716C61.4225 8.22125 61.1733 8.72259 60.9242 9.22409C60.9074 9.25799 60.859 9.25799 60.8422 9.22409L60.6305 8.79587C60.6275 8.78957 60.6259 8.78263 60.6259 8.77553V6.22349C60.6259 6.17297 60.6668 6.13196 60.7173 6.13196H62.3131Z' fill='%23EA4B4B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M74.8537 10.0096C75.2721 10.0096 75.654 10.1125 75.9993 10.3184C76.3513 10.5177 76.6303 10.8032 76.8361 11.1751C77.0487 11.547 77.1549 11.9953 77.1549 12.52V12.6495C77.1549 13.1675 77.052 13.6158 76.8461 13.9943C76.6402 14.3729 76.3613 14.6618 76.0093 14.861C75.664 15.0603 75.2788 15.1599 74.8537 15.1599C74.515 15.1599 74.2261 15.1134 73.9871 15.0204C73.7546 14.9341 73.5653 14.8212 73.4192 14.6817C73.2731 14.5423 73.1602 14.3995 73.0805 14.2534H72.941V16.9659L72.1541 16.0013V10.1491H72.9211V10.956H73.0352C73.2729 10.6733 73.3893 10.4911 73.6683 10.2985C73.9538 10.1059 74.349 10.0096 74.8537 10.0096ZM74.6445 10.7069C74.1464 10.7069 73.7347 10.8696 73.4092 11.195C73.0905 11.5138 72.9311 11.9621 72.9311 12.5399V12.6296C72.9311 13.2074 73.0905 13.659 73.4092 13.9844C73.7347 14.3032 74.1464 14.4626 74.6445 14.4626C75.1492 14.4626 75.5577 14.3032 75.8698 13.9844C76.1886 13.659 76.348 13.2074 76.348 12.6296V12.5399C76.348 11.9621 76.1886 11.5138 75.8698 11.195C75.5577 10.8696 75.1492 10.7069 74.6445 10.7069Z' fill='%230E0D0B'/%3e%3cpath d='M78.5848 11.9583L78.5555 15.4596L77.7681 14.4846V10.9583L78.5848 11.9583Z' fill='%230E0D0B'/%3e%3cpath d='M101.588 10.2986H102.444L103 10.986H101.588V10.9867H100.802L101.588 11.9623V14.1937C101.588 14.3929 101.685 14.4926 101.877 14.4926H102.379L102.928 15.17H101.668C101.389 15.17 101.173 15.0936 101.021 14.9409C100.874 14.7881 100.801 14.5789 100.801 14.3133V10.986H99.8799L99.3217 10.2986H100.801V9.13501H101.588V10.2986Z' fill='%230E0D0B'/%3e%3cpath d='M69.0133 7.90764C69.4848 7.90764 69.9065 7.99068 70.2784 8.15671C70.6569 8.3161 70.9525 8.55517 71.165 8.87395C71.3842 9.18609 71.4938 9.58126 71.4938 10.0594V10.4778H70.667V10.0594C70.667 9.72072 70.5939 9.44842 70.4477 9.24254C70.3083 9.03666 70.1124 8.88392 69.86 8.7843C69.6143 8.68469 69.332 8.63487 69.0133 8.63487C68.555 8.63487 68.1864 8.7378 67.9075 8.94367C67.6286 9.14291 67.4891 9.4285 67.4891 9.80041C67.4891 10.0461 67.5488 10.2453 67.6684 10.3981C67.7879 10.5508 67.9573 10.677 68.1764 10.7767C68.3956 10.8696 68.658 10.9527 68.9635 11.0257L69.4815 11.1552C69.8866 11.2416 70.2485 11.3611 70.5673 11.5138C70.8927 11.6599 71.1517 11.8625 71.3443 12.1215C71.5369 12.3739 71.6332 12.706 71.6332 13.1177C71.6332 13.5295 71.5303 13.8881 71.3244 14.1936C71.1185 14.4991 70.8263 14.7382 70.4477 14.9109C70.0758 15.0769 69.6375 15.1599 69.1328 15.1599C68.6281 15.1599 68.1765 15.0702 67.778 14.8909C67.3795 14.7116 67.0641 14.4426 66.8316 14.084C66.6058 13.7187 66.4929 13.2638 66.4929 12.7192V12.51H67.3197V12.7192C67.3197 13.297 67.4891 13.7287 67.8278 14.0143C68.1665 14.2932 68.6015 14.4327 69.1328 14.4327C69.6774 14.4327 70.0924 14.3098 70.378 14.0641C70.6636 13.8183 70.8064 13.5095 70.8064 13.1376C70.8064 12.8786 70.74 12.6727 70.6072 12.52C70.481 12.3673 70.3017 12.2444 70.0692 12.1514C69.8368 12.0518 69.5645 11.9655 69.2523 11.8924L68.7343 11.7629C68.3292 11.6566 67.9706 11.5271 67.6584 11.3744C67.3463 11.2216 67.1006 11.0224 66.9213 10.7767C66.7486 10.5243 66.6623 10.2022 66.6623 9.81035C66.6623 9.41852 66.7585 9.07981 66.9511 8.79424C67.1504 8.50866 67.426 8.28953 67.778 8.13678C68.1366 7.98404 68.5484 7.90764 69.0133 7.90764Z' fill='%230E0D0B'/%3e%3cpath d='M81.6544 10.0096C82.1193 10.0096 82.5145 10.0959 82.8399 10.2686C83.1719 10.4412 83.431 10.6704 83.6169 10.956C83.8095 11.2415 83.9324 11.5471 83.9855 11.8725L83.2185 12.0318C83.1853 11.7928 83.1056 11.5736 82.9794 11.3744C82.8598 11.1752 82.6905 11.0158 82.4713 10.8962C82.2521 10.7767 81.9832 10.7169 81.6644 10.7169C81.339 10.7169 81.0468 10.7899 80.7877 10.936C80.5354 11.0821 80.3328 11.2914 80.1801 11.5637C80.034 11.836 79.9609 12.1614 79.9609 12.5399V12.6296C79.9609 13.0081 80.034 13.3335 80.1801 13.6058C80.3328 13.8781 80.5354 14.0873 80.7877 14.2334C81.0468 14.3795 81.339 14.4526 81.6644 14.4526C82.1492 14.4526 82.5178 14.3264 82.7702 14.0741C83.0292 13.8217 83.1886 13.5095 83.2483 13.1376L84.0254 13.307C83.9523 13.6257 83.8195 13.9279 83.6269 14.2135C83.4343 14.4991 83.172 14.7282 82.8399 14.9009C82.5145 15.0735 82.1193 15.1599 81.6544 15.1599C81.1829 15.1599 80.7579 15.0603 80.3793 14.861C80.0074 14.6551 79.7119 14.363 79.4927 13.9844C79.2802 13.6059 79.1739 13.1575 79.1739 12.6395V12.5299C79.1739 12.0053 79.2802 11.557 79.4927 11.1851C79.7119 10.8066 80.0074 10.5177 80.3793 10.3184C80.7579 10.1126 81.1829 10.0096 81.6544 10.0096Z' fill='%230E0D0B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M86.7515 10.0096C87.2097 10.0096 87.6149 10.1092 87.9668 10.3084C88.3188 10.501 88.5944 10.78 88.7937 11.1452C88.9929 11.5105 89.0925 11.9389 89.0925 12.4304V12.7889H85.1177C85.1377 13.3136 85.3071 13.7254 85.6258 14.0243C85.9446 14.3165 86.3431 14.4626 86.8212 14.4626C87.2396 14.4626 87.5617 14.3663 87.7875 14.1737C88.0133 13.9811 88.186 13.752 88.3056 13.4863L88.983 13.815C88.8833 14.0209 88.7439 14.2268 88.5646 14.4327C88.3919 14.6386 88.1628 14.8113 87.8772 14.9507C87.5983 15.0902 87.2396 15.1599 86.8013 15.1599C86.3099 15.1599 85.8782 15.057 85.5063 14.8511C85.1344 14.6386 84.8455 14.343 84.6396 13.9645C84.4337 13.5859 84.3307 13.1476 84.3307 12.6495V12.5299C84.3307 12.0252 84.4337 11.5836 84.6396 11.205C84.8455 10.8265 85.1311 10.5342 85.4963 10.3284C85.8616 10.1159 86.28 10.0096 86.7515 10.0096ZM86.7515 10.7069C86.3066 10.7069 85.9413 10.8331 85.6557 11.0855C85.3701 11.3378 85.1941 11.6898 85.1277 12.1414H88.2956C88.269 11.6898 88.113 11.3378 87.8274 11.0855C87.5485 10.8331 87.1898 10.7069 86.7515 10.7069Z' fill='%230E0D0B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M97.1624 10.0096C97.6207 10.0096 98.0258 10.1092 98.3778 10.3084C98.7298 10.501 99.0054 10.78 99.2046 11.1452C99.4039 11.5105 99.5035 11.9389 99.5035 12.4304V12.7889H95.5287C95.5487 13.3136 95.718 13.7254 96.0368 14.0243C96.3555 14.3165 96.754 14.4626 97.2322 14.4626C97.6505 14.4626 97.9727 14.3663 98.1985 14.1737C98.4243 13.9811 98.5969 13.752 98.7165 13.4863L99.3939 13.815C99.2943 14.0209 99.1548 14.2268 98.9755 14.4327C98.8028 14.6386 98.5737 14.8113 98.2881 14.9507C98.0092 15.0902 97.6506 15.1599 97.2123 15.1599C96.7208 15.1599 96.2892 15.057 95.9172 14.8511C95.5453 14.6386 95.2564 14.343 95.0505 13.9645C94.8446 13.5859 94.7417 13.1476 94.7417 12.6495V12.5299C94.7417 12.0252 94.8446 11.5836 95.0505 11.205C95.2564 10.8265 95.542 10.5342 95.9073 10.3284C96.2725 10.1158 96.6909 10.0096 97.1624 10.0096ZM97.1624 10.7069C96.7175 10.7069 96.3522 10.8331 96.0666 11.0855C95.7811 11.3378 95.6051 11.6898 95.5387 12.1414H98.7066C98.68 11.6898 98.5239 11.3378 98.2383 11.0855C97.9594 10.8331 97.6008 10.7069 97.1624 10.7069Z' fill='%230E0D0B'/%3e%3cpath d='M92.2484 10.0594C92.6137 10.0594 92.9391 10.1358 93.2247 10.2885C93.5169 10.4413 93.7494 10.6671 93.9221 10.966C94.0947 11.2648 94.1811 11.6334 94.1811 12.0717V15.1458H93.394V12.1315C93.394 11.6467 93.2712 11.2947 93.0255 11.0755C92.7864 10.8564 92.461 10.7468 92.0492 10.7468C91.5777 10.7468 91.1925 10.8995 90.8936 11.205C90.6014 11.5105 90.4553 11.9655 90.4553 12.5698V15.1458H89.6683V10.1491H90.4354V10.9582H90.5361C90.7355 10.7018 90.8604 10.5342 91.1128 10.3483C91.3718 10.1557 91.7503 10.0594 92.2484 10.0594Z' fill='%230E0D0B'/%3e%3cpath d='M78.5932 10.9581H77.7681V10.1514H78.6L78.5932 10.9581Z' fill='%230E0D0B'/%3e%3c/svg%3e";const xt=({isOpen:t,onClose:o,title:r,subtitle:n,children:s,overlayContent:c,styles:i,theme:d,maxWidth:g="522px"})=>{const f=d||de.createTheme("light");return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{border:"6px solid #E9E9E9",backgroundColor:"white",borderRadius:"12px",width:"100%",padding:"0",display:"flex",flexDirection:"column",maxWidth:g,position:"relative",overflow:"hidden"},children:[c&&e.jsx("div",{style:{position:"absolute",inset:0,backgroundColor:"rgba(0, 0, 0, 0.4)",zIndex:5,pointerEvents:"none",borderRadius:"12px"}}),e.jsxs("div",{style:{padding:"24px 24px 16px 24px",borderBottom:"1px solid #cdcfd1",position:"relative"},children:[e.jsx("button",{onClick:o,style:{position:"absolute",top:"16px",right:"16px",color:"#111827",padding:"8px",backgroundColor:"transparent",borderRadius:"50%",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",transition:"background-color 0.2s",fontSize:"20px",fontWeight:"600"},onMouseEnter:u=>{u.currentTarget.style.backgroundColor="#f3f4f6"},onMouseLeave:u=>{u.currentTarget.style.backgroundColor="transparent"},children:e.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})}),e.jsx("h2",{style:{fontSize:"23px",fontWeight:"600",color:"#111827",margin:"0",fontFamily:i?.fontFamily||f.typography.fontFamily||"system-ui, -apple-system, sans-serif"},children:r})]}),n&&e.jsx("div",{style:{padding:"16px 24px 0px 24px",fontSize:"12px",color:"#6b7280",margin:"0 0 2rem 0",lineHeight:"1.4",fontFamily:i?.fontFamily||f.typography.fontFamily||"system-ui, -apple-system, sans-serif"},children:n}),s,e.jsxs("div",{style:{padding:"0px 28px 8px 28px",margin:0,marginTop:"10px",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("img",{src:xs,alt:"Powered by SpiceNet",style:{height:"auto",width:"auto",opacity:1,margin:0,display:"block"}}),e.jsxs("a",{href:"https://spicenet.io/accounts",target:"_blank",rel:"noopener noreferrer",style:{fontSize:"10px",color:"#51514f",textDecoration:"none",display:"flex",alignItems:"center",gap:"4px",fontFamily:i?.fontFamily||f.typography.fontFamily,lineHeight:"1"},children:[e.jsx("span",{children:"Learn more about"}),e.jsx("span",{style:{color:i?.primaryColor||f.colors.primary,textDecoration:"underline",fontWeight:"500"},children:"Spicenet accounts \u2192"})]})]}),c]})}):null};var Pt="data:image/svg+xml,%3csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M7.5 7.49993V10.4999M7.5 4.96868V4.96784M14.25 7.5C14.25 11.2279 11.2279 14.25 7.5 14.25C3.77208 14.25 0.75 11.2279 0.75 7.5C0.75 3.77208 3.77208 0.75 7.5 0.75C11.2279 0.75 14.25 3.77208 14.25 7.5Z' stroke='%23ED6969' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3e%3c/svg%3e";const wo=({isOpen:t,onClose:o,title:r="Deposit",maxWidth:n="480px",depositBatches:s,tokenAddress:c,tokenDecimals:i,supportedChains:d,supportedTokens:g,theme:f="light",styles:u,className:l,depositInputHook:C,onDepositSuccess:A,onDepositError:w})=>{const k=de.createTheme(f),p=b=>{A?.(b)};return e.jsx(xt,{isOpen:t,onClose:o,title:r,subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:"Use your cross-chain balance to deposit WBTC to earn 6.3% yield, all in one click."})]}),styles:u,theme:k,maxWidth:n,children:e.jsx("div",{style:{padding:"0 24px 24px 24px"},children:e.jsx(gs,{depositBatches:s,tokenAddress:c,tokenDecimals:i,supportedChains:d,supportedTokens:g,theme:f,styles:{...u,container:{...u?.container,boxShadow:"none",borderColor:"transparent",padding:"0",backgroundColor:"transparent"}},className:l,depositInputHook:C,onDepositSuccess:p,onDepositError:w})})})},So=({asset:t,amount:o,onAmountChange:r,onPercentageClick:n,usdValue:s,disabled:c,styles:i,theme:d})=>{const g=t.balanceFormatted??0,f=parseFloat(o)||0,u=g>0?f/g*100:0,[l,C]=a.useState(null),[A,w]=a.useState(null),k=p=>{const b=p.target.value;(b===""||/^\d*\.?\d*$/.test(b))&&r(b)};return e.jsx("div",{style:{backgroundColor:"#e9e9e9",border:"0.5px solid #A8A8A7",borderRadius:"6px",padding:"16px",height:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsx("div",{style:{display:"flex",flexDirection:"column",justifyContent:"space-between",height:"100%"},children:e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsx("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:"Amount"}),e.jsx("input",{type:"text",value:o,onChange:k,placeholder:"0.00",disabled:c,style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"40px",fontWeight:700,color:c?"rgba(14, 13, 11, 0.16)":o?"#0e0d0b":"#d1d5db",lineHeight:"1.08",letterSpacing:"-1.2px",backgroundColor:"transparent",border:"none",outline:"none",padding:0,width:"100%",maxWidth:"200px"}})]})}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",justifyContent:"space-between",height:"100%",gap:"12px"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",alignItems:"flex-end"},children:[e.jsxs("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:["Balance: ",g.toFixed(4)]}),e.jsx("div",{style:{width:"128px"},children:e.jsxs("div",{style:{border:"1px solid #CDCFD1",borderRadius:"6px 6px 6px 6px",backgroundColor:"transparent",padding:"8px 12px 8px 8px",display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx(ot,{symbol:t.symbol,logoURI:t.logoURI,size:30,theme:d}),e.jsx("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.symbol})]})})]}),e.jsx("div",{style:{display:"flex",gap:"10px",height:"14px",alignItems:"center",justifyContent:"flex-end"},children:[0,25,50,75,100].map((p,b)=>{const m=Math.abs(u-p)<1,j=b===4,y=p/100,h=l===p,x=A===p;return e.jsx("button",{onClick:()=>n(p),onMouseEnter:()=>C(p),onMouseLeave:()=>{C(null),w(null)},onMouseDown:()=>w(p),onMouseUp:()=>w(null),disabled:c,title:`${p}%`,style:{width:"14px",height:"14px",padding:0,border:"none",backgroundColor:"transparent",cursor:c?"not-allowed":"pointer",opacity:m?1:h?.8:.5,transform:x?"scale(0.85)":h?"scale(1.15)":"scale(1)",transition:"all 0.15s ease"},children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:j?"#ea4b4b":"none",stroke:j?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!j&&y>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${y>.5?1:0} 1 ${7+6.84375*Math.sin(y*2*Math.PI)} ${7-6.84375*Math.cos(y*2*Math.PI)} Z`,fill:"#3C3E42"})]})},p)})})]})]})})};var ko="data:image/svg+xml,%3csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M5.83337 11.0833C8.73287 11.0833 11.0834 8.73275 11.0834 5.83325C11.0834 2.93376 8.73287 0.583252 5.83337 0.583252C2.93388 0.583252 0.583374 2.93376 0.583374 5.83325C0.583374 8.73275 2.93388 11.0833 5.83337 11.0833Z' stroke='%23757171' stroke-width='1.16667' stroke-linecap='round' stroke-linejoin='round'/%3e%3cpath d='M4.84329 4.48988C5.18981 4.14336 5.36306 3.97011 5.56285 3.90519C5.73859 3.84809 5.92789 3.84809 6.10363 3.90519C6.30342 3.97011 6.47668 4.14336 6.82319 4.48988L7.17663 4.84331C7.52314 5.18983 7.6964 5.36308 7.76131 5.56287C7.81841 5.73861 7.81841 5.92791 7.76131 6.10365C7.6964 6.30344 7.52314 6.4767 7.17663 6.82321L6.82319 7.17665C6.47668 7.52316 6.30342 7.69642 6.10363 7.76133C5.92789 7.81843 5.73859 7.81843 5.56285 7.76133C5.36306 7.69642 5.18981 7.52316 4.84329 7.17665L4.48986 6.82321C4.14334 6.4767 3.97009 6.30344 3.90517 6.10365C3.84807 5.92791 3.84807 5.73861 3.90517 5.56287C3.97009 5.36308 4.14334 5.18983 4.48986 4.84331L4.84329 4.48988Z' stroke='%23757171' stroke-width='1.16667' stroke-linecap='round' stroke-linejoin='round'/%3e%3c/svg%3e";const Io=({isOpen:t,onClose:o,onComplete:r,title:n="Deposit to Spicenet",description:s="Select tokens and enter amounts to deposit to your Spicenet Account",chainId:c,embeddedWalletAddress:i,externalWalletAddress:d,escrowAddress:g="0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",getChainConfig:f,getSupportedTokens:u})=>{const l=de.createTheme("light"),[C,A]=a.useState(new Map),[w,k]=a.useState(!1),[p,b]=a.useState(null),[m,j]=a.useState([]),[y,h]=a.useState(!1),[x,S]=a.useState(null),[F,B]=a.useState(null),[I,G]=a.useState(!1),[P,_]=a.useState(!1),{chain:$}=Ae.useAccount(),{data:J,isLoading:M}=Ae.useWalletClient(),{switchChainAsync:z}=Ae.useSwitchChain(),E=a.useMemo(()=>u(c),[c,u]),{data:U}=Ae.useReadContracts({contracts:E.map(v=>({address:v.address,abi:re.erc20Abi,functionName:"balanceOf",args:[d],chainId:c}))}),X=a.useMemo(()=>{if(!f(c))return[];const v=[];return E.forEach((N,O)=>{const se=U?.[O],ae=se?.status==="success"?se.result:BigInt(0),Z=Number(ae)/Math.pow(10,N.decimals);v.push({address:N.address,symbol:N.symbol,name:N.name,decimals:N.decimals,isNative:!1,chainId:c,balance:ae,balanceFormatted:Z})}),v},[c,U,E,f]);a.useEffect(()=>{if(X.length>0&&C.size>0){const v=new Map(C);let N=!1;C.forEach((O,se)=>{const ae=X.find(Z=>Z.address===se);ae&&ae.balanceFormatted!==O.asset.balanceFormatted&&(v.set(se,{...O,asset:ae}),N=!0)}),N&&A(v)}},[X,C]);const ee=f(c),H=v=>{const N=new Map(C);N.has(v.address)?N.delete(v.address):N.set(v.address,{asset:v,amount:""}),A(N),b(null)},ne=(v,N)=>{if(N===""||/^\d*\.?\d*$/.test(N)){const O=new Map(C),se=O.get(v);se&&(O.set(v,{...se,amount:N}),A(O),b(null))}},xe=(v,N)=>{const O=C.get(v);if(O?.asset.balanceFormatted!==void 0){const se=O.asset.balanceFormatted*N/100;ne(v,se.toString())}},ue=a.useCallback(async()=>{if(C.size===0){b("Please select at least one asset");return}for(const[N,O]of Array.from(C.entries())){if(!O.amount){b(`Please enter an amount for ${O.asset.symbol}`);return}const se=parseFloat(O.amount);if(isNaN(se)||se<=0){b(`Please enter a valid amount for ${O.asset.symbol}`);return}const ae=X.find(Z=>Z.address===N)?.balanceFormatted??O.asset.balanceFormatted;if(ae!==void 0&&se>ae){b(`Insufficient ${O.asset.symbol} balance`);return}}if(!J){b("Wallet not connected. Please reconnect your external wallet.");return}k(!0),b(null);const v=[];try{$?.id!==c&&await z({chainId:c});for(const[,N]of Array.from(C.entries())){const{asset:O,amount:se}=N;try{const ae=re.parseUnits(se,O.decimals);let Z;if(O.isNative)Z=await J.sendTransaction({to:g,value:ae});else{const T=re.encodeFunctionData({abi:re.erc20Abi,functionName:"transfer",args:[g,ae]});Z=await J.sendTransaction({to:O.address,data:T})}const he=Ve(c),Ce=await he.waitForTransactionReceipt({hash:Z,timeout:12e4,pollingInterval:2e3,confirmations:2});if(Ce.status!=="success")throw new Error(`Transfer to escrow failed for ${O.symbol}`);await he.getBlockNumber()-Ce.blockNumber<2&&await new Promise(T=>setTimeout(T,3e3)),await we.submitSpiceDeposit({txHash:Z,sender:i,tokenAddress:O.address,chainId:c,amount:re.parseUnits(se,O.decimals).toString(),user:i,isDeposit:!0}),v.push({asset:O,txHash:Z,success:!0})}catch(ae){const Z=ae;let he=Z?.message||"Deposit failed";Z?.code===4001||Z?.message?.includes("rejected")?he="Transaction rejected by user":Z?.message?.includes("insufficient funds")&&(he="Insufficient funds for transaction"),v.push({asset:O,txHash:"",success:!1,error:he})}}j(v),h(!0)}catch(N){b(N?.message||"Deposit failed")}finally{k(!1)}},[C,J,$,c,z,g,X]);a.useEffect(()=>{t||(A(new Map),b(null),j([]),h(!1),k(!1))},[t]);const Ee=a.useCallback(()=>{j([]),h(!1),b(null)},[]),R=C.size>0&&Array.from(C.values()).every(v=>v.amount&&parseFloat(v.amount)>0)&&!w&&!y&&J,q=e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:s})]}),pe=w||y&&m.length>0?e.jsx(qt,{type:"deposit",isOpen:y&&m.length>0,isProcessing:w,onClose:o,onComplete:r,onRetryTx:Ee,onNewTx:()=>{},results:m.length>0?m.map(v=>({asset:{symbol:v.asset.symbol,address:v.asset.address},txHash:v.txHash,success:v.success,error:v.error})):void 0,chainName:st(c),explorerUrl:ee?.blockExplorers?.default?.url,theme:l}):null;return e.jsx(xt,{isOpen:t,onClose:o,title:n,subtitle:q,theme:l,maxWidth:"480px",children:e.jsxs("div",{style:{padding:"0 24px 32px 24px",position:"relative"},children:[pe&&e.jsx("div",{style:{position:"absolute",inset:0,overflow:"hidden",pointerEvents:"none"},children:e.jsx("div",{style:{position:"relative",width:"100%",height:"100%",pointerEvents:"auto"},children:pe})}),e.jsxs("div",{style:{marginBottom:"16px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:"10px"},children:[e.jsx("span",{style:{fontSize:"14px",color:"#6b7280"},children:e.jsx("img",{src:ko,alt:"Info",style:{width:"10.5px",height:"10.5px",top:"1.75px",left:"1.75px",flexShrink:0}})}),e.jsx("label",{style:{fontSize:"12px",fontWeight:590,color:"#374151"},children:"Select Assets to Deposit"})]}),e.jsx("div",{style:{display:"flex",gap:"12px",flexWrap:"wrap"},children:X.map(v=>{const N=C.has(v.address);return e.jsx("button",{onClick:()=>H(v),onMouseEnter:()=>S(v.address),onMouseLeave:()=>{S(null),B(null)},onMouseDown:()=>B(v.address),onMouseUp:()=>B(null),style:{padding:"4px 8px 4px 8px",borderRadius:"8px",border:`1px solid ${N?"#EA4B4B7A":x===v.address?"#F4A5A5":"#e5e7eb"}`,backgroundColor:N?"#FEF2F2":F===v.address?"#f5f5f5":x===v.address?"#fafafa":"white",cursor:"pointer",display:"flex",alignItems:"center",gap:"8px",transition:"all 150ms ease",transform:F===v.address?"scale(0.96)":x===v.address?"translateY(-1px)":"none",boxShadow:N?"0 0 0 3px #FBDBDB":F===v.address?"0 1px 2px rgba(0, 0, 0, 0.05)":x===v.address?"0 4px 8px rgba(0, 0, 0, 0.1)":"none"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx(ot,{symbol:v.symbol,size:24,theme:l}),e.jsx("span",{style:{fontSize:"16px",fontWeight:510,color:"#3C3E42"},children:v.symbol}),v.balanceFormatted!==void 0&&e.jsxs("span",{style:{fontSize:"10px",fontWeight:500,color:"#939291",fontFamily:'"IBM Plex Mono", monospace'},children:["(",v.balanceFormatted.toFixed(4),")"]})]})},v.address)})})]}),C.size>0&&e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"16px"},children:Array.from(C.values()).map(({asset:v,amount:N})=>e.jsx(So,{asset:v,amount:N,onAmountChange:O=>ne(v.address,O),onPercentageClick:O=>xe(v.address,O),theme:l,disabled:w},v.address))}),p&&e.jsx("div",{style:{padding:"12px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"8px",marginTop:"16px"},children:e.jsx("p",{style:{fontSize:"14px",color:"#dc2626",margin:0},children:p})}),!y&&e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ue,onMouseEnter:()=>G(!0),onMouseLeave:()=>{G(!1),_(!1)},onMouseDown:()=>_(!0),onMouseUp:()=>_(!1),disabled:!R,theme:l,style:{width:"100%",padding:"8px ",backgroundColor:R?P?"#d43d3d":I?"#f05555":"#ea4b4b":"#d1d5db",color:R?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:R?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:R?P?"scale(0.98)":I?"translateY(-2px)":"none":"none",boxShadow:P?"1px 1px 0px black":I&&R?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:w?e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"18px",height:"18px",border:"2px solid white",borderTopColor:"transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsx("span",{children:"PROCESSING..."})]}):M?"CONNECTING WALLET...":J?C.size===0?"SELECT ASSETS":Array.from(C.values()).every(v=>v.amount)?"DEPOSIT":"ENTER AMOUNTS":"WALLET NOT CONNECTED"}),e.jsx("style",{children:`
|
|
38
|
+
`})]})},gs=({depositBatches:t,tokenAddress:o,tokenDecimals:r,supportedChains:n,supportedTokens:s,theme:c="light",styles:i,className:d="",depositInputHook:g,onDepositSuccess:f,onDepositError:u,onTopUp:l})=>{const C=de.createTheme(c),A={...C,typography:{...C.typography,fontFamily:i?.fontFamily||C.typography.fontFamily},colors:{...C.colors,primary:i?.primaryColor||C.colors.primary,primaryHover:i?.primaryColor?`${i.primaryColor}dd`:C.colors.primaryHover}},w=Lt(),{isReady:k,isAuthenticated:p,isConnected:b,address:m,provider:j,actions:y}=w,[h,x]=a.useState(null),{assets:S,loading:F,error:B,hasBalance:I,refetch:G}=us({address:m,supportedChains:n,enabled:b,refetchInterval:3e4}),[P,_]=a.useState(!1),[$,J]=a.useState(null),[M,z]=a.useState(!1),[E,H]=a.useState(!1),[X,ee]=a.useState(!1),U=a.useRef(null),{intentStatus:ne,startStatusPolling:xe,clearStatus:ue}=kt({checkStepStatus:(Z,he)=>we.checkStepStatus(Z,he)});a.useEffect(()=>{if(ne?.overallStatus==="success"&&ne.intentId&&U.current!==ne.intentId&&h&&m){const Z=ne.steps.find(he=>he.transactionHash);if(Z?.transactionHash){U.current=ne.intentId;const he=re.parseUnits(h.amount,h.asset.decimals);we.submitSpiceDeposit({user:m,txHash:Z.transactionHash,sender:m,tokenAddress:h.asset.address,chainId:h.asset.chainId,amount:he.toString(),isDeposit:!1}).then(()=>{G()}).catch(()=>{U.current=null})}}},[ne,m]),a.useEffect(()=>{g&&g.assetAmount!==h?.amount&&h&&x({...h,amount:g.assetAmount})},[g?.assetAmount,h]);const Ee=a.useCallback(()=>{J(null)},[]),R=Z=>{x({asset:Z,amount:h?.amount||""}),Ee()},q=a.useCallback(Z=>{h&&(a.startTransition(()=>{x({...h,amount:Z}),Ee()}),g&&g.setAssetAmount(Z))},[h,g,Ee]),pe=async()=>{if(!(!h||!m||t.length===0)){if(!k||!p){J(`Please authenticate with ${j||"wallet provider"} to continue`);return}_(!0),J(null),ee(!0);try{const Z=[...t],he=[...new Set(Z.map(ce=>ce.chainId))],Ce=[];for(const ce of he){const ze=Ve(ce),W=pt(ce),K=await Ye.getAccountNonce(m,ze),ie=await y.signAuthorization({contractAddress:W,chainId:ce,nonce:Number(K)});Ce.push(ie)}const T=Ye.hashChainBatches(Z),oe=Math.floor(Date.now()/1e3)+60*10,le=Ye.getIntentHash(0n,BigInt(oe),T),Se=await y.signMessage({raw:le}),ve=typeof Se=="string"?Se:Se.signature;if(!ve)throw new Error("Failed to sign intent authorization");const ke={mode:"7702",signatureType:"ecdsa",signature:ve,nbf:0,exp:oe,chainBatches:T.map(ce=>({hash:ce.hash,chainId:ce.chainId,tokenTransfers:[{from:"solver",to:m,token:"0x0000000000000000000000000000000000000000",amount:re.parseUnits("0.01",18)},{from:"solver",to:m,token:o,amount:re.parseUnits(h.amount,r)}],calls:ce.calls}))},Ie=await we.createAction({user:m,chainAuthorizations:Ce.map(ce=>({...ce,r:ce.r,s:ce.s,yParity:ce.yParity,address:ce.address,chainId:Number(ce.chainId),nonce:Number(ce.nonce)})),intents:[ke]});if(Ie){const ce=Et(Z,ie=>`Chain ${ie}`),[ze,W]=Ie.intentIds[0].split("/"),K=parseInt(W||"0",10);xe(Ie.intentIds[0],ce);for(let ie=0;ie<Z.length;ie++)await we.executeStep(ze,K,ie,{action:"execute"})}}catch(Z){const he=Z instanceof Error?Z.message:"Deposit failed";J(he),u?.(he)}finally{_(!1)}}},v=a.useMemo(()=>s&&s.length>0?S.filter(Z=>s.some(he=>he.toLowerCase()===Z.symbol.toLowerCase())):S,[S,s]),N=h&&h.amount&&parseFloat(h.amount)>0&&parseFloat(h.amount)<=h.asset.balanceFormatted&&b&&!P&&t.length>0,O=B||$,se={backgroundColor:i?.container?.backgroundColor||i?.primaryBackground||A.colors.background,border:`1px solid ${i?.container?.borderColor||A.colors.border}`,borderRadius:i?.container?.borderRadius||A.borderRadius.lg,padding:i?.container?.padding||A.spacing.md,width:i?.container?.width||"100%",maxWidth:"28rem",minHeight:"200px",margin:"0 auto",color:A.colors.text,fontFamily:A.typography.fontFamily,boxShadow:i?.container?.boxShadow||(A.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")},ae=ne?e.jsx(qt,{type:"deposit",isOpen:!!ne&&ne.overallStatus!=="processing",isProcessing:P||ne?.overallStatus==="processing",onRetryTx:()=>{ue(),ee(!1),pe()},onNewTx:()=>{ue(),ee(!1),x(null),U.current=null,G()},onClose:()=>{ue(),ee(!1)},onComplete:()=>{ue(),ee(!1),x(null),U.current=null,G()},results:ne?.overallStatus==="success"||ne?.overallStatus==="failed"?ne.steps.map(Z=>({asset:{symbol:h?.asset.symbol||"Token",address:h?.asset.address||""},txHash:Z.transactionHash||"",success:Z.status==="success",amount:h?.amount})):void 0,chainName:h?st(t[t.length-1].chainId):"Network",explorerUrl:h?Wt(t[t.length-1].chainId,"").replace(/\/tx\/.*$/,""):void 0,theme:A}):null;return e.jsxs("div",{style:{...se,position:"relative"},className:d,children:[ae&&e.jsx("div",{style:{position:"absolute",top:0,left:"-25px",right:"-25px",bottom:"-16px"},children:e.jsx("div",{style:{position:"absolute",width:"100%",height:"100%",pointerEvents:"auto"},children:ae})}),!F&&!I&&e.jsx("div",{style:{backgroundColor:A.mode==="light"?"#fef3c7":`${A.colors.warning||"#f59e0b"}20`,border:`1px solid ${A.mode==="light"?"#fcd34d":A.colors.warning||"#f59e0b"}`,borderRadius:A.borderRadius.md,padding:A.spacing.md,marginBottom:A.spacing.md,textAlign:"center"},children:e.jsxs("p",{style:{color:A.mode==="light"?"#92400e":"#fbbf24",fontSize:A.typography.fontSize.sm,fontFamily:A.typography.fontFamily,margin:0,lineHeight:1.5},children:["You do not have any cross-chain balance."," ",l&&e.jsx("span",{onClick:l,style:{color:A.colors.primary,textDecoration:"underline",cursor:"pointer",fontWeight:600},children:"Top-up here."})]})}),e.jsx("div",{style:{marginBottom:A.spacing.sm},children:e.jsx(ht,{assets:v,selectedAsset:h||void 0,onAssetSelect:R,onAmountChange:q,loading:F,label:"Amount",showBalance:!0,showMaxButton:!0,theme:A,styles:i})}),O&&e.jsx("div",{style:{backgroundColor:i?.errorMessage?.backgroundColor||(A.mode==="light"?"#fef2f2":`${i?.statusDisplay?.errorColor||A.colors.error}20`),border:`1px solid ${i?.errorMessage?.borderColor||(A.mode==="light"?"#fecaca":i?.statusDisplay?.errorColor||A.colors.error)}`,borderRadius:i?.errorMessage?.borderRadius||A.borderRadius.md,padding:i?.errorMessage?.padding||A.spacing.md,marginBottom:A.spacing.sm},children:e.jsx("p",{style:{color:i?.errorMessage?.color||i?.statusDisplay?.errorColor||A.colors.error,fontSize:i?.errorMessage?.fontSize||A.typography.fontSize.sm,fontWeight:i?.errorMessage?.fontWeight,fontFamily:i?.errorMessage?.fontFamily||A.typography.fontFamily,margin:0},children:O})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:A.spacing.sm},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:pe,onMouseEnter:()=>z(!0),onMouseLeave:()=>{z(!1),H(!1)},onMouseDown:()=>H(!0),onMouseUp:()=>H(!1),loading:P,disabled:!N||!b,theme:A,styles:i,style:{width:"100%",padding:"8px",backgroundColor:N?E?"#d43d3d":M?"#f05555":"#ea4b4b":"#d1d5db",color:N?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:N?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:N?E?"scale(0.98)":M?"translateY(-2px)":"none":"none",boxShadow:E?"1px 1px 0px black":M&&N?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:k?p?b?P?"Executing Deposit...":h?h.amount?parseFloat(h.amount)>h.asset.balanceFormatted?"Insufficient Balance":t.length===0?"No Deposit Batches":"Execute Deposit":"Enter Amount":"Select Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})};var xs="data:image/svg+xml,%3csvg width='108' height='22' viewBox='0 0 108 22' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M1.9916 11.9854V11.2041H3.98379C4.48835 11.2041 4.87897 11.0739 5.15566 10.8135C5.43236 10.5498 5.5707 10.1868 5.5707 9.72461V9.71484C5.5707 9.24935 5.43236 8.88639 5.15566 8.62598C4.87897 8.36556 4.48835 8.23535 3.98379 8.23535H1.9916V7.4541H4.2084C4.65111 7.4541 5.04173 7.5485 5.38027 7.7373C5.71882 7.92611 5.98411 8.18978 6.17617 8.52832C6.37148 8.86686 6.46914 9.25911 6.46914 9.70508V9.71484C6.46914 10.1608 6.37148 10.5547 6.17617 10.8965C5.98411 11.2383 5.71882 11.5052 5.38027 11.6973C5.04173 11.8893 4.65111 11.9854 4.2084 11.9854H1.9916ZM1.55215 14.5V7.4541H2.43106V14.5H1.55215ZM9.51875 14.5928C9.0207 14.5928 8.58939 14.4837 8.2248 14.2656C7.86348 14.0443 7.58353 13.7301 7.38496 13.3232C7.18965 12.9163 7.09199 12.4329 7.09199 11.873V11.8633C7.09199 11.3001 7.18965 10.8151 7.38496 10.4082C7.58353 10.0013 7.86348 9.6888 8.2248 9.4707C8.58939 9.2526 9.0207 9.14355 9.51875 9.14355C10.0201 9.14355 10.4514 9.2526 10.8127 9.4707C11.174 9.6888 11.4523 10.0013 11.6477 10.4082C11.8462 10.8151 11.9455 11.3001 11.9455 11.8633V11.873C11.9455 12.4329 11.8462 12.9163 11.6477 13.3232C11.4523 13.7301 11.174 14.0443 10.8127 14.2656C10.4514 14.4837 10.0201 14.5928 9.51875 14.5928ZM9.51875 13.8408C9.85078 13.8408 10.1324 13.7627 10.3635 13.6064C10.5946 13.4502 10.7704 13.2256 10.8908 12.9326C11.0145 12.6396 11.0764 12.2865 11.0764 11.873V11.8633C11.0764 11.4466 11.0145 11.0918 10.8908 10.7988C10.7704 10.5059 10.5946 10.2829 10.3635 10.1299C10.1324 9.97363 9.85078 9.89551 9.51875 9.89551C9.18672 9.89551 8.90514 9.97363 8.67402 10.1299C8.4429 10.2829 8.26549 10.5059 8.1418 10.7988C8.02135 11.0918 7.96113 11.4466 7.96113 11.8633V11.873C7.96113 12.2865 8.02135 12.6396 8.1418 12.9326C8.26549 13.2256 8.4429 13.4502 8.67402 13.6064C8.90514 13.7627 9.18672 13.8408 9.51875 13.8408ZM13.7842 14.5L12.3096 9.23633H13.1592L14.1943 13.4453H14.2725L15.4492 9.23633H16.2549L17.4316 13.4453H17.5098L18.5449 9.23633H19.3896L17.915 14.5H17.0605L15.8838 10.4277H15.8057L14.6338 14.5H13.7842ZM22.1658 14.5928C21.6645 14.5928 21.2332 14.4821 20.8719 14.2607C20.5138 14.0394 20.2371 13.7269 20.0418 13.3232C19.8497 12.9163 19.7537 12.4378 19.7537 11.8877V11.8828C19.7537 11.3392 19.8497 10.8623 20.0418 10.4521C20.2371 10.042 20.5122 9.72135 20.867 9.49023C21.2218 9.25911 21.6368 9.14355 22.1121 9.14355C22.5906 9.14355 23.0008 9.25423 23.3426 9.47559C23.6876 9.69694 23.9513 10.0062 24.1336 10.4033C24.3191 10.7972 24.4119 11.2562 24.4119 11.7803V12.1123H20.1932V11.4336H23.9773L23.5574 12.0537V11.7168C23.5574 11.3034 23.4956 10.9632 23.3719 10.6963C23.2482 10.4294 23.0773 10.2308 22.8592 10.1006C22.6411 9.96712 22.3904 9.90039 22.1072 9.90039C21.824 9.90039 21.5701 9.97038 21.3455 10.1104C21.1242 10.2471 20.9484 10.4505 20.8182 10.7207C20.688 10.9909 20.6229 11.3229 20.6229 11.7168V12.0537C20.6229 12.4281 20.6863 12.7487 20.8133 13.0156C20.9402 13.2793 21.1209 13.4827 21.3553 13.626C21.5896 13.766 21.8663 13.8359 22.1854 13.8359C22.423 13.8359 22.6297 13.8034 22.8055 13.7383C22.9813 13.6732 23.1261 13.5902 23.24 13.4893C23.354 13.3883 23.4337 13.2858 23.4793 13.1816L23.4988 13.1377H24.3484L24.3387 13.1768C24.2931 13.3558 24.2117 13.5299 24.0945 13.6992C23.9806 13.8652 23.8325 14.0166 23.6502 14.1533C23.4679 14.2868 23.2514 14.3942 23.0008 14.4756C22.7534 14.5537 22.4751 14.5928 22.1658 14.5928ZM25.4303 14.5V9.23633H26.2799V10.0176H26.358C26.4589 9.74089 26.6298 9.52604 26.8707 9.37305C27.1116 9.22005 27.4094 9.14355 27.7643 9.14355C27.8456 9.14355 27.9254 9.14844 28.0035 9.1582C28.0849 9.16471 28.1467 9.17122 28.1891 9.17773V10.0029C28.1012 9.98665 28.0149 9.97526 27.9303 9.96875C27.8489 9.95898 27.761 9.9541 27.6666 9.9541C27.3964 9.9541 27.1572 10.0078 26.9488 10.1152C26.7405 10.2227 26.5761 10.3724 26.4557 10.5645C26.3385 10.7565 26.2799 10.9811 26.2799 11.2383V14.5H25.4303ZM30.9408 14.5928C30.4395 14.5928 30.0082 14.4821 29.6469 14.2607C29.2888 14.0394 29.0121 13.7269 28.8168 13.3232C28.6247 12.9163 28.5287 12.4378 28.5287 11.8877V11.8828C28.5287 11.3392 28.6247 10.8623 28.8168 10.4521C29.0121 10.042 29.2872 9.72135 29.642 9.49023C29.9968 9.25911 30.4118 9.14355 30.8871 9.14355C31.3656 9.14355 31.7758 9.25423 32.1176 9.47559C32.4626 9.69694 32.7263 10.0062 32.9086 10.4033C33.0941 10.7972 33.1869 11.2562 33.1869 11.7803V12.1123H28.9682V11.4336H32.7523L32.3324 12.0537V11.7168C32.3324 11.3034 32.2706 10.9632 32.1469 10.6963C32.0232 10.4294 31.8523 10.2308 31.6342 10.1006C31.4161 9.96712 31.1654 9.90039 30.8822 9.90039C30.599 9.90039 30.3451 9.97038 30.1205 10.1104C29.8992 10.2471 29.7234 10.4505 29.5932 10.7207C29.463 10.9909 29.3979 11.3229 29.3979 11.7168V12.0537C29.3979 12.4281 29.4613 12.7487 29.5883 13.0156C29.7152 13.2793 29.8959 13.4827 30.1303 13.626C30.3646 13.766 30.6413 13.8359 30.9604 13.8359C31.198 13.8359 31.4047 13.8034 31.5805 13.7383C31.7563 13.6732 31.9011 13.5902 32.015 13.4893C32.129 13.3883 32.2087 13.2858 32.2543 13.1816L32.2738 13.1377H33.1234L33.1137 13.1768C33.0681 13.3558 32.9867 13.5299 32.8695 13.6992C32.7556 13.8652 32.6075 14.0166 32.4252 14.1533C32.2429 14.2868 32.0264 14.3942 31.7758 14.4756C31.5284 14.5537 31.2501 14.5928 30.9408 14.5928ZM36.1486 14.5928C35.7059 14.5928 35.3186 14.4805 34.9865 14.2559C34.6545 14.0312 34.3973 13.7155 34.215 13.3086C34.0328 12.8984 33.9416 12.4199 33.9416 11.873V11.8633C33.9416 11.3132 34.0328 10.8346 34.215 10.4277C34.3973 10.0208 34.6529 9.70508 34.9816 9.48047C35.3137 9.25586 35.7027 9.14355 36.1486 9.14355C36.3895 9.14355 36.6158 9.18262 36.8273 9.26074C37.0422 9.33561 37.2326 9.44141 37.3986 9.57812C37.5647 9.71484 37.6949 9.8776 37.7893 10.0664H37.8674V7.14648H38.717V14.5H37.8674V13.6602H37.7893C37.6818 13.8555 37.5467 14.0231 37.384 14.1631C37.2212 14.2998 37.0357 14.4056 36.8273 14.4805C36.619 14.5553 36.3928 14.5928 36.1486 14.5928ZM36.3439 13.8408C36.663 13.8408 36.938 13.7611 37.1691 13.6016C37.4003 13.4421 37.5777 13.2158 37.7014 12.9229C37.8251 12.6266 37.8869 12.2767 37.8869 11.873V11.8633C37.8869 11.4564 37.8251 11.1064 37.7014 10.8135C37.5777 10.5205 37.4003 10.2943 37.1691 10.1348C36.938 9.97526 36.663 9.89551 36.3439 9.89551C36.0249 9.89551 35.7499 9.97526 35.5188 10.1348C35.2909 10.291 35.1151 10.5156 34.9914 10.8086C34.871 11.1016 34.8107 11.4531 34.8107 11.8633V11.873C34.8107 12.2799 34.871 12.6315 34.9914 12.9277C35.1151 13.2207 35.2909 13.4469 35.5188 13.6064C35.7499 13.7627 36.0249 13.8408 36.3439 13.8408ZM45.1775 14.5928C44.9334 14.5928 44.7072 14.5553 44.4988 14.4805C44.2905 14.4056 44.1049 14.2998 43.9422 14.1631C43.7794 14.0231 43.6443 13.8555 43.5369 13.6602H43.4588V14.5H42.6092V7.14648H43.4588V10.0664H43.5369C43.6346 9.8776 43.7648 9.71484 43.9275 9.57812C44.0936 9.44141 44.2824 9.33561 44.4939 9.26074C44.7088 9.18262 44.9367 9.14355 45.1775 9.14355C45.6235 9.14355 46.0109 9.25586 46.3396 9.48047C46.6717 9.70508 46.9288 10.0208 47.1111 10.4277C47.2934 10.8346 47.3846 11.3132 47.3846 11.8633V11.873C47.3846 12.4199 47.2934 12.8984 47.1111 13.3086C46.9288 13.7155 46.6717 14.0312 46.3396 14.2559C46.0109 14.4805 45.6235 14.5928 45.1775 14.5928ZM44.9822 13.8408C45.3045 13.8408 45.5796 13.7627 45.8074 13.6064C46.0353 13.4469 46.2094 13.2207 46.3299 12.9277C46.4536 12.6315 46.5154 12.2799 46.5154 11.873V11.8633C46.5154 11.4531 46.4536 11.1016 46.3299 10.8086C46.2094 10.5156 46.0353 10.291 45.8074 10.1348C45.5796 9.97526 45.3045 9.89551 44.9822 9.89551C44.6632 9.89551 44.3881 9.97526 44.157 10.1348C43.9259 10.2943 43.7485 10.5205 43.6248 10.8135C43.5011 11.1064 43.4393 11.4564 43.4393 11.8633V11.873C43.4393 12.2767 43.5011 12.6266 43.6248 12.9229C43.7485 13.2158 43.9259 13.4421 44.157 13.6016C44.3881 13.7611 44.6632 13.8408 44.9822 13.8408ZM48.6568 16.3457C48.6015 16.3457 48.5396 16.3424 48.4713 16.3359C48.4029 16.3327 48.3395 16.3262 48.2809 16.3164V15.6182C48.3329 15.6279 48.3899 15.6344 48.4518 15.6377C48.5136 15.641 48.5738 15.6426 48.6324 15.6426C48.8733 15.6426 49.0702 15.5807 49.2232 15.457C49.3795 15.3333 49.5048 15.1201 49.5992 14.8174L49.6969 14.5049L47.7486 9.23633H48.6568L50.2779 14.0996L49.941 13.5674H50.3414L50.0045 14.0996L51.6207 9.23633H52.5143L50.4586 14.8223C50.3154 15.2161 50.164 15.5238 50.0045 15.7451C49.845 15.9665 49.6578 16.1211 49.443 16.209C49.2314 16.3001 48.9693 16.3457 48.6568 16.3457Z' fill='%230E0D0B'/%3e%3cpath d='M62.7081 13.27C62.742 13.27 62.7642 13.3057 62.7491 13.3362V13.336L61.1229 16.6083C61.0892 16.6761 60.9926 16.6759 60.959 16.6083L59.3382 13.336C59.3232 13.3057 59.3453 13.27 59.3792 13.27H62.7081Z' fill='%23EA4B4B'/%3e%3cpath d='M61.0026 9.71913C61.0194 9.68524 61.0678 9.68524 61.0845 9.71913L62.747 13.0897C62.762 13.12 62.7399 13.1557 62.706 13.1557H59.3763C59.3424 13.1557 59.3203 13.12 59.3353 13.0897L61.0026 9.71913Z' fill='%23EA4B4B'/%3e%3cpath d='M60.8426 9.63827C60.8766 9.63827 60.8987 9.6741 60.8835 9.70444L59.2164 13.0594C59.1995 13.0932 59.1513 13.0932 59.1345 13.0594L57.5001 9.77047C57.47 9.70962 57.5142 9.63827 57.5821 9.63827H60.8426Z' fill='%23EA4B4B'/%3e%3cpath d='M64.5036 9.63617C64.5715 9.63618 64.6157 9.70753 64.5855 9.76838H64.5854L62.9512 13.0573C62.9344 13.0911 62.8862 13.0912 62.8692 13.0573L61.2021 9.70235C61.187 9.672 61.2091 9.63617 61.2431 9.63617H64.5036Z' fill='%23EA4B4B'/%3e%3cpath d='M62.8284 6.18281C62.862 6.11518 62.9586 6.11518 62.9922 6.18281L64.5855 9.38969C64.6157 9.45054 64.5715 9.52189 64.5036 9.52189H61.2431C61.2091 9.52189 61.187 9.48605 61.2021 9.45571L62.8283 6.18265L62.8284 6.18281Z' fill='%23EA4B4B'/%3e%3cpath d='M62.3131 6.13196C62.381 6.13196 62.4252 6.20331 62.3951 6.26416C62.154 6.74935 61.9128 7.23455 61.6718 7.71975H61.6716C61.4225 8.22125 61.1733 8.72259 60.9242 9.22409C60.9074 9.25799 60.859 9.25799 60.8422 9.22409L60.6305 8.79587C60.6275 8.78957 60.6259 8.78263 60.6259 8.77553V6.22349C60.6259 6.17297 60.6668 6.13196 60.7173 6.13196H62.3131Z' fill='%23EA4B4B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M74.8537 10.0096C75.2721 10.0096 75.654 10.1125 75.9993 10.3184C76.3513 10.5177 76.6303 10.8032 76.8361 11.1751C77.0487 11.547 77.1549 11.9953 77.1549 12.52V12.6495C77.1549 13.1675 77.052 13.6158 76.8461 13.9943C76.6402 14.3729 76.3613 14.6618 76.0093 14.861C75.664 15.0603 75.2788 15.1599 74.8537 15.1599C74.515 15.1599 74.2261 15.1134 73.9871 15.0204C73.7546 14.9341 73.5653 14.8212 73.4192 14.6817C73.2731 14.5423 73.1602 14.3995 73.0805 14.2534H72.941V16.9659L72.1541 16.0013V10.1491H72.9211V10.956H73.0352C73.2729 10.6733 73.3893 10.4911 73.6683 10.2985C73.9538 10.1059 74.349 10.0096 74.8537 10.0096ZM74.6445 10.7069C74.1464 10.7069 73.7347 10.8696 73.4092 11.195C73.0905 11.5138 72.9311 11.9621 72.9311 12.5399V12.6296C72.9311 13.2074 73.0905 13.659 73.4092 13.9844C73.7347 14.3032 74.1464 14.4626 74.6445 14.4626C75.1492 14.4626 75.5577 14.3032 75.8698 13.9844C76.1886 13.659 76.348 13.2074 76.348 12.6296V12.5399C76.348 11.9621 76.1886 11.5138 75.8698 11.195C75.5577 10.8696 75.1492 10.7069 74.6445 10.7069Z' fill='%230E0D0B'/%3e%3cpath d='M78.5848 11.9583L78.5555 15.4596L77.7681 14.4846V10.9583L78.5848 11.9583Z' fill='%230E0D0B'/%3e%3cpath d='M101.588 10.2986H102.444L103 10.986H101.588V10.9867H100.802L101.588 11.9623V14.1937C101.588 14.3929 101.685 14.4926 101.877 14.4926H102.379L102.928 15.17H101.668C101.389 15.17 101.173 15.0936 101.021 14.9409C100.874 14.7881 100.801 14.5789 100.801 14.3133V10.986H99.8799L99.3217 10.2986H100.801V9.13501H101.588V10.2986Z' fill='%230E0D0B'/%3e%3cpath d='M69.0133 7.90764C69.4848 7.90764 69.9065 7.99068 70.2784 8.15671C70.6569 8.3161 70.9525 8.55517 71.165 8.87395C71.3842 9.18609 71.4938 9.58126 71.4938 10.0594V10.4778H70.667V10.0594C70.667 9.72072 70.5939 9.44842 70.4477 9.24254C70.3083 9.03666 70.1124 8.88392 69.86 8.7843C69.6143 8.68469 69.332 8.63487 69.0133 8.63487C68.555 8.63487 68.1864 8.7378 67.9075 8.94367C67.6286 9.14291 67.4891 9.4285 67.4891 9.80041C67.4891 10.0461 67.5488 10.2453 67.6684 10.3981C67.7879 10.5508 67.9573 10.677 68.1764 10.7767C68.3956 10.8696 68.658 10.9527 68.9635 11.0257L69.4815 11.1552C69.8866 11.2416 70.2485 11.3611 70.5673 11.5138C70.8927 11.6599 71.1517 11.8625 71.3443 12.1215C71.5369 12.3739 71.6332 12.706 71.6332 13.1177C71.6332 13.5295 71.5303 13.8881 71.3244 14.1936C71.1185 14.4991 70.8263 14.7382 70.4477 14.9109C70.0758 15.0769 69.6375 15.1599 69.1328 15.1599C68.6281 15.1599 68.1765 15.0702 67.778 14.8909C67.3795 14.7116 67.0641 14.4426 66.8316 14.084C66.6058 13.7187 66.4929 13.2638 66.4929 12.7192V12.51H67.3197V12.7192C67.3197 13.297 67.4891 13.7287 67.8278 14.0143C68.1665 14.2932 68.6015 14.4327 69.1328 14.4327C69.6774 14.4327 70.0924 14.3098 70.378 14.0641C70.6636 13.8183 70.8064 13.5095 70.8064 13.1376C70.8064 12.8786 70.74 12.6727 70.6072 12.52C70.481 12.3673 70.3017 12.2444 70.0692 12.1514C69.8368 12.0518 69.5645 11.9655 69.2523 11.8924L68.7343 11.7629C68.3292 11.6566 67.9706 11.5271 67.6584 11.3744C67.3463 11.2216 67.1006 11.0224 66.9213 10.7767C66.7486 10.5243 66.6623 10.2022 66.6623 9.81035C66.6623 9.41852 66.7585 9.07981 66.9511 8.79424C67.1504 8.50866 67.426 8.28953 67.778 8.13678C68.1366 7.98404 68.5484 7.90764 69.0133 7.90764Z' fill='%230E0D0B'/%3e%3cpath d='M81.6544 10.0096C82.1193 10.0096 82.5145 10.0959 82.8399 10.2686C83.1719 10.4412 83.431 10.6704 83.6169 10.956C83.8095 11.2415 83.9324 11.5471 83.9855 11.8725L83.2185 12.0318C83.1853 11.7928 83.1056 11.5736 82.9794 11.3744C82.8598 11.1752 82.6905 11.0158 82.4713 10.8962C82.2521 10.7767 81.9832 10.7169 81.6644 10.7169C81.339 10.7169 81.0468 10.7899 80.7877 10.936C80.5354 11.0821 80.3328 11.2914 80.1801 11.5637C80.034 11.836 79.9609 12.1614 79.9609 12.5399V12.6296C79.9609 13.0081 80.034 13.3335 80.1801 13.6058C80.3328 13.8781 80.5354 14.0873 80.7877 14.2334C81.0468 14.3795 81.339 14.4526 81.6644 14.4526C82.1492 14.4526 82.5178 14.3264 82.7702 14.0741C83.0292 13.8217 83.1886 13.5095 83.2483 13.1376L84.0254 13.307C83.9523 13.6257 83.8195 13.9279 83.6269 14.2135C83.4343 14.4991 83.172 14.7282 82.8399 14.9009C82.5145 15.0735 82.1193 15.1599 81.6544 15.1599C81.1829 15.1599 80.7579 15.0603 80.3793 14.861C80.0074 14.6551 79.7119 14.363 79.4927 13.9844C79.2802 13.6059 79.1739 13.1575 79.1739 12.6395V12.5299C79.1739 12.0053 79.2802 11.557 79.4927 11.1851C79.7119 10.8066 80.0074 10.5177 80.3793 10.3184C80.7579 10.1126 81.1829 10.0096 81.6544 10.0096Z' fill='%230E0D0B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M86.7515 10.0096C87.2097 10.0096 87.6149 10.1092 87.9668 10.3084C88.3188 10.501 88.5944 10.78 88.7937 11.1452C88.9929 11.5105 89.0925 11.9389 89.0925 12.4304V12.7889H85.1177C85.1377 13.3136 85.3071 13.7254 85.6258 14.0243C85.9446 14.3165 86.3431 14.4626 86.8212 14.4626C87.2396 14.4626 87.5617 14.3663 87.7875 14.1737C88.0133 13.9811 88.186 13.752 88.3056 13.4863L88.983 13.815C88.8833 14.0209 88.7439 14.2268 88.5646 14.4327C88.3919 14.6386 88.1628 14.8113 87.8772 14.9507C87.5983 15.0902 87.2396 15.1599 86.8013 15.1599C86.3099 15.1599 85.8782 15.057 85.5063 14.8511C85.1344 14.6386 84.8455 14.343 84.6396 13.9645C84.4337 13.5859 84.3307 13.1476 84.3307 12.6495V12.5299C84.3307 12.0252 84.4337 11.5836 84.6396 11.205C84.8455 10.8265 85.1311 10.5342 85.4963 10.3284C85.8616 10.1159 86.28 10.0096 86.7515 10.0096ZM86.7515 10.7069C86.3066 10.7069 85.9413 10.8331 85.6557 11.0855C85.3701 11.3378 85.1941 11.6898 85.1277 12.1414H88.2956C88.269 11.6898 88.113 11.3378 87.8274 11.0855C87.5485 10.8331 87.1898 10.7069 86.7515 10.7069Z' fill='%230E0D0B'/%3e%3cpath fill-rule='evenodd' clip-rule='evenodd' d='M97.1624 10.0096C97.6207 10.0096 98.0258 10.1092 98.3778 10.3084C98.7298 10.501 99.0054 10.78 99.2046 11.1452C99.4039 11.5105 99.5035 11.9389 99.5035 12.4304V12.7889H95.5287C95.5487 13.3136 95.718 13.7254 96.0368 14.0243C96.3555 14.3165 96.754 14.4626 97.2322 14.4626C97.6505 14.4626 97.9727 14.3663 98.1985 14.1737C98.4243 13.9811 98.5969 13.752 98.7165 13.4863L99.3939 13.815C99.2943 14.0209 99.1548 14.2268 98.9755 14.4327C98.8028 14.6386 98.5737 14.8113 98.2881 14.9507C98.0092 15.0902 97.6506 15.1599 97.2123 15.1599C96.7208 15.1599 96.2892 15.057 95.9172 14.8511C95.5453 14.6386 95.2564 14.343 95.0505 13.9645C94.8446 13.5859 94.7417 13.1476 94.7417 12.6495V12.5299C94.7417 12.0252 94.8446 11.5836 95.0505 11.205C95.2564 10.8265 95.542 10.5342 95.9073 10.3284C96.2725 10.1158 96.6909 10.0096 97.1624 10.0096ZM97.1624 10.7069C96.7175 10.7069 96.3522 10.8331 96.0666 11.0855C95.7811 11.3378 95.6051 11.6898 95.5387 12.1414H98.7066C98.68 11.6898 98.5239 11.3378 98.2383 11.0855C97.9594 10.8331 97.6008 10.7069 97.1624 10.7069Z' fill='%230E0D0B'/%3e%3cpath d='M92.2484 10.0594C92.6137 10.0594 92.9391 10.1358 93.2247 10.2885C93.5169 10.4413 93.7494 10.6671 93.9221 10.966C94.0947 11.2648 94.1811 11.6334 94.1811 12.0717V15.1458H93.394V12.1315C93.394 11.6467 93.2712 11.2947 93.0255 11.0755C92.7864 10.8564 92.461 10.7468 92.0492 10.7468C91.5777 10.7468 91.1925 10.8995 90.8936 11.205C90.6014 11.5105 90.4553 11.9655 90.4553 12.5698V15.1458H89.6683V10.1491H90.4354V10.9582H90.5361C90.7355 10.7018 90.8604 10.5342 91.1128 10.3483C91.3718 10.1557 91.7503 10.0594 92.2484 10.0594Z' fill='%230E0D0B'/%3e%3cpath d='M78.5932 10.9581H77.7681V10.1514H78.6L78.5932 10.9581Z' fill='%230E0D0B'/%3e%3c/svg%3e";const xt=({isOpen:t,onClose:o,title:r,subtitle:n,children:s,overlayContent:c,styles:i,theme:d,maxWidth:g="522px"})=>{const f=d||de.createTheme("light");return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{border:"6px solid #E9E9E9",backgroundColor:"white",borderRadius:"12px",width:"100%",padding:"0",display:"flex",flexDirection:"column",maxWidth:g,position:"relative",overflow:"hidden"},children:[c&&e.jsx("div",{style:{position:"absolute",inset:0,backgroundColor:"rgba(0, 0, 0, 0.4)",zIndex:5,pointerEvents:"none",borderRadius:"12px"}}),e.jsxs("div",{style:{padding:"24px 24px 16px 24px",borderBottom:"1px solid #cdcfd1",position:"relative"},children:[e.jsx("button",{onClick:o,style:{position:"absolute",top:"16px",right:"16px",color:"#111827",padding:"8px",backgroundColor:"transparent",borderRadius:"50%",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",transition:"background-color 0.2s",fontSize:"20px",fontWeight:"600"},onMouseEnter:u=>{u.currentTarget.style.backgroundColor="#f3f4f6"},onMouseLeave:u=>{u.currentTarget.style.backgroundColor="transparent"},children:e.jsxs("svg",{width:"24",height:"24",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2.5",children:[e.jsx("line",{x1:"18",y1:"6",x2:"6",y2:"18"}),e.jsx("line",{x1:"6",y1:"6",x2:"18",y2:"18"})]})}),e.jsx("h2",{style:{fontSize:"23px",fontWeight:"600",color:"#111827",margin:"0",fontFamily:i?.fontFamily||f.typography.fontFamily||"system-ui, -apple-system, sans-serif"},children:r})]}),n&&e.jsx("div",{style:{padding:"16px 24px 0px 24px",fontSize:"12px",color:"#6b7280",margin:"0 0 2rem 0",lineHeight:"1.4",fontFamily:i?.fontFamily||f.typography.fontFamily||"system-ui, -apple-system, sans-serif"},children:n}),s,e.jsxs("div",{style:{padding:"0px 28px 8px 28px",margin:0,marginTop:"10px",display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("img",{src:xs,alt:"Powered by SpiceNet",style:{height:"auto",width:"auto",opacity:1,margin:0,display:"block"}}),e.jsxs("a",{href:"https://spicenet.io/accounts",target:"_blank",rel:"noopener noreferrer",style:{fontSize:"10px",color:"#51514f",textDecoration:"none",display:"flex",alignItems:"center",gap:"4px",fontFamily:i?.fontFamily||f.typography.fontFamily,lineHeight:"1"},children:[e.jsx("span",{children:"Learn more about"}),e.jsx("span",{style:{color:i?.primaryColor||f.colors.primary,textDecoration:"underline",fontWeight:"500"},children:"Spicenet accounts \u2192"})]})]}),c]})}):null};var Pt="data:image/svg+xml,%3csvg width='15' height='15' viewBox='0 0 15 15' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M7.5 7.49993V10.4999M7.5 4.96868V4.96784M14.25 7.5C14.25 11.2279 11.2279 14.25 7.5 14.25C3.77208 14.25 0.75 11.2279 0.75 7.5C0.75 3.77208 3.77208 0.75 7.5 0.75C11.2279 0.75 14.25 3.77208 14.25 7.5Z' stroke='%23ED6969' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3e%3c/svg%3e";const wo=({isOpen:t,onClose:o,title:r="Deposit",maxWidth:n="480px",depositBatches:s,tokenAddress:c,tokenDecimals:i,supportedChains:d,supportedTokens:g,theme:f="light",styles:u,className:l,depositInputHook:C,onDepositSuccess:A,onDepositError:w})=>{const k=de.createTheme(f),p=b=>{A?.(b)};return e.jsx(xt,{isOpen:t,onClose:o,title:r,subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:"Use your cross-chain balance to deposit WBTC to earn 6.3% yield, all in one click."})]}),styles:u,theme:k,maxWidth:n,children:e.jsx("div",{style:{padding:"0 24px 24px 24px"},children:e.jsx(gs,{depositBatches:s,tokenAddress:c,tokenDecimals:i,supportedChains:d,supportedTokens:g,theme:f,styles:{...u,container:{...u?.container,boxShadow:"none",borderColor:"transparent",padding:"0",backgroundColor:"transparent"}},className:l,depositInputHook:C,onDepositSuccess:p,onDepositError:w})})})},So=({asset:t,amount:o,onAmountChange:r,onPercentageClick:n,usdValue:s,disabled:c,styles:i,theme:d})=>{const g=t.balanceFormatted??0,f=parseFloat(o)||0,u=g>0?f/g*100:0,[l,C]=a.useState(null),[A,w]=a.useState(null),k=p=>{const b=p.target.value;(b===""||/^\d*\.?\d*$/.test(b))&&r(b)};return e.jsx("div",{style:{backgroundColor:"#e9e9e9",border:"0.5px solid #A8A8A7",borderRadius:"6px",padding:"16px",height:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsx("div",{style:{display:"flex",flexDirection:"column",justifyContent:"space-between",height:"100%"},children:e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsx("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:"Amount"}),e.jsx("input",{type:"text",value:o,onChange:k,placeholder:"0.00",disabled:c,style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"40px",fontWeight:700,color:c?"rgba(14, 13, 11, 0.16)":o?"#0e0d0b":"#d1d5db",lineHeight:"1.08",letterSpacing:"-1.2px",backgroundColor:"transparent",border:"none",outline:"none",padding:0,width:"100%",maxWidth:"200px"}})]})}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",justifyContent:"space-between",height:"100%",gap:"12px"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",alignItems:"flex-end"},children:[e.jsxs("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:["Balance: ",g.toFixed(4)]}),e.jsx("div",{style:{width:"128px"},children:e.jsxs("div",{style:{border:"1px solid #CDCFD1",borderRadius:"6px 6px 6px 6px",backgroundColor:"transparent",padding:"8px 12px 8px 8px",display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx(ot,{symbol:t.symbol,logoURI:t.logoURI,size:30,theme:d}),e.jsx("span",{style:{fontFamily:i?.fontFamily||d.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.symbol})]})})]}),e.jsx("div",{style:{display:"flex",gap:"10px",height:"14px",alignItems:"center",justifyContent:"flex-end"},children:[0,25,50,75,100].map((p,b)=>{const m=Math.abs(u-p)<1,j=b===4,y=p/100,h=l===p,x=A===p;return e.jsx("button",{onClick:()=>n(p),onMouseEnter:()=>C(p),onMouseLeave:()=>{C(null),w(null)},onMouseDown:()=>w(p),onMouseUp:()=>w(null),disabled:c,title:`${p}%`,style:{width:"14px",height:"14px",padding:0,border:"none",backgroundColor:"transparent",cursor:c?"not-allowed":"pointer",opacity:m?1:h?.8:.5,transform:x?"scale(0.85)":h?"scale(1.15)":"scale(1)",transition:"all 0.15s ease"},children:e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:j?"#ea4b4b":"none",stroke:j?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!j&&y>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${y>.5?1:0} 1 ${7+6.84375*Math.sin(y*2*Math.PI)} ${7-6.84375*Math.cos(y*2*Math.PI)} Z`,fill:"#3C3E42"})]})},p)})})]})]})})};var ko="data:image/svg+xml,%3csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M5.83337 11.0833C8.73287 11.0833 11.0834 8.73275 11.0834 5.83325C11.0834 2.93376 8.73287 0.583252 5.83337 0.583252C2.93388 0.583252 0.583374 2.93376 0.583374 5.83325C0.583374 8.73275 2.93388 11.0833 5.83337 11.0833Z' stroke='%23757171' stroke-width='1.16667' stroke-linecap='round' stroke-linejoin='round'/%3e%3cpath d='M4.84329 4.48988C5.18981 4.14336 5.36306 3.97011 5.56285 3.90519C5.73859 3.84809 5.92789 3.84809 6.10363 3.90519C6.30342 3.97011 6.47668 4.14336 6.82319 4.48988L7.17663 4.84331C7.52314 5.18983 7.6964 5.36308 7.76131 5.56287C7.81841 5.73861 7.81841 5.92791 7.76131 6.10365C7.6964 6.30344 7.52314 6.4767 7.17663 6.82321L6.82319 7.17665C6.47668 7.52316 6.30342 7.69642 6.10363 7.76133C5.92789 7.81843 5.73859 7.81843 5.56285 7.76133C5.36306 7.69642 5.18981 7.52316 4.84329 7.17665L4.48986 6.82321C4.14334 6.4767 3.97009 6.30344 3.90517 6.10365C3.84807 5.92791 3.84807 5.73861 3.90517 5.56287C3.97009 5.36308 4.14334 5.18983 4.48986 4.84331L4.84329 4.48988Z' stroke='%23757171' stroke-width='1.16667' stroke-linecap='round' stroke-linejoin='round'/%3e%3c/svg%3e";const Io=({isOpen:t,onClose:o,onComplete:r,title:n="Deposit to Spicenet",description:s="Select tokens and enter amounts to deposit to your Spicenet Account",chainId:c,embeddedWalletAddress:i,externalWalletAddress:d,escrowAddress:g="0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",getChainConfig:f,getSupportedTokens:u})=>{const l=de.createTheme("light"),[C,A]=a.useState(new Map),[w,k]=a.useState(!1),[p,b]=a.useState(null),[m,j]=a.useState([]),[y,h]=a.useState(!1),[x,S]=a.useState(null),[F,B]=a.useState(null),[I,G]=a.useState(!1),[P,_]=a.useState(!1),{chain:$}=Ae.useAccount(),{data:J,isLoading:M}=Ae.useWalletClient(),{switchChainAsync:z}=Ae.useSwitchChain(),E=a.useMemo(()=>u(c),[c,u]),{data:H}=Ae.useReadContracts({contracts:E.map(v=>({address:v.address,abi:re.erc20Abi,functionName:"balanceOf",args:[d],chainId:c}))}),X=a.useMemo(()=>{if(!f(c))return[];const v=[];return E.forEach((N,O)=>{const se=H?.[O],ae=se?.status==="success"?se.result:BigInt(0),Z=Number(ae)/Math.pow(10,N.decimals);v.push({address:N.address,symbol:N.symbol,name:N.name,decimals:N.decimals,isNative:!1,chainId:c,balance:ae,balanceFormatted:Z})}),v},[c,H,E,f]);a.useEffect(()=>{if(X.length>0&&C.size>0){const v=new Map(C);let N=!1;C.forEach((O,se)=>{const ae=X.find(Z=>Z.address===se);ae&&ae.balanceFormatted!==O.asset.balanceFormatted&&(v.set(se,{...O,asset:ae}),N=!0)}),N&&A(v)}},[X,C]);const ee=f(c),U=v=>{const N=new Map(C);N.has(v.address)?N.delete(v.address):N.set(v.address,{asset:v,amount:""}),A(N),b(null)},ne=(v,N)=>{if(N===""||/^\d*\.?\d*$/.test(N)){const O=new Map(C),se=O.get(v);se&&(O.set(v,{...se,amount:N}),A(O),b(null))}},xe=(v,N)=>{const O=C.get(v);if(O?.asset.balanceFormatted!==void 0){const se=O.asset.balanceFormatted*N/100;ne(v,se.toString())}},ue=a.useCallback(async()=>{if(C.size===0){b("Please select at least one asset");return}for(const[N,O]of Array.from(C.entries())){if(!O.amount){b(`Please enter an amount for ${O.asset.symbol}`);return}const se=parseFloat(O.amount);if(isNaN(se)||se<=0){b(`Please enter a valid amount for ${O.asset.symbol}`);return}const ae=X.find(Z=>Z.address===N)?.balanceFormatted??O.asset.balanceFormatted;if(ae!==void 0&&se>ae){b(`Insufficient ${O.asset.symbol} balance`);return}}if(!J){b("Wallet not connected. Please reconnect your external wallet.");return}k(!0),b(null);const v=[];try{$?.id!==c&&await z({chainId:c});for(const[,N]of Array.from(C.entries())){const{asset:O,amount:se}=N;try{const ae=re.parseUnits(se,O.decimals);let Z;if(O.isNative)Z=await J.sendTransaction({to:g,value:ae});else{const T=re.encodeFunctionData({abi:re.erc20Abi,functionName:"transfer",args:[g,ae]});Z=await J.sendTransaction({to:O.address,data:T})}const he=Ve(c),Ce=await he.waitForTransactionReceipt({hash:Z,timeout:12e4,pollingInterval:2e3,confirmations:2});if(Ce.status!=="success")throw new Error(`Transfer to escrow failed for ${O.symbol}`);await he.getBlockNumber()-Ce.blockNumber<2&&await new Promise(T=>setTimeout(T,3e3)),await we.submitSpiceDeposit({txHash:Z,sender:i,tokenAddress:O.address,chainId:c,amount:re.parseUnits(se,O.decimals).toString(),user:i,isDeposit:!0}),v.push({asset:O,txHash:Z,success:!0})}catch(ae){const Z=ae;let he=Z?.message||"Deposit failed";Z?.code===4001||Z?.message?.includes("rejected")?he="Transaction rejected by user":Z?.message?.includes("insufficient funds")&&(he="Insufficient funds for transaction"),v.push({asset:O,txHash:"",success:!1,error:he})}}j(v),h(!0)}catch(N){b(N?.message||"Deposit failed")}finally{k(!1)}},[C,J,$,c,z,g,X]);a.useEffect(()=>{t||(A(new Map),b(null),j([]),h(!1),k(!1))},[t]);const Ee=a.useCallback(()=>{j([]),h(!1),b(null)},[]),R=C.size>0&&Array.from(C.values()).every(v=>v.amount&&parseFloat(v.amount)>0)&&!w&&!y&&J,q=e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:s})]}),pe=w||y&&m.length>0?e.jsx(qt,{type:"deposit",isOpen:y&&m.length>0,isProcessing:w,onClose:o,onComplete:r,onRetryTx:Ee,onNewTx:()=>{},results:m.length>0?m.map(v=>({asset:{symbol:v.asset.symbol,address:v.asset.address},txHash:v.txHash,success:v.success,error:v.error})):void 0,chainName:st(c),explorerUrl:ee?.blockExplorers?.default?.url,theme:l}):null;return e.jsx(xt,{isOpen:t,onClose:o,title:n,subtitle:q,theme:l,maxWidth:"480px",children:e.jsxs("div",{style:{padding:"0 24px 32px 24px",position:"relative"},children:[pe&&e.jsx("div",{style:{position:"absolute",inset:0,overflow:"hidden",pointerEvents:"none"},children:e.jsx("div",{style:{position:"relative",width:"100%",height:"100%",pointerEvents:"auto"},children:pe})}),e.jsxs("div",{style:{marginBottom:"16px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:"10px"},children:[e.jsx("span",{style:{fontSize:"14px",color:"#6b7280"},children:e.jsx("img",{src:ko,alt:"Info",style:{width:"10.5px",height:"10.5px",top:"1.75px",left:"1.75px",flexShrink:0}})}),e.jsx("label",{style:{fontSize:"12px",fontWeight:590,color:"#374151"},children:"Select Assets to Deposit"})]}),e.jsx("div",{style:{display:"flex",gap:"12px",flexWrap:"wrap"},children:X.map(v=>{const N=C.has(v.address);return e.jsx("button",{onClick:()=>U(v),onMouseEnter:()=>S(v.address),onMouseLeave:()=>{S(null),B(null)},onMouseDown:()=>B(v.address),onMouseUp:()=>B(null),style:{padding:"4px 8px 4px 8px",borderRadius:"8px",border:`1px solid ${N?"#EA4B4B7A":x===v.address?"#F4A5A5":"#e5e7eb"}`,backgroundColor:N?"#FEF2F2":F===v.address?"#f5f5f5":x===v.address?"#fafafa":"white",cursor:"pointer",display:"flex",alignItems:"center",gap:"8px",transition:"all 150ms ease",transform:F===v.address?"scale(0.96)":x===v.address?"translateY(-1px)":"none",boxShadow:N?"0 0 0 3px #FBDBDB":F===v.address?"0 1px 2px rgba(0, 0, 0, 0.05)":x===v.address?"0 4px 8px rgba(0, 0, 0, 0.1)":"none"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx(ot,{symbol:v.symbol,size:24,theme:l}),e.jsx("span",{style:{fontSize:"16px",fontWeight:510,color:"#3C3E42"},children:v.symbol}),v.balanceFormatted!==void 0&&e.jsxs("span",{style:{fontSize:"10px",fontWeight:500,color:"#939291",fontFamily:'"IBM Plex Mono", monospace'},children:["(",v.balanceFormatted.toFixed(4),")"]})]})},v.address)})})]}),C.size>0&&e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"16px"},children:Array.from(C.values()).map(({asset:v,amount:N})=>e.jsx(So,{asset:v,amount:N,onAmountChange:O=>ne(v.address,O),onPercentageClick:O=>xe(v.address,O),theme:l,disabled:w},v.address))}),p&&e.jsx("div",{style:{padding:"12px",backgroundColor:"#fef2f2",border:"1px solid #fecaca",borderRadius:"8px",marginTop:"16px"},children:e.jsx("p",{style:{fontSize:"14px",color:"#dc2626",margin:0},children:p})}),!y&&e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ue,onMouseEnter:()=>G(!0),onMouseLeave:()=>{G(!1),_(!1)},onMouseDown:()=>_(!0),onMouseUp:()=>_(!1),disabled:!R,theme:l,style:{width:"100%",padding:"8px ",backgroundColor:R?P?"#d43d3d":I?"#f05555":"#ea4b4b":"#d1d5db",color:R?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:R?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:R?P?"scale(0.98)":I?"translateY(-2px)":"none":"none",boxShadow:P?"1px 1px 0px black":I&&R?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:w?e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"18px",height:"18px",border:"2px solid white",borderTopColor:"transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsx("span",{children:"PROCESSING..."})]}):M?"CONNECTING WALLET...":J?C.size===0?"SELECT ASSETS":Array.from(C.values()).every(v=>v.amount)?"DEPOSIT":"ENTER AMOUNTS":"WALLET NOT CONNECTED"}),e.jsx("style",{children:`
|
|
39
39
|
@keyframes spin {
|
|
40
40
|
from { transform: rotate(0deg); }
|
|
41
41
|
to { transform: rotate(360deg); }
|
|
42
42
|
}
|
|
43
|
-
`})]})})},Fo=[{id:"external",label:"External Wallet"},{id:"embedded",label:"Embedded Wallet"}],fs=({withdrawBatches:t,externalWithdrawBatches:o,tokens:r,supportedTokens:n,enableSpiceBalanceUpdate:s=!1,theme:c="light",styles:i,className:d="",withdrawInputHook:g,defaultSelectedAsset:f,filterChains:u,withdrawMode:l="external",onWithdrawModeChange:C,externalWalletAddress:A,embeddedWalletAddress:w,onWithdrawSuccess:k,onWithdrawError:p})=>{const b=de.createTheme(c),m={...b,typography:{...b.typography,fontFamily:i?.fontFamily||b.typography.fontFamily},colors:{...b.colors,primary:i?.primaryColor||b.colors.primary,primaryHover:i?.primaryColor?`${i.primaryColor}dd`:b.colors.primaryHover}},j=Lt(),{isReady:y,isAuthenticated:h,isConnected:x,address:S,provider:F,actions:B}=j,[I,G]=a.useState(()=>f?{asset:f,amount:""}:null),[P,_]=a.useState([]),[$,J]=a.useState(!1),[M,z]=a.useState(null),E=a.useMemo(()=>!r||r.length===0?[]:!n||n.length===0?r:r.filter(Y=>n.some(te=>te.toLowerCase()===Y.symbol.toLowerCase())),[r,n]),U=a.useCallback(async()=>{if(!E||E.length===0||!w){_([]);return}J(!0),z(null);try{const Y=await Promise.all(E.map(async te=>{try{const Fe=await Ve(te.chainId).readContract({address:te.address,abi:re.erc20Abi,functionName:"balanceOf",args:[w]}),De=parseFloat(re.formatUnits(Fe,te.decimals));return{address:te.address,symbol:te.symbol,name:te.name,decimals:te.decimals,chainId:te.chainId,balance:Fe,balanceFormatted:De,balanceUsd:0,isNative:!1,logoURI:te.logoURI}}catch(Fe){return console.error(`Failed to fetch balance for ${te.symbol}:`,Fe),{address:te.address,symbol:te.symbol,name:te.name,decimals:te.decimals,chainId:te.chainId,balance:BigInt(0),balanceFormatted:0,balanceUsd:0,isNative:!1,logoURI:te.logoURI}}}));_(Y)}catch(Y){console.error("Failed to fetch token balances:",Y),z(Y instanceof Error?Y.message:"Failed to fetch token balances")}finally{J(!1)}},[E,w]);a.useEffect(()=>{U()},[U]),a.useEffect(()=>{if(!E||E.length===0)return;const Y=setInterval(()=>{U()},3e4);return()=>clearInterval(Y)},[U,E]);const X=P.some(Y=>Y.balanceFormatted>0),[ee,H]=a.useState(!1),[ne,xe]=a.useState(null),[ue,Ee]=a.useState(!1),[R,q]=a.useState(!1),[pe,v]=a.useState(!1),[N,O]=a.useState(l),[se,ae]=a.useState(null),[Z,he]=a.useState(null),Ce=a.useRef(null),T=a.useMemo(()=>N==="external"?A:w,[N,A,w]),oe=a.useCallback(Y=>{O(Y),C?.(Y)},[C]),{intentStatus:le,startStatusPolling:Se,clearStatus:ve}=kt({checkStepStatus:(Y,te)=>we.checkStepStatus(Y,te)});a.useEffect(()=>{if(le?.overallStatus==="success"&&le.intentId&&Ce.current!==le.intentId&&I&&S){const Y=le.steps.find(te=>te.transactionHash);if(Y?.transactionHash)if(Ce.current=le.intentId,s){const te=re.parseUnits(I.amount,I.asset.decimals);we.submitSpiceDeposit({user:S,txHash:Y.transactionHash,sender:S,tokenAddress:I.asset.address,chainId:I.asset.chainId,amount:te.toString(),isDeposit:!1}).then(()=>{U()}).catch(()=>{Ce.current=null})}else U()}},[le,S,s]),a.useEffect(()=>{g&&g.assetAmount!==I?.amount&&I&&G({...I,amount:g.assetAmount})},[g?.assetAmount,I]);const ke=a.useCallback(()=>{xe(null)},[]),Ie=Y=>{G({asset:Y,amount:I?.amount||""}),ke()},ce=a.useCallback(Y=>{I&&(a.startTransition(()=>{G({...I,amount:Y}),ke()}),g&&g.setAssetAmount(Y))},[I,g,ke]),ze=async()=>{if(!(!I||!S||t.length===0)){if(!T){xe(`Please provide a ${N==="external"?"external":"embedded"} wallet address`);return}if(!y||!h){xe(`Please authenticate with ${F||"wallet provider"} to continue`);return}H(!0),xe(null),v(!0);try{const Y=N==="external"&&o?[...t,...o]:[...t],te=[...new Set(Y.map(ge=>ge.chainId))],Fe=[];for(const ge of te){const nt=Ve(ge),tt=ct(ge),ft=await Ye.getAccountNonce(S,nt),Ge=await B.signAuthorization({contractAddress:tt,chainId:ge,nonce:Number(ft)});Fe.push(Ge)}const De=Ye.hashChainBatches(Y),_e=Math.floor(Date.now()/1e3)+60*10,at=Ye.getIntentHash(0n,BigInt(_e),De),et=await B.signMessage({raw:at}),Ze=typeof et=="string"?et:et.signature;if(!Ze)throw new Error("Failed to sign intent authorization");const be={mode:"7702",signatureType:"ecdsa",signature:Ze,nbf:0,exp:_e,chainBatches:De.map(ge=>({hash:ge.hash,chainId:ge.chainId,tokenTransfers:[{from:"solver",to:S,token:"0x0000000000000000000000000000000000000000",amount:re.parseUnits("0.01",18)}],calls:ge.calls}))},Re=await we.createAction({user:S,chainAuthorizations:Fe.map(ge=>({...ge,r:ge.r,s:ge.s,yParity:ge.yParity,address:ge.address,chainId:Number(ge.chainId),nonce:Number(ge.nonce)})),intents:[be]});if(Re){const ge=Et(Y,Ge=>`Chain ${Ge}`),[nt,tt]=Re.intentIds[0].split("/"),ft=parseInt(tt||"0",10);Se(Re.intentIds[0],ge);for(let Ge=0;Ge<Y.length;Ge++)await we.executeStep(nt,ft,Ge,{action:"execute"})}}catch(Y){const te=Y instanceof Error?Y.message:"Withdraw failed";xe(te),p?.(te)}finally{H(!1)}}},W=a.useMemo(()=>{let Y=P;return u&&u.length>0&&(Y=Y.filter(te=>u.includes(te.chainId))),Y},[P,u]),K=I&&I.amount&&parseFloat(I.amount)>0&&parseFloat(I.amount)<=I.asset.balanceFormatted&&x&&!ee&&t.length>0&&!!T,ie=M||ne,me={backgroundColor:i?.container?.backgroundColor||i?.primaryBackground||m.colors.background,border:`1px solid ${i?.container?.borderColor||m.colors.border}`,borderRadius:i?.container?.borderRadius||m.borderRadius.lg,padding:i?.container?.padding||m.spacing.md,width:i?.container?.width||"100%",maxWidth:"28rem",minHeight:"200px",margin:"0 auto",color:m.colors.text,fontFamily:m.typography.fontFamily,boxShadow:i?.container?.boxShadow||(m.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")},$e=le?e.jsx(qt,{type:"withdraw",isOpen:!!le&&le.overallStatus!=="processing",isProcessing:ee||le?.overallStatus==="processing",onRetryTx:()=>{ve(),v(!1),ze()},onNewTx:()=>{ve(),v(!1),G(null),Ce.current=null,U()},onClose:()=>{ve(),v(!1)},onComplete:()=>{ve(),v(!1),G(null),Ce.current=null,U()},results:le?.overallStatus==="success"||le?.overallStatus==="failed"?le.steps.map(Y=>({asset:{symbol:I?.asset.symbol||"Token",address:I?.asset.address||""},txHash:Y.transactionHash||"",success:Y.status==="success",amount:I?.amount})):void 0,chainName:I?st(t[t.length-1].chainId):"Network",explorerUrl:I?Wt(t[t.length-1].chainId,"").replace(/\/tx\/.*$/,""):void 0,theme:m}):null;return e.jsxs("div",{style:{...me,position:"relative"},className:d,children:[$e&&e.jsx("div",{style:{position:"absolute",top:0,left:"-25px",right:"-25px",bottom:"-16px"},children:e.jsx("div",{style:{position:"absolute",width:"100%",height:"100%",pointerEvents:"auto"},children:$e})}),!$&&!X&&e.jsx("div",{style:{backgroundColor:m.mode==="light"?"#fef3c7":`${m.colors.warning||"#f59e0b"}20`,border:`1px solid ${m.mode==="light"?"#fcd34d":m.colors.warning||"#f59e0b"}`,borderRadius:m.borderRadius.md,padding:m.spacing.md,marginBottom:m.spacing.md,textAlign:"center"}}),e.jsxs("div",{style:{marginBottom:"16px"},children:[e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:"10px"},children:e.jsx("label",{style:{fontSize:"12px",fontWeight:590,color:m.mode==="light"?"#374151":"#d1d5db"},children:"Withdraw To"})}),e.jsx("div",{style:{display:"flex",gap:"12px",flexWrap:"wrap"},children:Fo.map(Y=>{const te=N===Y.id,Fe=Y.id==="external"?A:w,De=Fe?`${Fe.slice(0,6)}...${Fe.slice(-4)}`:null;return e.jsxs("button",{onClick:()=>oe(Y.id),onMouseEnter:()=>ae(Y.id),onMouseLeave:()=>{ae(null),he(null)},onMouseDown:()=>he(Y.id),onMouseUp:()=>he(null),style:{padding:"8px 12px",borderRadius:"8px",border:`1px solid ${te?"#EA4B4B7A":se===Y.id?"#F4A5A5":m.mode==="light"?"#e5e7eb":"#374151"}`,backgroundColor:te?m.mode==="light"?"#FEF2F2":"#451a1a":Z===Y.id?m.mode==="light"?"#f5f5f5":"#2d2d2d":se===Y.id?m.mode==="light"?"#fafafa":"#333333":m.mode==="light"?"white":"#1f1f1f",cursor:"pointer",display:"flex",flexDirection:"column",alignItems:"flex-start",gap:"4px",transition:"all 150ms ease",transform:Z===Y.id?"scale(0.96)":se===Y.id?"translateY(-1px)":"none",boxShadow:te?"0 0 0 3px #FBDBDB":Z===Y.id?"0 1px 2px rgba(0, 0, 0, 0.05)":se===Y.id?"0 4px 8px rgba(0, 0, 0, 0.1)":"none"},children:[e.jsx("span",{style:{fontSize:"14px",fontWeight:510,color:m.mode==="light"?"#3C3E42":"#e5e7eb"},children:Y.label}),De&&e.jsx("span",{style:{fontSize:"10px",fontWeight:500,color:m.mode==="light"?"#939291":"#6b7280",fontFamily:'"IBM Plex Mono", monospace'},children:De})]},Y.id)})})]}),e.jsx("div",{style:{marginBottom:m.spacing.sm},children:e.jsx(ht,{assets:W,selectedAsset:I||void 0,onAssetSelect:Ie,onAmountChange:ce,loading:$,label:"Amount",showBalance:!0,showMaxButton:!0,theme:m,styles:i})}),ie&&e.jsx("div",{style:{backgroundColor:i?.errorMessage?.backgroundColor||(m.mode==="light"?"#fef2f2":`${i?.statusDisplay?.errorColor||m.colors.error}20`),border:`1px solid ${i?.errorMessage?.borderColor||(m.mode==="light"?"#fecaca":i?.statusDisplay?.errorColor||m.colors.error)}`,borderRadius:i?.errorMessage?.borderRadius||m.borderRadius.md,padding:i?.errorMessage?.padding||m.spacing.md,marginBottom:m.spacing.sm},children:e.jsx("p",{style:{color:i?.errorMessage?.color||i?.statusDisplay?.errorColor||m.colors.error,fontSize:i?.errorMessage?.fontSize||m.typography.fontSize.sm,fontWeight:i?.errorMessage?.fontWeight,fontFamily:i?.errorMessage?.fontFamily||m.typography.fontFamily,margin:0},children:ie})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:m.spacing.sm},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ze,onMouseEnter:()=>Ee(!0),onMouseLeave:()=>{Ee(!1),q(!1)},onMouseDown:()=>q(!0),onMouseUp:()=>q(!1),loading:ee,disabled:!K||!x,theme:m,styles:i,style:{width:"100%",padding:"8px",backgroundColor:K?R?"#d43d3d":ue?"#f05555":"#ea4b4b":"#d1d5db",color:K?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:K?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:K?R?"scale(0.98)":ue?"translateY(-2px)":"none":"none",boxShadow:R?"1px 1px 0px black":ue&&K?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:y?h?x?ee?"Executing Withdraw...":I?I.amount?parseFloat(I.amount)>I.asset.balanceFormatted?"Insufficient Balance":t.length===0?"No Withdraw Batches":T?"Execute Withdraw":`Set ${N==="external"?"External":"Embedded"} Wallet`:"Enter Amount":"Select Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})},Eo=({isOpen:t,onClose:o,title:r="Withdraw",maxWidth:n="480px",withdrawBatches:s,externalWithdrawBatches:c,tokens:i,supportedTokens:d,enableSpiceBalanceUpdate:g=!1,theme:f="light",styles:u,className:l,withdrawInputHook:C,defaultSelectedAsset:A,filterChains:w,withdrawMode:k,onWithdrawModeChange:p,externalWalletAddress:b,embeddedWalletAddress:m,onWithdrawSuccess:j,onWithdrawError:y})=>{const h=de.createTheme(f),x=S=>{j?.(S)};return e.jsx(xt,{isOpen:t,onClose:o,title:r,subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:"Withdraw your vault tokens to your external or embedded wallet."})]}),styles:u,theme:h,maxWidth:n,children:e.jsx("div",{style:{padding:"0 24px 24px 24px"},children:e.jsx(fs,{withdrawBatches:s,externalWithdrawBatches:c,tokens:i,supportedTokens:d,enableSpiceBalanceUpdate:g,theme:f,styles:{...u,container:{...u?.container,boxShadow:"none",borderColor:"transparent",padding:"0",backgroundColor:"transparent"}},className:l,withdrawInputHook:C,defaultSelectedAsset:A,filterChains:w,withdrawMode:k,onWithdrawModeChange:p,externalWalletAddress:b,embeddedWalletAddress:m,onWithdrawSuccess:x,onWithdrawError:y})})})};/**
|
|
43
|
+
`})]})})},Fo=[{id:"external",label:"External Wallet"},{id:"embedded",label:"Embedded Wallet"}],fs=({withdrawBatches:t,externalWithdrawBatches:o,tokens:r,supportedTokens:n,enableSpiceBalanceUpdate:s=!1,theme:c="light",styles:i,className:d="",withdrawInputHook:g,defaultSelectedAsset:f,filterChains:u,withdrawMode:l="external",onWithdrawModeChange:C,externalWalletAddress:A,embeddedWalletAddress:w,onWithdrawSuccess:k,onWithdrawError:p})=>{const b=de.createTheme(c),m={...b,typography:{...b.typography,fontFamily:i?.fontFamily||b.typography.fontFamily},colors:{...b.colors,primary:i?.primaryColor||b.colors.primary,primaryHover:i?.primaryColor?`${i.primaryColor}dd`:b.colors.primaryHover}},j=Lt(),{isReady:y,isAuthenticated:h,isConnected:x,address:S,provider:F,actions:B}=j,[I,G]=a.useState(()=>f?{asset:f,amount:""}:null),[P,_]=a.useState([]),[$,J]=a.useState(!1),[M,z]=a.useState(null),E=a.useMemo(()=>!r||r.length===0?[]:!n||n.length===0?r:r.filter(Y=>n.some(te=>te.toLowerCase()===Y.symbol.toLowerCase())),[r,n]),H=a.useCallback(async()=>{if(!E||E.length===0||!w){_([]);return}J(!0),z(null);try{const Y=await Promise.all(E.map(async te=>{try{const Fe=await Ve(te.chainId).readContract({address:te.address,abi:re.erc20Abi,functionName:"balanceOf",args:[w]}),De=parseFloat(re.formatUnits(Fe,te.decimals));return{address:te.address,symbol:te.symbol,name:te.name,decimals:te.decimals,chainId:te.chainId,balance:Fe,balanceFormatted:De,balanceUsd:0,isNative:!1,logoURI:te.logoURI}}catch(Fe){return console.error(`Failed to fetch balance for ${te.symbol}:`,Fe),{address:te.address,symbol:te.symbol,name:te.name,decimals:te.decimals,chainId:te.chainId,balance:BigInt(0),balanceFormatted:0,balanceUsd:0,isNative:!1,logoURI:te.logoURI}}}));_(Y)}catch(Y){console.error("Failed to fetch token balances:",Y),z(Y instanceof Error?Y.message:"Failed to fetch token balances")}finally{J(!1)}},[E,w]);a.useEffect(()=>{H()},[H]),a.useEffect(()=>{if(!E||E.length===0)return;const Y=setInterval(()=>{H()},3e4);return()=>clearInterval(Y)},[H,E]);const X=P.some(Y=>Y.balanceFormatted>0),[ee,U]=a.useState(!1),[ne,xe]=a.useState(null),[ue,Ee]=a.useState(!1),[R,q]=a.useState(!1),[pe,v]=a.useState(!1),[N,O]=a.useState(l),[se,ae]=a.useState(null),[Z,he]=a.useState(null),Ce=a.useRef(null),T=a.useMemo(()=>N==="external"?A:w,[N,A,w]),oe=a.useCallback(Y=>{O(Y),C?.(Y)},[C]),{intentStatus:le,startStatusPolling:Se,clearStatus:ve}=kt({checkStepStatus:(Y,te)=>we.checkStepStatus(Y,te)});a.useEffect(()=>{if(le?.overallStatus==="success"&&le.intentId&&Ce.current!==le.intentId&&I&&S){const Y=le.steps.find(te=>te.transactionHash);if(Y?.transactionHash)if(Ce.current=le.intentId,s){const te=re.parseUnits(I.amount,I.asset.decimals);we.submitSpiceDeposit({user:S,txHash:Y.transactionHash,sender:S,tokenAddress:I.asset.address,chainId:I.asset.chainId,amount:te.toString(),isDeposit:!1}).then(()=>{H()}).catch(()=>{Ce.current=null})}else H()}},[le,S,s]),a.useEffect(()=>{g&&g.assetAmount!==I?.amount&&I&&G({...I,amount:g.assetAmount})},[g?.assetAmount,I]);const ke=a.useCallback(()=>{xe(null)},[]),Ie=Y=>{G({asset:Y,amount:I?.amount||""}),ke()},ce=a.useCallback(Y=>{I&&(a.startTransition(()=>{G({...I,amount:Y}),ke()}),g&&g.setAssetAmount(Y))},[I,g,ke]),ze=async()=>{if(!(!I||!S||t.length===0)){if(!T){xe(`Please provide a ${N==="external"?"external":"embedded"} wallet address`);return}if(!y||!h){xe(`Please authenticate with ${F||"wallet provider"} to continue`);return}U(!0),xe(null),v(!0);try{const Y=N==="external"&&o?[...t,...o]:[...t],te=[...new Set(Y.map(ge=>ge.chainId))],Fe=[];for(const ge of te){const nt=Ve(ge),tt=pt(ge),ft=await Ye.getAccountNonce(S,nt),Ge=await B.signAuthorization({contractAddress:tt,chainId:ge,nonce:Number(ft)});Fe.push(Ge)}const De=Ye.hashChainBatches(Y),_e=Math.floor(Date.now()/1e3)+60*10,it=Ye.getIntentHash(0n,BigInt(_e),De),et=await B.signMessage({raw:it}),Ze=typeof et=="string"?et:et.signature;if(!Ze)throw new Error("Failed to sign intent authorization");const be={mode:"7702",signatureType:"ecdsa",signature:Ze,nbf:0,exp:_e,chainBatches:De.map(ge=>({hash:ge.hash,chainId:ge.chainId,tokenTransfers:[{from:"solver",to:S,token:"0x0000000000000000000000000000000000000000",amount:re.parseUnits("0.01",18)}],calls:ge.calls}))},Re=await we.createAction({user:S,chainAuthorizations:Fe.map(ge=>({...ge,r:ge.r,s:ge.s,yParity:ge.yParity,address:ge.address,chainId:Number(ge.chainId),nonce:Number(ge.nonce)})),intents:[be]});if(Re){const ge=Et(Y,Ge=>`Chain ${Ge}`),[nt,tt]=Re.intentIds[0].split("/"),ft=parseInt(tt||"0",10);Se(Re.intentIds[0],ge);for(let Ge=0;Ge<Y.length;Ge++)await we.executeStep(nt,ft,Ge,{action:"execute"})}}catch(Y){const te=Y instanceof Error?Y.message:"Withdraw failed";xe(te),p?.(te)}finally{U(!1)}}},W=a.useMemo(()=>{let Y=P;return u&&u.length>0&&(Y=Y.filter(te=>u.includes(te.chainId))),Y},[P,u]),K=I&&I.amount&&parseFloat(I.amount)>0&&parseFloat(I.amount)<=I.asset.balanceFormatted&&x&&!ee&&t.length>0&&!!T,ie=M||ne,me={backgroundColor:i?.container?.backgroundColor||i?.primaryBackground||m.colors.background,border:`1px solid ${i?.container?.borderColor||m.colors.border}`,borderRadius:i?.container?.borderRadius||m.borderRadius.lg,padding:i?.container?.padding||m.spacing.md,width:i?.container?.width||"100%",maxWidth:"28rem",minHeight:"200px",margin:"0 auto",color:m.colors.text,fontFamily:m.typography.fontFamily,boxShadow:i?.container?.boxShadow||(m.mode==="light"?"0 4px 6px -1px rgb(0 0 0 / 0.1)":"0 4px 6px -1px rgb(0 0 0 / 0.3)")},$e=le?e.jsx(qt,{type:"withdraw",isOpen:!!le&&le.overallStatus!=="processing",isProcessing:ee||le?.overallStatus==="processing",onRetryTx:()=>{ve(),v(!1),ze()},onNewTx:()=>{ve(),v(!1),G(null),Ce.current=null,H()},onClose:()=>{ve(),v(!1)},onComplete:()=>{ve(),v(!1),G(null),Ce.current=null,H()},results:le?.overallStatus==="success"||le?.overallStatus==="failed"?le.steps.map(Y=>({asset:{symbol:I?.asset.symbol||"Token",address:I?.asset.address||""},txHash:Y.transactionHash||"",success:Y.status==="success",amount:I?.amount})):void 0,chainName:I?st(t[t.length-1].chainId):"Network",explorerUrl:I?Wt(t[t.length-1].chainId,"").replace(/\/tx\/.*$/,""):void 0,theme:m}):null;return e.jsxs("div",{style:{...me,position:"relative"},className:d,children:[$e&&e.jsx("div",{style:{position:"absolute",top:0,left:"-25px",right:"-25px",bottom:"-16px"},children:e.jsx("div",{style:{position:"absolute",width:"100%",height:"100%",pointerEvents:"auto"},children:$e})}),!$&&!X&&e.jsx("div",{style:{backgroundColor:m.mode==="light"?"#fef3c7":`${m.colors.warning||"#f59e0b"}20`,border:`1px solid ${m.mode==="light"?"#fcd34d":m.colors.warning||"#f59e0b"}`,borderRadius:m.borderRadius.md,padding:m.spacing.md,marginBottom:m.spacing.md,textAlign:"center"}}),e.jsxs("div",{style:{marginBottom:"16px"},children:[e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:"10px"},children:e.jsx("label",{style:{fontSize:"12px",fontWeight:590,color:m.mode==="light"?"#374151":"#d1d5db"},children:"Withdraw To"})}),e.jsx("div",{style:{display:"flex",gap:"12px",flexWrap:"wrap"},children:Fo.map(Y=>{const te=N===Y.id,Fe=Y.id==="external"?A:w,De=Fe?`${Fe.slice(0,6)}...${Fe.slice(-4)}`:null;return e.jsxs("button",{onClick:()=>oe(Y.id),onMouseEnter:()=>ae(Y.id),onMouseLeave:()=>{ae(null),he(null)},onMouseDown:()=>he(Y.id),onMouseUp:()=>he(null),style:{padding:"8px 12px",borderRadius:"8px",border:`1px solid ${te?"#EA4B4B7A":se===Y.id?"#F4A5A5":m.mode==="light"?"#e5e7eb":"#374151"}`,backgroundColor:te?m.mode==="light"?"#FEF2F2":"#451a1a":Z===Y.id?m.mode==="light"?"#f5f5f5":"#2d2d2d":se===Y.id?m.mode==="light"?"#fafafa":"#333333":m.mode==="light"?"white":"#1f1f1f",cursor:"pointer",display:"flex",flexDirection:"column",alignItems:"flex-start",gap:"4px",transition:"all 150ms ease",transform:Z===Y.id?"scale(0.96)":se===Y.id?"translateY(-1px)":"none",boxShadow:te?"0 0 0 3px #FBDBDB":Z===Y.id?"0 1px 2px rgba(0, 0, 0, 0.05)":se===Y.id?"0 4px 8px rgba(0, 0, 0, 0.1)":"none"},children:[e.jsx("span",{style:{fontSize:"14px",fontWeight:510,color:m.mode==="light"?"#3C3E42":"#e5e7eb"},children:Y.label}),De&&e.jsx("span",{style:{fontSize:"10px",fontWeight:500,color:m.mode==="light"?"#939291":"#6b7280",fontFamily:'"IBM Plex Mono", monospace'},children:De})]},Y.id)})})]}),e.jsx("div",{style:{marginBottom:m.spacing.sm},children:e.jsx(ht,{assets:W,selectedAsset:I||void 0,onAssetSelect:Ie,onAmountChange:ce,loading:$,label:"Amount",showBalance:!0,showMaxButton:!0,theme:m,styles:i})}),ie&&e.jsx("div",{style:{backgroundColor:i?.errorMessage?.backgroundColor||(m.mode==="light"?"#fef2f2":`${i?.statusDisplay?.errorColor||m.colors.error}20`),border:`1px solid ${i?.errorMessage?.borderColor||(m.mode==="light"?"#fecaca":i?.statusDisplay?.errorColor||m.colors.error)}`,borderRadius:i?.errorMessage?.borderRadius||m.borderRadius.md,padding:i?.errorMessage?.padding||m.spacing.md,marginBottom:m.spacing.sm},children:e.jsx("p",{style:{color:i?.errorMessage?.color||i?.statusDisplay?.errorColor||m.colors.error,fontSize:i?.errorMessage?.fontSize||m.typography.fontSize.sm,fontWeight:i?.errorMessage?.fontWeight,fontFamily:i?.errorMessage?.fontFamily||m.typography.fontFamily,margin:0},children:ie})}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:m.spacing.sm},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ze,onMouseEnter:()=>Ee(!0),onMouseLeave:()=>{Ee(!1),q(!1)},onMouseDown:()=>q(!0),onMouseUp:()=>q(!1),loading:ee,disabled:!K||!x,theme:m,styles:i,style:{width:"100%",padding:"8px",backgroundColor:K?R?"#d43d3d":ue?"#f05555":"#ea4b4b":"#d1d5db",color:K?"#0e0d0b":"#6b7280",border:"1px solid #0e0d0b",fontWeight:500,fontSize:"18px",fontFamily:'"IBM Plex Mono", monospace',lineHeight:"156%",textTransform:"uppercase",cursor:K?"pointer":"not-allowed",marginTop:"20px",display:"flex",alignItems:"center",justifyContent:"center",gap:"10px",transition:"all 150ms ease",transform:K?R?"scale(0.98)":ue?"translateY(-2px)":"none":"none",boxShadow:R?"1px 1px 0px black":ue&&K?"5px 5px 0px white, 6px 6px 0px black":"3px 3px 0px white, 4px 4px 0px black"},children:y?h?x?ee?"Executing Withdraw...":I?I.amount?parseFloat(I.amount)>I.asset.balanceFormatted?"Insufficient Balance":t.length===0?"No Withdraw Batches":T?"Execute Withdraw":`Set ${N==="external"?"External":"Embedded"} Wallet`:"Enter Amount":"Select Token":"Wallet Not Connected":"Authentication Required":"Loading..."})})]})},Eo=({isOpen:t,onClose:o,title:r="Withdraw",maxWidth:n="480px",withdrawBatches:s,externalWithdrawBatches:c,tokens:i,supportedTokens:d,enableSpiceBalanceUpdate:g=!1,theme:f="light",styles:u,className:l,withdrawInputHook:C,defaultSelectedAsset:A,filterChains:w,withdrawMode:k,onWithdrawModeChange:p,externalWalletAddress:b,embeddedWalletAddress:m,onWithdrawSuccess:j,onWithdrawError:y})=>{const h=de.createTheme(f),x=S=>{j?.(S)};return e.jsx(xt,{isOpen:t,onClose:o,title:r,subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"5px",backgroundColor:"#f9fafb",border:"1px solid #ed6969",borderRadius:"8px",padding:"10px",margin:"0 0 0 0"},children:[e.jsx("img",{src:Pt,alt:"Info",style:{width:"14px",height:"14px",marginTop:"2px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"13px",color:"#374151",margin:0,lineHeight:"1.5"},children:"Withdraw your vault tokens to your external or embedded wallet."})]}),styles:u,theme:h,maxWidth:n,children:e.jsx("div",{style:{padding:"0 24px 24px 24px"},children:e.jsx(fs,{withdrawBatches:s,externalWithdrawBatches:c,tokens:i,supportedTokens:d,enableSpiceBalanceUpdate:g,theme:f,styles:{...u,container:{...u?.container,boxShadow:"none",borderColor:"transparent",padding:"0",backgroundColor:"transparent"}},className:l,withdrawInputHook:C,defaultSelectedAsset:A,filterChains:w,withdrawMode:k,onWithdrawModeChange:p,externalWalletAddress:b,embeddedWalletAddress:m,onWithdrawSuccess:x,onWithdrawError:y})})})};/**
|
|
44
44
|
* @license lucide-react v0.562.0 - ISC
|
|
45
45
|
*
|
|
46
46
|
* This source code is licensed under the ISC license.
|
|
@@ -75,7 +75,7 @@
|
|
|
75
75
|
*
|
|
76
76
|
* This source code is licensed under the ISC license.
|
|
77
77
|
* See the LICENSE file in the root directory of this source tree.
|
|
78
|
-
*/const Qo=[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]],Ho=Jt("x",Qo);var Cs="",As="";const ws=({title:t,onClose:o})=>e.jsxs("div",{style:{position:"relative",width:"100%"},children:[e.jsx("img",{src:t==="Connect Wallet"?As:Cs,style:{width:"100%",height:"auto",display:"block",borderRadius:"2px 2px 0 0"},alt:t==="Connect Wallet"?"Connect Wallet banner":"Network selector banner",onError:r=>{console.warn(`Failed to load banner: ${t==="Connect Wallet"?As:Cs}`);const n=r.target;n.style.display="none"}}),e.jsx("button",{onClick:o,style:{position:"absolute",color:"black",top:"15px",right:"15px",padding:"8px",backgroundColor:"transparent",borderRadius:"9999px",border:"none",cursor:"pointer",transition:"background-color 0.2s",display:"flex",alignItems:"center",justifyContent:"center",zIndex:1},children:e.jsx(Ho,{size:28,strokeWidth:2.5})})]});var qe="",rt="",vt="",Ss="",ks="",Uo="data:image/svg+xml,%3csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M4.51484 1.22476C5.04689 0.494255 5.87167 0 6.83333 0C7.79352 0 8.62302 0.493038 9.15721 1.22447C10.0512 1.08473 10.9879 1.32154 11.6665 2.00014C12.3456 2.67921 12.5823 3.61677 12.4419 4.51135C13.1714 5.04616 13.6667 5.87042 13.6667 6.83333C13.6667 7.79624 13.1714 8.62051 12.4419 9.15532C12.5823 10.0499 12.3456 10.9875 11.6665 11.6665C10.986 12.3471 10.049 12.5769 9.15858 12.4403C8.62445 13.1728 7.79434 13.6667 6.83333 13.6667C5.86959 13.6667 5.04474 13.1705 4.50996 12.44C3.619 12.5772 2.68116 12.3475 2.00014 11.6665C1.31939 10.9858 1.08903 10.0476 1.23037 9.15532C0.501138 8.62162 0 7.79824 0 6.83333C0 5.86843 0.501137 5.04504 1.23037 4.51135C1.08903 3.61904 1.31939 2.68089 2.00014 2.00014C2.67986 1.32042 3.61766 1.08457 4.51484 1.22476ZM9.20928 5.95387C9.51334 5.74624 9.59152 5.33144 9.38389 5.02737C9.17626 4.72331 8.76145 4.64514 8.45739 4.85277L8.3995 4.89229C7.48372 5.51764 6.69012 6.30153 6.05487 7.20477L5.30449 6.45518C5.044 6.19497 4.62189 6.1952 4.36168 6.45569C4.10147 6.71618 4.10169 7.13829 4.36218 7.3985L5.7 8.73489C5.84693 8.88167 6.05387 8.95158 6.25971 8.924C6.46555 8.89641 6.64677 8.77448 6.74987 8.5942C7.34322 7.55668 8.16436 6.6674 9.1514 5.9934L9.20928 5.95387Z' fill='%23EA4B4B'/%3e%3c/svg%3e";const To={11155111:qe,421614:vt,123420001114:rt,5115:Ss,84532:rt,688689:ks},Is=({isOpen:t,onClose:o,onChainSelect:r,supportedChains:n=[11155111,421614,5115,123420001114]})=>{const[s,c]=a.useState(""),[i,d]=a.useState(null),[g,f]=a.useState(null),[u,l]=a.useState(!1),[C,A]=a.useState(!1),[w,k]=a.useState(!1),[p,b]=a.useState(null),{switchChainAsync:m}=Ae.useSwitchChain();a.useEffect(()=>{const h=document.createElement("link");return h.href="https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@100;200;300;400;500;600;700&display=swap",h.rel="stylesheet",document.head.appendChild(h),()=>{document.head.removeChild(h)}},[]);const j=n.map(h=>{const x=fe(h);return x?{id:h.toString(),name:x.displayName,icon:To[h]||qe,chainId:h,verified:!0}:null}).filter(h=>h!==null).filter(h=>h.name.toLowerCase().includes(s.toLowerCase())),y=async()=>{if(!i)return;const h=parseInt(i,10);k(!0),b(null);try{await m({chainId:h}),r&&r(i),o()}catch(x){console.error("Failed to switch chain:",x),b(x instanceof Error?x.message:"Failed to switch chain")}finally{k(!1)}};return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"9px",width:"100%",padding:"5px 5px 5px 5px",display:"flex",flexDirection:"column",maxWidth:"522px",overflow:"hidden"},children:[e.jsx(ws,{title:"Select Chain",onClose:o}),e.jsx("div",{style:{padding:"24px 20px"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#FAFAFA",borderRadius:"4px",boxShadow:"0 2px 4px rgba(0, 0, 0, 0.1)",padding:"10px 5px",border:"1px solid #e5e7eb"},children:[e.jsx(Mo,{style:{color:"#9ca3af"},size:24}),e.jsx("input",{type:"text",placeholder:"Search chain name, symbol or address",value:s,onChange:h=>c(h.target.value),style:{flex:1,backgroundColor:"#FAFAFA",outline:"none",border:"none",color:"#374151",fontSize:"14px",fontWeight:"400"}}),e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"2px",color:"#999",fontSize:"14px",fontWeight:500,flexShrink:0},children:e.jsx("div",{style:{padding:"5px 5px",borderRadius:"3px",fontSize:"13px",backgroundColor:"#E9E9E9",color:"#485066"},children:"\u2318F"})}),e.jsx("button",{style:{color:"#9ca3af",fontSize:"20px",fontWeight:500,border:"none",background:"none",cursor:"pointer"}})]})}),e.jsx("div",{style:{padding:"0 32px 20px",display:"flex",flexDirection:"column",gap:"12px"},children:j.map(h=>e.jsxs("button",{onClick:()=>d(h.id),onMouseEnter:()=>f(h.id),onMouseLeave:()=>f(null),style:{width:"100%",display:"flex",alignItems:"center",gap:"16px",padding:"8px",borderRadius:"8px",backgroundColor:i===h.id?"#FBDBDB":"transparent",border:i===h.id||g===h.id?"1px solid #F4A5A5":"1px solid transparent",cursor:"pointer",transition:"all 0.2s"},children:[e.jsx("div",{style:{width:"40px",height:"40px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"30px"},children:e.jsx("img",{src:h.icon,alt:h.name,style:{width:"100%",height:"100%",borderRadius:"50%"}})}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",flex:1},children:[e.jsx("span",{className:"ibm-plex-mono-medium",style:{fontFamily:'"IBM Plex Mono", monospace',fontSize:"17px",fontWeight:500,letterSpacing:"0.4px",color:"#111827",textAlign:"left"},children:h.name}),h.verified&&e.jsx("img",{src:Uo,alt:"Verified",style:{width:"16px",height:"16px"}})]})]},h.id))}),e.jsx("div",{style:{padding:"0 25px 25px"},children:e.jsxs("button",{onClick:y,onMouseEnter:()=>l(!0),onMouseLeave:()=>{l(!1),A(!1)},onMouseDown:()=>A(!0),onMouseUp:()=>A(!1),disabled:!i||w,style:{width:"100%",padding:"10px",borderRadius:"8px",boxShadow:C?"0 1px 2px rgba(0, 0, 0, 0.1)":u?"0 4px 8px rgba(0, 0, 0, 0.15)":"0 2px 4px rgba(0, 0, 0, 0.1)",fontWeight:500,fontSize:"16px",transition:"all 0.2s",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",backgroundColor:C?"#f0f0f0":u?"#fafafa":"white",border:u?"1px solid #F4A5A5":"1px solid #00000029",color:"black",cursor:i&&!w?"pointer":"not-allowed",transform:C?"scale(0.98)":u?"translateY(-1px)":"none"},children:["SELECT",e.jsx(bs,{size:20})]})})]})}):null};var Fs="",Zt="",zo="";const Vo={metamask:Fs,metaMask:Fs,rabby:Zt,phantom:zo},No={11155111:qe,421614:vt,123420001114:rt,5115:Ss,84532:rt,688689:ks},Es=({isOpen:t,onClose:o,onWalletSelect:r,onContinue:n,requiredChainId:s})=>{const[c]=a.useState(""),[i,d]=a.useState(null),[g,f]=a.useState(!1),[u,l]=a.useState(null),[C,A]=a.useState(!1),[w,k]=a.useState(null),[p,b]=a.useState("idle"),[m,j]=a.useState(null),[y,h]=a.useState(!1);a.useEffect(()=>{const R=document.createElement("link");return R.href="https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@100;200;300;400;500;600;700&display=swap",R.rel="stylesheet",document.head.appendChild(R),()=>{document.head.removeChild(R)}},[]),a.useEffect(()=>{t||(l(null),A(!1),f(!1),k(null),h(!1))},[t]);const{address:x,isConnected:S,chain:F,connector:B}=Ae.useAccount(),{connectors:I,connect:G}=Ae.useConnect(),{disconnect:P}=Ae.useDisconnect(),{switchChainAsync:_}=Ae.useSwitchChain(),$=a.useRef(new Map),J=a.useCallback(async R=>{if($.current.has(R)){const q=$.current.get(R);b(q?"eligible":"ineligible"),h(!q);return}b("checking"),j(null);try{const q=await fetch(`https://portal-api.spicenet.io/api/v1/devnet/eligibility/admin?address=${R}`,{method:"GET",headers:{"Content-Type":"application/json","X-Api-Key":"c1820ce3-48ef-497d-8f17-ea80d0b4a608"}});if(!q.ok)throw new Error(`Eligibility check failed with status ${q.status}`);const pe=(await q.json())?.isEligible||!1;$.current.set(R,pe),b(pe?"eligible":"ineligible"),h(!pe)}catch(q){console.error("Eligibility check failed:",q),b("error"),j("Could not verify eligibility. Please retry.")}},[]);a.useEffect(()=>{t&&S&&x&&J(x)},[t,S,x,J]);const M=a.useRef(F);a.useEffect(()=>{M.current=F},[F]);const z=s?fe(s):null,E=s&&No[s]||qe,U=z?.displayName||F?.name||`Chain ${F?.id||s}`,X=R=>typeof R.ready=="boolean"?R.ready:!0,ee=I.filter(R=>{const q=R.name.toLowerCase();if(!q.includes(c.toLowerCase()))return!1;const pe=R.type==="injected"||(R.id||"").toLowerCase().includes("metamask")||q.includes("metamask");return R.type==="walletConnect"?!!R?.options?.projectId:pe?X(R):!1}),H=async R=>{if(!(C||g))try{if(A(!0),k(R.uid),l(null),await G({connector:R}),await new Promise(q=>setTimeout(q,500)),r&&r(R.id),s){f(!0);try{if(F?.id!==s){await _({chainId:s});let q=0;const pe=20;for(;q<pe;){if(await new Promise(v=>setTimeout(v,100)),M.current?.id===s){l(null);break}q++}M.current?.id!==s&&l("Please switch to the correct network in your wallet to continue.")}}catch(q){console.error("Chain switch error:",q),q.code===4902||q.name==="ChainNotConfiguredError"?l("This network is not configured in your wallet. Please add it manually to continue."):q.code===4001?l("Network switch cancelled. Please switch manually in your wallet to continue."):l("Unable to switch network. Please switch manually in your wallet to continue.")}finally{f(!1)}}await new Promise(q=>setTimeout(q,800)),x&&J(x)}catch(q){console.error("Connection error:",q),q?.code===4001||q?.message?.includes("rejected")?l("Connection rejected. Please try again."):l(`Failed to connect: ${q?.message||"Unknown error"}`)}finally{A(!1),k(null)}},ne=R=>{if(R.icon)return R.icon;const q=R.name.toLowerCase();for(const[pe,v]of Object.entries(Vo))if(q.includes(pe.toLowerCase()))return v;return null},xe=async()=>{if(!(!s||g)){f(!0),l(null);try{await _({chainId:s});let R=0;const q=20;for(;R<q;){if(await new Promise(pe=>setTimeout(pe,100)),M.current?.id===s){l(null);break}R++}M.current?.id!==s&&l("Unable to switch to the correct network. Please switch manually in your wallet to continue.")}catch(R){console.error("Manual chain switch error:",R),R.code===4902||R.name==="ChainNotConfiguredError"?l("This network is not configured in your wallet. Please add it manually to continue."):R.code===4001?l("Network switch cancelled. Please switch manually in your wallet to continue."):l("Unable to switch network. Please switch manually in your wallet to continue.")}finally{f(!1)}}},ue=S&&!g&&!C&&p==="eligible"&&(!s||F?.id===s),Ee=S&&!g&&!C&&p==="eligible"&&s&&F?.id!==s;return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"12px",width:"100%",padding:"5px",display:"flex",flexDirection:"column",maxWidth:"522px"},children:[e.jsx(ws,{title:"Connect Wallet",onClose:o}),s===421614&&!S&&e.jsx("div",{style:{padding:"0 32px",marginTop:"20px"},children:e.jsxs("div",{style:{padding:"12px 16px",backgroundColor:"#EFF6FF",borderRadius:"8px",border:"1px solid #BFDBFE",display:"flex",alignItems:"center",gap:"10px"},children:[e.jsx("div",{style:{width:"32px",height:"32px",borderRadius:"50%",backgroundColor:"#DBEAFE",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("img",{src:Zt,alt:"Rabby",style:{width:"20px",height:"20px",objectFit:"contain"}})}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{margin:"0 0 4px 0",color:"#1E40AF",fontSize:"13px",fontWeight:600},children:"Recommended Wallet"}),e.jsx("p",{style:{margin:0,color:"#1E3A8A",fontSize:"12px",lineHeight:"1.4"},children:"For Arbitrum Sepolia, we recommend using Rabby wallet instead of MetaMask for the best experience."})]})]})}),e.jsxs("div",{style:{padding:"0 32px 20px",display:"flex",flexDirection:"column",gap:"12px",marginTop:"20px"},children:[u&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:[e.jsx("p",{style:{margin:"0 0 10px 0",color:"#92400e",fontSize:"14px"},children:u}),e.jsx("button",{onClick:xe,disabled:g,style:{width:"100%",padding:"8px 12px",borderRadius:"6px",border:"1px solid #fbbf24",backgroundColor:"white",cursor:g?"not-allowed":"pointer",fontWeight:600,fontSize:"13px",color:"#92400e",opacity:g?.6:1},children:g?"Switching...":"Try Switch Again"})]}),g&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#dbeafe",borderRadius:"8px",display:"flex",alignItems:"center",gap:"10px",marginTop:"20px"},children:[e.jsx("div",{style:{width:"20px",height:"20px",border:"2px solid #3b82f6",borderTopColor:"transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsx("p",{style:{margin:0,color:"#1e40af",fontSize:"14px"},children:"Switching network..."})]}),S&&p==="checking"&&e.jsx("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:e.jsxs("p",{style:{margin:0,color:"#92400e",fontSize:"14px"},children:["Checking eligibility for ",x?.slice(0,6),"..."]})}),S&&p==="error"&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef2f2",borderRadius:"8px",border:"1px solid #fecdd3"},children:[e.jsx("p",{style:{margin:0,color:"#b91c1c",fontSize:"14px"},children:m||"Eligibility check failed. Please try again."}),e.jsx("button",{onClick:()=>x&&J(x),style:{marginTop:"10px",padding:"8px 12px",borderRadius:"6px",border:"1px solid #e5e7eb",backgroundColor:"white",cursor:"pointer",fontWeight:600},children:"Retry eligibility check"})]}),S&&s===421614&&B&&(B.name.toLowerCase().includes("metamask")||B.type==="injected")&&e.jsxs("div",{style:{padding:"12px 16px",backgroundColor:"#EFF6FF",borderRadius:"8px",border:"1px solid #BFDBFE",display:"flex",alignItems:"center",gap:"10px"},children:[e.jsx("div",{style:{width:"32px",height:"32px",borderRadius:"50%",backgroundColor:"#DBEAFE",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("img",{src:Zt,alt:"Rabby",style:{width:"20px",height:"20px",objectFit:"contain"}})}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{margin:"0 0 4px 0",color:"#1E40AF",fontSize:"13px",fontWeight:600},children:"Recommended Wallet"}),e.jsx("p",{style:{margin:0,color:"#1E3A8A",fontSize:"12px",lineHeight:"1.4"},children:"For Arbitrum Sepolia, we recommend using Rabby wallet instead of MetaMask for the best experience."})]})]}),S&&x?e.jsxs("div",{style:{border:"1px solid #02974F",borderRadius:"8px",overflow:"hidden",marginTop:"20px"},children:[e.jsxs("div",{style:{backgroundColor:"#00FFA81C",padding:"14px 18px",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx("div",{style:{width:"22px",height:"22px",borderRadius:"50%",backgroundColor:"#02974F",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"14px",fontWeight:"bold"},children:"\u2713"}),e.jsx("span",{className:"ibm-plex-mono",style:{color:"#02974F",fontWeight:600,fontSize:"14px",letterSpacing:"0.5px"},children:"WALLET CONNECTED"})]}),e.jsx("div",{style:{width:"38px",height:"38px",borderRadius:"50%",backgroundColor:"#f3f4f6",display:"flex",alignItems:"center",justifyContent:"center",overflow:"hidden"},children:B&&ne(B)?e.jsx("img",{src:ne(B),alt:B.name,style:{width:"24px",height:"24px",objectFit:"contain"}}):e.jsx("span",{style:{fontSize:"16px",fontWeight:"bold"},children:B?.name?.charAt(0)||"W"})})]}),e.jsxs("div",{style:{padding:"18px",backgroundColor:"white"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"14px"},children:[e.jsx("span",{className:"ibm-plex-mono",style:{color:"#939291",fontSize:"13px",fontWeight:500,letterSpacing:"0.3px"},children:"ADDRESS:"}),e.jsxs("span",{className:"ibm-plex-mono",style:{color:"black",fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.3px"},children:[x.slice(0,6),"...",x.slice(-4)]})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"16px"},children:[e.jsx("span",{className:"ibm-plex-mono",style:{color:"#939291",fontSize:"13px",fontWeight:500,letterSpacing:"0.3px"},children:"NETWORK:"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[e.jsx("img",{src:E,alt:U,style:{width:"20px",height:"20px",borderRadius:"50%",objectFit:"contain"}}),e.jsx("span",{style:{color:"black",fontSize:"14px",fontWeight:500},children:U}),s&&F?.id===s?e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#02974F",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"10px",fontWeight:"bold"},children:"\u2713"}):s?e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#EF4444",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"10px",fontWeight:"bold"},children:"!"}):null,e.jsx("button",{onClick:xe,disabled:g,style:{background:"none",border:"none",color:"#3C3E42",fontSize:"11px",fontWeight:500,textDecoration:"underline",cursor:g?"not-allowed":"pointer",padding:0,marginLeft:"4px",opacity:g?.6:1},children:g?"Switching...":"Switch"})]})]}),e.jsxs("button",{className:"ibm-plex-mono",onClick:()=>{P(),l(null)},style:{width:"100%",padding:"10px",backgroundColor:"transparent",border:"1px solid #E5E7EB",borderRadius:"6px",cursor:"pointer",fontSize:"13px",fontWeight:500,color:"#9CA3AF",display:"flex",alignItems:"center",justifyContent:"center",gap:"6px"},children:[e.jsx("span",{style:{fontSize:"16px"},children:"\u27F2"}),"DISCONNECT"]})]})]}):ee.map(R=>{const q=X(R),pe=w===R.uid,v=!q||C||pe;return e.jsxs("button",{onClick:()=>{v||H(R)},onMouseEnter:()=>!v&&d(R.uid),onMouseLeave:()=>d(null),disabled:v,style:{width:"100%",display:"flex",alignItems:"center",gap:"14px",padding:"10px",borderRadius:"8px",backgroundColor:pe?"#f3f4f6":"transparent",border:i===R.uid&&!v?"2px solid #F4A5A5":"2px solid transparent",cursor:v?"not-allowed":"pointer",opacity:v?.6:1,transition:"all 0.2s"},children:[e.jsx("div",{style:{width:"40px",height:"40px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"#f3f4f6"},children:ne(R)?e.jsx("img",{src:ne(R),alt:R.name,style:{width:"26px",height:"26px",objectFit:"contain"}}):e.jsx("span",{style:{fontSize:"16px",fontWeight:"bold"},children:R.name.charAt(0)})}),e.jsxs("span",{className:"ibm-plex-mono",style:{fontSize:"17px",fontWeight:500,letterSpacing:"0.4px",color:v?"#9ca3af":"#111827",flex:1,textAlign:"left",fontFamily:'"IBM Plex Mono", monospace'},children:[pe?"Connecting...":R.name,!q&&!pe&&e.jsx("span",{style:{fontSize:"12px",marginLeft:"8px"},children:"(Not detected)"})]})]},R.uid)})]}),Ee&&!u&&e.jsx("div",{style:{padding:"0 25px 20px"},children:e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:[e.jsxs("p",{style:{margin:"0 0 10px 0",color:"#92400e",fontSize:"14px"},children:["Please switch to ",U," to continue."]}),e.jsx("button",{onClick:xe,disabled:g,style:{width:"100%",padding:"8px 12px",borderRadius:"6px",border:"1px solid #fbbf24",backgroundColor:"white",cursor:g?"not-allowed":"pointer",fontWeight:600,fontSize:"13px",color:"#92400e",opacity:g?.6:1},children:g?"Switching...":"Switch Network"})]})}),e.jsx("div",{style:{padding:"0 25px 25px"},children:e.jsxs("button",{onClick:async()=>{ue&&(await new Promise(R=>setTimeout(R,300)),n?await n():o())},disabled:!ue,style:{width:"100%",padding:"10px",borderRadius:"8px",boxShadow:"0 2px 4px rgba(0, 0, 0, 0.1)",fontWeight:600,fontSize:"16px",transition:"all 0.2s",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",backgroundColor:ue?"white":"#f3f4f6",border:"1px solid #00000029",color:ue?"black":"#9ca3af",cursor:ue?"pointer":"not-allowed"},children:[C?"CONNECTING...":g?"SWITCHING NETWORK...":p==="checking"?"CHECKING ELIGIBILITY...":"CONTINUE",e.jsx(bs,{size:20})]})}),y&&e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.55)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:60},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"12px",padding:"28px",width:"100%",maxWidth:"420px",textAlign:"center",boxShadow:"0 20px 60px rgba(0, 0, 0, 0.18)"},children:[e.jsx("p",{className:"ibm-plex-mono",style:{fontSize:"14px",fontWeight:600,letterSpacing:"0.4px",color:"#EF4444",marginBottom:"10px"},children:"ACCESS BLOCKED"}),e.jsx("h3",{style:{margin:"0 0 12px",fontSize:"22px",fontWeight:700},children:"Sorry, you're not eligible"}),e.jsx("p",{style:{margin:"0 0 18px",color:"#4B5563"},children:"This wallet does not meet the eligibility requirements to deposit assets."}),e.jsx("button",{onClick:()=>{P(),l(null),h(!1),b("idle"),j(null),$.current.clear(),o()},style:{width:"100%",padding:"12px",borderRadius:"8px",border:"none",backgroundColor:"#111827",color:"white",fontWeight:600,cursor:"pointer"},children:"Disconnect wallet"})]})}),e.jsx("style",{children:`
|
|
78
|
+
*/const Qo=[["path",{d:"M18 6 6 18",key:"1bl5f8"}],["path",{d:"m6 6 12 12",key:"d8bk6v"}]],Uo=Jt("x",Qo);var Cs="",As="";const ws=({title:t,onClose:o})=>e.jsxs("div",{style:{position:"relative",width:"100%"},children:[e.jsx("img",{src:t==="Connect Wallet"?As:Cs,style:{width:"100%",height:"auto",display:"block",borderRadius:"2px 2px 0 0"},alt:t==="Connect Wallet"?"Connect Wallet banner":"Network selector banner",onError:r=>{console.warn(`Failed to load banner: ${t==="Connect Wallet"?As:Cs}`);const n=r.target;n.style.display="none"}}),e.jsx("button",{onClick:o,style:{position:"absolute",color:"black",top:"15px",right:"15px",padding:"8px",backgroundColor:"transparent",borderRadius:"9999px",border:"none",cursor:"pointer",transition:"background-color 0.2s",display:"flex",alignItems:"center",justifyContent:"center",zIndex:1},children:e.jsx(Uo,{size:28,strokeWidth:2.5})})]});var qe="",at="",vt="",Ss="",ks="",Ho="data:image/svg+xml,%3csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M4.51484 1.22476C5.04689 0.494255 5.87167 0 6.83333 0C7.79352 0 8.62302 0.493038 9.15721 1.22447C10.0512 1.08473 10.9879 1.32154 11.6665 2.00014C12.3456 2.67921 12.5823 3.61677 12.4419 4.51135C13.1714 5.04616 13.6667 5.87042 13.6667 6.83333C13.6667 7.79624 13.1714 8.62051 12.4419 9.15532C12.5823 10.0499 12.3456 10.9875 11.6665 11.6665C10.986 12.3471 10.049 12.5769 9.15858 12.4403C8.62445 13.1728 7.79434 13.6667 6.83333 13.6667C5.86959 13.6667 5.04474 13.1705 4.50996 12.44C3.619 12.5772 2.68116 12.3475 2.00014 11.6665C1.31939 10.9858 1.08903 10.0476 1.23037 9.15532C0.501138 8.62162 0 7.79824 0 6.83333C0 5.86843 0.501137 5.04504 1.23037 4.51135C1.08903 3.61904 1.31939 2.68089 2.00014 2.00014C2.67986 1.32042 3.61766 1.08457 4.51484 1.22476ZM9.20928 5.95387C9.51334 5.74624 9.59152 5.33144 9.38389 5.02737C9.17626 4.72331 8.76145 4.64514 8.45739 4.85277L8.3995 4.89229C7.48372 5.51764 6.69012 6.30153 6.05487 7.20477L5.30449 6.45518C5.044 6.19497 4.62189 6.1952 4.36168 6.45569C4.10147 6.71618 4.10169 7.13829 4.36218 7.3985L5.7 8.73489C5.84693 8.88167 6.05387 8.95158 6.25971 8.924C6.46555 8.89641 6.64677 8.77448 6.74987 8.5942C7.34322 7.55668 8.16436 6.6674 9.1514 5.9934L9.20928 5.95387Z' fill='%23EA4B4B'/%3e%3c/svg%3e";const To={11155111:qe,421614:vt,123420001114:at,5115:Ss,84532:at,688689:ks},Is=({isOpen:t,onClose:o,onChainSelect:r,supportedChains:n=[11155111,421614,5115,123420001114]})=>{const[s,c]=a.useState(""),[i,d]=a.useState(null),[g,f]=a.useState(null),[u,l]=a.useState(!1),[C,A]=a.useState(!1),[w,k]=a.useState(!1),[p,b]=a.useState(null),{switchChainAsync:m}=Ae.useSwitchChain();a.useEffect(()=>{const h=document.createElement("link");return h.href="https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@100;200;300;400;500;600;700&display=swap",h.rel="stylesheet",document.head.appendChild(h),()=>{document.head.removeChild(h)}},[]);const j=n.map(h=>{const x=fe(h);return x?{id:h.toString(),name:x.displayName,icon:To[h]||qe,chainId:h,verified:!0}:null}).filter(h=>h!==null).filter(h=>h.name.toLowerCase().includes(s.toLowerCase())),y=async()=>{if(!i)return;const h=parseInt(i,10);k(!0),b(null);try{await m({chainId:h}),r&&r(i),o()}catch(x){console.error("Failed to switch chain:",x),b(x instanceof Error?x.message:"Failed to switch chain")}finally{k(!1)}};return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"9px",width:"100%",padding:"5px 5px 5px 5px",display:"flex",flexDirection:"column",maxWidth:"522px",overflow:"hidden"},children:[e.jsx(ws,{title:"Select Chain",onClose:o}),e.jsx("div",{style:{padding:"24px 20px"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#FAFAFA",borderRadius:"4px",boxShadow:"0 2px 4px rgba(0, 0, 0, 0.1)",padding:"10px 5px",border:"1px solid #e5e7eb"},children:[e.jsx(Mo,{style:{color:"#9ca3af"},size:24}),e.jsx("input",{type:"text",placeholder:"Search chain name, symbol or address",value:s,onChange:h=>c(h.target.value),style:{flex:1,backgroundColor:"#FAFAFA",outline:"none",border:"none",color:"#374151",fontSize:"14px",fontWeight:"400"}}),e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"2px",color:"#999",fontSize:"14px",fontWeight:500,flexShrink:0},children:e.jsx("div",{style:{padding:"5px 5px",borderRadius:"3px",fontSize:"13px",backgroundColor:"#E9E9E9",color:"#485066"},children:"\u2318F"})}),e.jsx("button",{style:{color:"#9ca3af",fontSize:"20px",fontWeight:500,border:"none",background:"none",cursor:"pointer"}})]})}),e.jsx("div",{style:{padding:"0 32px 20px",display:"flex",flexDirection:"column",gap:"12px"},children:j.map(h=>e.jsxs("button",{onClick:()=>d(h.id),onMouseEnter:()=>f(h.id),onMouseLeave:()=>f(null),style:{width:"100%",display:"flex",alignItems:"center",gap:"16px",padding:"8px",borderRadius:"8px",backgroundColor:i===h.id?"#FBDBDB":"transparent",border:i===h.id||g===h.id?"1px solid #F4A5A5":"1px solid transparent",cursor:"pointer",transition:"all 0.2s"},children:[e.jsx("div",{style:{width:"40px",height:"40px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"30px"},children:e.jsx("img",{src:h.icon,alt:h.name,style:{width:"100%",height:"100%",borderRadius:"50%"}})}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",flex:1},children:[e.jsx("span",{className:"ibm-plex-mono-medium",style:{fontFamily:'"IBM Plex Mono", monospace',fontSize:"17px",fontWeight:500,letterSpacing:"0.4px",color:"#111827",textAlign:"left"},children:h.name}),h.verified&&e.jsx("img",{src:Ho,alt:"Verified",style:{width:"16px",height:"16px"}})]})]},h.id))}),e.jsx("div",{style:{padding:"0 25px 25px"},children:e.jsxs("button",{onClick:y,onMouseEnter:()=>l(!0),onMouseLeave:()=>{l(!1),A(!1)},onMouseDown:()=>A(!0),onMouseUp:()=>A(!1),disabled:!i||w,style:{width:"100%",padding:"10px",borderRadius:"8px",boxShadow:C?"0 1px 2px rgba(0, 0, 0, 0.1)":u?"0 4px 8px rgba(0, 0, 0, 0.15)":"0 2px 4px rgba(0, 0, 0, 0.1)",fontWeight:500,fontSize:"16px",transition:"all 0.2s",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",backgroundColor:C?"#f0f0f0":u?"#fafafa":"white",border:u?"1px solid #F4A5A5":"1px solid #00000029",color:"black",cursor:i&&!w?"pointer":"not-allowed",transform:C?"scale(0.98)":u?"translateY(-1px)":"none"},children:["SELECT",e.jsx(bs,{size:20})]})})]})}):null};var Fs="",Zt="",zo="";const Vo={metamask:Fs,metaMask:Fs,rabby:Zt,phantom:zo},No={11155111:qe,421614:vt,123420001114:at,5115:Ss,84532:at,688689:ks},Es=({isOpen:t,onClose:o,onWalletSelect:r,onContinue:n,requiredChainId:s})=>{const[c]=a.useState(""),[i,d]=a.useState(null),[g,f]=a.useState(!1),[u,l]=a.useState(null),[C,A]=a.useState(!1),[w,k]=a.useState(null),[p,b]=a.useState("idle"),[m,j]=a.useState(null),[y,h]=a.useState(!1);a.useEffect(()=>{const R=document.createElement("link");return R.href="https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@100;200;300;400;500;600;700&display=swap",R.rel="stylesheet",document.head.appendChild(R),()=>{document.head.removeChild(R)}},[]),a.useEffect(()=>{t||(l(null),A(!1),f(!1),k(null),h(!1))},[t]);const{address:x,isConnected:S,chain:F,connector:B}=Ae.useAccount(),{connectors:I,connect:G}=Ae.useConnect(),{disconnect:P}=Ae.useDisconnect(),{switchChainAsync:_}=Ae.useSwitchChain(),$=a.useRef(new Map),J=a.useCallback(async R=>{if($.current.has(R)){const q=$.current.get(R);b(q?"eligible":"ineligible"),h(!q);return}b("checking"),j(null);try{const q=await fetch(`https://portal-api.spicenet.io/api/v1/devnet/eligibility/admin?address=${R}`,{method:"GET",headers:{"Content-Type":"application/json","X-Api-Key":"c1820ce3-48ef-497d-8f17-ea80d0b4a608"}});if(!q.ok)throw new Error(`Eligibility check failed with status ${q.status}`);const pe=(await q.json())?.isEligible||!1;$.current.set(R,pe),b(pe?"eligible":"ineligible"),h(!pe)}catch(q){console.error("Eligibility check failed:",q),b("error"),j("Could not verify eligibility. Please retry.")}},[]);a.useEffect(()=>{t&&S&&x&&J(x)},[t,S,x,J]);const M=a.useRef(F);a.useEffect(()=>{M.current=F},[F]);const z=s?fe(s):null,E=s&&No[s]||qe,H=z?.displayName||F?.name||`Chain ${F?.id||s}`,X=R=>typeof R.ready=="boolean"?R.ready:!0,ee=I.filter(R=>{const q=R.name.toLowerCase();if(!q.includes(c.toLowerCase()))return!1;const pe=R.type==="injected"||(R.id||"").toLowerCase().includes("metamask")||q.includes("metamask");return R.type==="walletConnect"?!!R?.options?.projectId:pe?X(R):!1}),U=async R=>{if(!(C||g))try{if(A(!0),k(R.uid),l(null),await G({connector:R}),await new Promise(q=>setTimeout(q,500)),r&&r(R.id),s){f(!0);try{if(F?.id!==s){await _({chainId:s});let q=0;const pe=20;for(;q<pe;){if(await new Promise(v=>setTimeout(v,100)),M.current?.id===s){l(null);break}q++}M.current?.id!==s&&l("Please switch to the correct network in your wallet to continue.")}}catch(q){console.error("Chain switch error:",q),q.code===4902||q.name==="ChainNotConfiguredError"?l("This network is not configured in your wallet. Please add it manually to continue."):q.code===4001?l("Network switch cancelled. Please switch manually in your wallet to continue."):l("Unable to switch network. Please switch manually in your wallet to continue.")}finally{f(!1)}}await new Promise(q=>setTimeout(q,800)),x&&J(x)}catch(q){console.error("Connection error:",q),q?.code===4001||q?.message?.includes("rejected")?l("Connection rejected. Please try again."):l(`Failed to connect: ${q?.message||"Unknown error"}`)}finally{A(!1),k(null)}},ne=R=>{if(R.icon)return R.icon;const q=R.name.toLowerCase();for(const[pe,v]of Object.entries(Vo))if(q.includes(pe.toLowerCase()))return v;return null},xe=async()=>{if(!(!s||g)){f(!0),l(null);try{await _({chainId:s});let R=0;const q=20;for(;R<q;){if(await new Promise(pe=>setTimeout(pe,100)),M.current?.id===s){l(null);break}R++}M.current?.id!==s&&l("Unable to switch to the correct network. Please switch manually in your wallet to continue.")}catch(R){console.error("Manual chain switch error:",R),R.code===4902||R.name==="ChainNotConfiguredError"?l("This network is not configured in your wallet. Please add it manually to continue."):R.code===4001?l("Network switch cancelled. Please switch manually in your wallet to continue."):l("Unable to switch network. Please switch manually in your wallet to continue.")}finally{f(!1)}}},ue=S&&!g&&!C&&p==="eligible"&&(!s||F?.id===s),Ee=S&&!g&&!C&&p==="eligible"&&s&&F?.id!==s;return t?e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.5)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:50},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"12px",width:"100%",padding:"5px",display:"flex",flexDirection:"column",maxWidth:"522px"},children:[e.jsx(ws,{title:"Connect Wallet",onClose:o}),s===421614&&!S&&e.jsx("div",{style:{padding:"0 32px",marginTop:"20px"},children:e.jsxs("div",{style:{padding:"12px 16px",backgroundColor:"#EFF6FF",borderRadius:"8px",border:"1px solid #BFDBFE",display:"flex",alignItems:"center",gap:"10px"},children:[e.jsx("div",{style:{width:"32px",height:"32px",borderRadius:"50%",backgroundColor:"#DBEAFE",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("img",{src:Zt,alt:"Rabby",style:{width:"20px",height:"20px",objectFit:"contain"}})}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{margin:"0 0 4px 0",color:"#1E40AF",fontSize:"13px",fontWeight:600},children:"Recommended Wallet"}),e.jsx("p",{style:{margin:0,color:"#1E3A8A",fontSize:"12px",lineHeight:"1.4"},children:"For Arbitrum Sepolia, we recommend using Rabby wallet instead of MetaMask for the best experience."})]})]})}),e.jsxs("div",{style:{padding:"0 32px 20px",display:"flex",flexDirection:"column",gap:"12px",marginTop:"20px"},children:[u&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:[e.jsx("p",{style:{margin:"0 0 10px 0",color:"#92400e",fontSize:"14px"},children:u}),e.jsx("button",{onClick:xe,disabled:g,style:{width:"100%",padding:"8px 12px",borderRadius:"6px",border:"1px solid #fbbf24",backgroundColor:"white",cursor:g?"not-allowed":"pointer",fontWeight:600,fontSize:"13px",color:"#92400e",opacity:g?.6:1},children:g?"Switching...":"Try Switch Again"})]}),g&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#dbeafe",borderRadius:"8px",display:"flex",alignItems:"center",gap:"10px",marginTop:"20px"},children:[e.jsx("div",{style:{width:"20px",height:"20px",border:"2px solid #3b82f6",borderTopColor:"transparent",borderRadius:"50%",animation:"spin 1s linear infinite"}}),e.jsx("p",{style:{margin:0,color:"#1e40af",fontSize:"14px"},children:"Switching network..."})]}),S&&p==="checking"&&e.jsx("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:e.jsxs("p",{style:{margin:0,color:"#92400e",fontSize:"14px"},children:["Checking eligibility for ",x?.slice(0,6),"..."]})}),S&&p==="error"&&e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef2f2",borderRadius:"8px",border:"1px solid #fecdd3"},children:[e.jsx("p",{style:{margin:0,color:"#b91c1c",fontSize:"14px"},children:m||"Eligibility check failed. Please try again."}),e.jsx("button",{onClick:()=>x&&J(x),style:{marginTop:"10px",padding:"8px 12px",borderRadius:"6px",border:"1px solid #e5e7eb",backgroundColor:"white",cursor:"pointer",fontWeight:600},children:"Retry eligibility check"})]}),S&&s===421614&&B&&(B.name.toLowerCase().includes("metamask")||B.type==="injected")&&e.jsxs("div",{style:{padding:"12px 16px",backgroundColor:"#EFF6FF",borderRadius:"8px",border:"1px solid #BFDBFE",display:"flex",alignItems:"center",gap:"10px"},children:[e.jsx("div",{style:{width:"32px",height:"32px",borderRadius:"50%",backgroundColor:"#DBEAFE",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("img",{src:Zt,alt:"Rabby",style:{width:"20px",height:"20px",objectFit:"contain"}})}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{margin:"0 0 4px 0",color:"#1E40AF",fontSize:"13px",fontWeight:600},children:"Recommended Wallet"}),e.jsx("p",{style:{margin:0,color:"#1E3A8A",fontSize:"12px",lineHeight:"1.4"},children:"For Arbitrum Sepolia, we recommend using Rabby wallet instead of MetaMask for the best experience."})]})]}),S&&x?e.jsxs("div",{style:{border:"1px solid #02974F",borderRadius:"8px",overflow:"hidden",marginTop:"20px"},children:[e.jsxs("div",{style:{backgroundColor:"#00FFA81C",padding:"14px 18px",display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx("div",{style:{width:"22px",height:"22px",borderRadius:"50%",backgroundColor:"#02974F",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"14px",fontWeight:"bold"},children:"\u2713"}),e.jsx("span",{className:"ibm-plex-mono",style:{color:"#02974F",fontWeight:600,fontSize:"14px",letterSpacing:"0.5px"},children:"WALLET CONNECTED"})]}),e.jsx("div",{style:{width:"38px",height:"38px",borderRadius:"50%",backgroundColor:"#f3f4f6",display:"flex",alignItems:"center",justifyContent:"center",overflow:"hidden"},children:B&&ne(B)?e.jsx("img",{src:ne(B),alt:B.name,style:{width:"24px",height:"24px",objectFit:"contain"}}):e.jsx("span",{style:{fontSize:"16px",fontWeight:"bold"},children:B?.name?.charAt(0)||"W"})})]}),e.jsxs("div",{style:{padding:"18px",backgroundColor:"white"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"14px"},children:[e.jsx("span",{className:"ibm-plex-mono",style:{color:"#939291",fontSize:"13px",fontWeight:500,letterSpacing:"0.3px"},children:"ADDRESS:"}),e.jsxs("span",{className:"ibm-plex-mono",style:{color:"black",fontSize:"14px",fontWeight:600,fontFamily:'"IBM Plex Mono", monospace',letterSpacing:"0.3px"},children:[x.slice(0,6),"...",x.slice(-4)]})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",marginBottom:"16px"},children:[e.jsx("span",{className:"ibm-plex-mono",style:{color:"#939291",fontSize:"13px",fontWeight:500,letterSpacing:"0.3px"},children:"NETWORK:"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[e.jsx("img",{src:E,alt:H,style:{width:"20px",height:"20px",borderRadius:"50%",objectFit:"contain"}}),e.jsx("span",{style:{color:"black",fontSize:"14px",fontWeight:500},children:H}),s&&F?.id===s?e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#02974F",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"10px",fontWeight:"bold"},children:"\u2713"}):s?e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#EF4444",display:"flex",alignItems:"center",justifyContent:"center",color:"white",fontSize:"10px",fontWeight:"bold"},children:"!"}):null,e.jsx("button",{onClick:xe,disabled:g,style:{background:"none",border:"none",color:"#3C3E42",fontSize:"11px",fontWeight:500,textDecoration:"underline",cursor:g?"not-allowed":"pointer",padding:0,marginLeft:"4px",opacity:g?.6:1},children:g?"Switching...":"Switch"})]})]}),e.jsxs("button",{className:"ibm-plex-mono",onClick:()=>{P(),l(null)},style:{width:"100%",padding:"10px",backgroundColor:"transparent",border:"1px solid #E5E7EB",borderRadius:"6px",cursor:"pointer",fontSize:"13px",fontWeight:500,color:"#9CA3AF",display:"flex",alignItems:"center",justifyContent:"center",gap:"6px"},children:[e.jsx("span",{style:{fontSize:"16px"},children:"\u27F2"}),"DISCONNECT"]})]})]}):ee.map(R=>{const q=X(R),pe=w===R.uid,v=!q||C||pe;return e.jsxs("button",{onClick:()=>{v||U(R)},onMouseEnter:()=>!v&&d(R.uid),onMouseLeave:()=>d(null),disabled:v,style:{width:"100%",display:"flex",alignItems:"center",gap:"14px",padding:"10px",borderRadius:"8px",backgroundColor:pe?"#f3f4f6":"transparent",border:i===R.uid&&!v?"2px solid #F4A5A5":"2px solid transparent",cursor:v?"not-allowed":"pointer",opacity:v?.6:1,transition:"all 0.2s"},children:[e.jsx("div",{style:{width:"40px",height:"40px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",backgroundColor:"#f3f4f6"},children:ne(R)?e.jsx("img",{src:ne(R),alt:R.name,style:{width:"26px",height:"26px",objectFit:"contain"}}):e.jsx("span",{style:{fontSize:"16px",fontWeight:"bold"},children:R.name.charAt(0)})}),e.jsxs("span",{className:"ibm-plex-mono",style:{fontSize:"17px",fontWeight:500,letterSpacing:"0.4px",color:v?"#9ca3af":"#111827",flex:1,textAlign:"left",fontFamily:'"IBM Plex Mono", monospace'},children:[pe?"Connecting...":R.name,!q&&!pe&&e.jsx("span",{style:{fontSize:"12px",marginLeft:"8px"},children:"(Not detected)"})]})]},R.uid)})]}),Ee&&!u&&e.jsx("div",{style:{padding:"0 25px 20px"},children:e.jsxs("div",{style:{padding:"12px",backgroundColor:"#fef3c7",borderRadius:"8px",border:"1px solid #fde68a"},children:[e.jsxs("p",{style:{margin:"0 0 10px 0",color:"#92400e",fontSize:"14px"},children:["Please switch to ",H," to continue."]}),e.jsx("button",{onClick:xe,disabled:g,style:{width:"100%",padding:"8px 12px",borderRadius:"6px",border:"1px solid #fbbf24",backgroundColor:"white",cursor:g?"not-allowed":"pointer",fontWeight:600,fontSize:"13px",color:"#92400e",opacity:g?.6:1},children:g?"Switching...":"Switch Network"})]})}),e.jsx("div",{style:{padding:"0 25px 25px"},children:e.jsxs("button",{onClick:async()=>{ue&&(await new Promise(R=>setTimeout(R,300)),n?await n():o())},disabled:!ue,style:{width:"100%",padding:"10px",borderRadius:"8px",boxShadow:"0 2px 4px rgba(0, 0, 0, 0.1)",fontWeight:600,fontSize:"16px",transition:"all 0.2s",display:"flex",alignItems:"center",justifyContent:"center",gap:"8px",backgroundColor:ue?"white":"#f3f4f6",border:"1px solid #00000029",color:ue?"black":"#9ca3af",cursor:ue?"pointer":"not-allowed"},children:[C?"CONNECTING...":g?"SWITCHING NETWORK...":p==="checking"?"CHECKING ELIGIBILITY...":"CONTINUE",e.jsx(bs,{size:20})]})}),y&&e.jsx("div",{style:{position:"fixed",inset:0,backgroundColor:"rgba(0, 0, 0, 0.55)",display:"flex",alignItems:"center",justifyContent:"center",padding:"16px",zIndex:60},children:e.jsxs("div",{style:{backgroundColor:"white",borderRadius:"12px",padding:"28px",width:"100%",maxWidth:"420px",textAlign:"center",boxShadow:"0 20px 60px rgba(0, 0, 0, 0.18)"},children:[e.jsx("p",{className:"ibm-plex-mono",style:{fontSize:"14px",fontWeight:600,letterSpacing:"0.4px",color:"#EF4444",marginBottom:"10px"},children:"ACCESS BLOCKED"}),e.jsx("h3",{style:{margin:"0 0 12px",fontSize:"22px",fontWeight:700},children:"Sorry, you're not eligible"}),e.jsx("p",{style:{margin:"0 0 18px",color:"#4B5563"},children:"This wallet does not meet the eligibility requirements to deposit assets."}),e.jsx("button",{onClick:()=>{P(),l(null),h(!1),b("idle"),j(null),$.current.clear(),o()},style:{width:"100%",padding:"12px",borderRadius:"8px",border:"none",backgroundColor:"#111827",color:"white",fontWeight:600,cursor:"pointer"},children:"Disconnect wallet"})]})}),e.jsx("style",{children:`
|
|
79
79
|
@keyframes spin {
|
|
80
80
|
from {
|
|
81
81
|
transform: rotate(0deg);
|
|
@@ -120,4 +120,4 @@
|
|
|
120
120
|
transform: rotate(360deg);
|
|
121
121
|
}
|
|
122
122
|
}
|
|
123
|
-
`})]})},js=a.memo(({isOpen:t,onClose:o,onDepositSelect:r,postDepositBatches:n,supportedChains:s,styles:c,onDepositAssetChange:i,assetInputHook:d,externalWalletAddress:g,allowedTokens:f,onDepositAmountChange:u,allowSecondAsset:l=!1,destinationChainId:C,destinationTokenAddress:A,postDepositInstruction:w,postDepositInstructionLabel:k,nativeChainId:p,airdrop:b=!1,sponsorGas:m=!1})=>{const j=a.useContext(Ue)?.mode||"7702",y=d?.assetAmount||"",h=de.defaultTheme,x={...h,typography:{...h.typography,fontFamily:c?.fontFamily||h.typography.fontFamily},colors:{...h.colors,primary:c?.primaryColor||h.colors.primary,primaryHover:c?.primaryColor?`${c.primaryColor}dd`:h.colors.primaryHover}},{ready:S,authenticated:F}=Je.usePrivy(),{signAuthorization:B}=Je.useSign7702Authorization();Je.useSignMessage();const{wallets:I}=Je.useWallets(),G=gt(),P=I?.find(D=>D.connectorType==="embedded"),_=j!="7702",$=_?!!g:S&&F&&!!G,J=G,M=g,{data:z}=Ae.useWalletClient(),{switchChainAsync:E}=Ae.useSwitchChain(),{chain:U}=Ae.useAccount(),X=a.useRef(U);a.useEffect(()=>{X.current=U},[U]);const ee=a.useRef(null),[H,ne]=a.useState([]),[xe]=a.useState([]),{assets:ue,loading:Ee,refreshAssets:R}=Vt({address:M||J,supportedChains:s,fetchBalances:zt,refreshInterval:8e3}),q=a.useMemo(()=>{const D=s.flatMap(V=>Rt(V,ue)).filter(V=>V.balance>BigInt(0));return f&&f.length>0?D.filter(V=>f.includes(V.symbol.toLowerCase())||V.isNative&&f.includes("native")):D},[s,ue,f]),pe=a.useMemo(()=>{if(!H[0]?.asset)return[];const D=H[0].asset.chainId;return q.filter(V=>V.chainId===D)},[q,H]),[v,N]=a.useState(!1),[O,se]=a.useState(null),[ae,Z]=a.useState("idle"),[he,Ce]=a.useState(null),[T,oe]=a.useState(!1),[le,Se]=a.useState(null),[ve,ke]=a.useState(!1),[Ie,ce]=a.useState(!1),[ze,W]=a.useState(null),[K,ie]=a.useState(null),{intentStatus:me,startStatusPolling:$e,clearStatus:Y}=kt({checkStepStatus:(D,V)=>we.checkStepStatus(D,V),pollingInterval:1e3});a.useEffect(()=>{H.length>0&&y!==H[0]?.amount&&ne(D=>{if(D.length===0)return D;const V=[...D];return V[0]={...V[0],amount:y||""},V})},[y]),a.useEffect(()=>{H.length!==0&&ne(D=>D.map(V=>{if(!V.asset)return V;const Q=q.find(L=>L.chainId===V.asset.chainId&&L.address.toLowerCase()===V.asset.address.toLowerCase());return Q?{...V,asset:Q,amount:V.amount}:V}))},[ue]);const te=a.useRef(null);a.useEffect(()=>{if(_&&me?.overallStatus==="success"&&w&&ae==="idle"){const D=te.current;D&&(async()=>{try{Z("executing"),await w(D),Z("success"),Se(D),oe(!0)}catch(V){console.error("postDepositInstruction failed:",V),Z("error"),Ce(V?.message||"Post-deposit instruction failed")}finally{te.current=null,ee.current=null}})()}},[me?.overallStatus,_,ae]);const Fe=a.useCallback(()=>{se(null)},[]);a.useEffect(()=>{t||(oe(!1),Se(null))},[t]);const De=a.useCallback(D=>{const V=D?.message||String(D||""),Q=D?.details||"",L=`${V} ${Q}`.toLowerCase();return L.includes("internal json-rpc error")||L.includes("internal error")||L.includes("an internal error was received")?"RPC Network error. Try switching your MetaMask RPC endpoint or try again.":V||"Transaction failed"},[]),_e=a.useCallback(async()=>{const D=M||J,V="0x111115763723b53395308ec4c9ab9d5fb0844cae";if(W(null),ie(null),!D){ie("Connect your wallet before requesting an airdrop");return}const Q=H[0]?.asset?.chainId??s[0];if(!Q){ie("No chain selected for airdrop");return}if(!z){ie("External wallet not connected");return}ce(!0);try{if(U?.id!==Q){W("Switching network...");try{await E({chainId:Q});let Me=0;const We=20;for(;Me<We&&(await new Promise(Oe=>setTimeout(Oe,100)),X.current?.id!==Q);)Me++;if(X.current?.id!==Q)throw new Error(`Failed to switch to chain ${Q}. Please switch manually in your wallet.`)}catch(Me){throw Me.code===4902||Me.name==="ChainNotConfiguredError"?new Error(`Chain ${Q} is not configured in your wallet. Please add it manually.`):Me}}W("Estimating required gas amount...");const L=Ve(Q),ye=await L.getGasPrice(),je=BigInt(65e3)*ye,Ke=BigInt(120),Te=je*Ke/BigInt(100);W("Sending gas deposit to solver...");const Le=await z.sendTransaction({to:V,value:Te});if(W("Waiting for transaction confirmation..."),(await L.waitForTransactionReceipt({hash:Le,timeout:12e4,pollingInterval:2e3,confirmations:2})).status!=="success")throw new Error("Gas deposit transaction failed");W("Requesting airdrop...");const Be=await we.requestSpiceUsdAirdrop({chainId:Q,address:D});if(!Be.success){ie(Be.errorMessage||"Failed to request airdrop");return}if(Be.txHash||Be.amount){const Me=Be.amount?` ${Be.amount}`:"";W(`Airdrop${Me} requested successfully.`);return}W("Airdrop requested successfully.")}catch(L){const ye=De(L);ie(ye)}finally{ce(!1)}},[J,M,H,s,z,U,E,De]),at=(D,V)=>{ne(Q=>{const L=[...Q];return L[V]={asset:D,amount:L[V]?.amount||""},L}),V===0&&i?.(D),Fe()},et=a.useCallback((D,V)=>{ne(Q=>{const L=[...Q];return L[V]&&(L[V]={...L[V],amount:D}),L}),Fe(),V===0&&(d?.setAssetAmount(D),u?.(D))},[Fe,d,u]),Ze=a.useCallback(()=>{H.length<2&&ne(D=>[...D,{asset:null,amount:""}])},[H.length]),be=a.useCallback(D=>{ne(V=>V.filter((Q,L)=>L!==D)),Fe()},[Fe]),[Re,ge]=a.useState(!1),[nt,tt]=a.useState(null),ft=()=>{if(H.length===0||!H[0]?.asset)return;const D=H.filter(ye=>ye.asset&&ye.amount&&parseFloat(ye.amount)>0);if(D.length===0)return;const V=D[0],Q=fe(V.asset.chainId),L=D.map(ye=>`${ye.amount} ${ye.asset.symbol}`).join(", ");tt({network:Q?.displayName||`Chain ${V.asset.chainId}`,amount:L,symbol:"",chainId:V.asset.chainId}),ge(!0)},Ge=async()=>{const D=H.filter(Q=>Q.asset&&Q.amount&&parseFloat(Q.amount)>0);if(D.length===0){se("Please select an asset and enter an amount");return}if(!M){se("External wallet not connected. Please connect your wallet in the previous step.");return}if(console.log("IS NON 7702",_),!_){if(!J||!G){se("Missing embedded wallet address");return}if(!S||!F){se("Please authenticate with Privy to continue");return}}N(!0),se(null);let V=!1;try{const Q=D[0].asset.chainId;if(!z)throw new Error("External wallet not connected");if(U?.id!==Q){se("Wrong chain selected. Switching network..."),console.log("Attempting to switch to chain:",{chainId:Q,currentChainId:U?.id,chainName:st(Q)});try{await E({chainId:Q});let L=0;const ye=20;for(;L<ye;){if(await new Promise(je=>setTimeout(je,100)),X.current?.id===Q){se(null);break}L++}if(X.current?.id!==Q)throw new Error(`Failed to switch to chain ${Q}. Please switch manually in your wallet.`);se(null)}catch(L){throw L.code===4902||L.name==="ChainNotConfiguredError"?new Error(`Chain ${Q} is not configured in your wallet. Please add it manually.`):L}}if(_)if(p&&Q===p){if(!w)throw new Error("Post-deposit instruction is required for native chain deposits");const L=fe(Q),ye=D.map(je=>`${je.amount} ${je.asset.symbol}`).join(", ");if(tt({network:L?.displayName||`Chain ${Q}`,amount:ye,symbol:"",chainId:Q}),ge(!0),D[0]?.amount){const je=D[0].amount;Z("executing");try{await w(je),Z("success"),Se(je),oe(!0)}catch(Ke){console.error("postDepositInstruction failed:",Ke),Z("error"),Ce(Ke?.message||"Post-deposit instruction failed")}}R(),r&&r(D[0].asset)}else{if(!C)throw new Error("Destination chain ID is required for non-7702 mode");const L=ct(Q),ye=[];let je=null;for(const Te of D){const Le=re.parseUnits(Te.amount,Te.asset.decimals),Be=wt(Te.asset.address),Me=Te.asset.isNative||Dt(Be);console.log("Sending transaction via MetaMask:",{chainId:Q,isNative:Me,tokenAddress:Be,delegateContract:L,amount:Le.toString(),walletChainId:z.chain?.id});const We=Me?await z.sendTransaction({to:L,value:Le}):await z.sendTransaction({to:Be,data:re.encodeFunctionData({abi:dt,functionName:"transfer",args:[L,Le]})});je||(je=We);const Oe=Ve(Q);console.log(`Waiting for transaction receipt: ${We}`);const Pe=await Oe.waitForTransactionReceipt({hash:We,timeout:12e4,pollingInterval:2e3,confirmations:2});if(console.log("Transaction receipt:",{hash:Pe.transactionHash,blockNumber:Pe.blockNumber,status:Pe.status,confirmations:2}),Pe.status!=="success")throw new Error(`Transfer to delegate contract failed for ${Te.asset.symbol}`);const it=await Oe.getBlockNumber()-Pe.blockNumber;console.log(`Transaction has ${it} confirmations`),it<2&&(console.log("Waiting for additional confirmations..."),await new Promise(mt=>setTimeout(mt,3e3))),ee.current||(ee.current=[]),ee.current.push({txHash:We,sender:M,tokenAddress:Be,chainId:Q,amount:Le.toString(),user:M}),console.log("Stored deposit data for later submission:",{txHash:We,sender:M,tokenAddress:Be,chainId:Q,amount:Le.toString()}),ye.push({tokenAddress:Be,tokenAmount:Le.toString(),sender:M,receiver:L})}if(!je)throw new Error("No transaction hash generated");const Ke=await Ve(Q).getBlockNumber();if(console.log("Final block number before relayer submission:",Ke),console.log("All transactions confirmed, submitting to relayer..."),!A)throw new Error("Destination token address is required for bridging");if(m&&p){const Te=re.parseUnits("0.05",18);ye.push({tokenAddress:"0x0",tokenAmount:Te.toString(),sender:M,receiver:L})}if(j==="ondemand"){const Te={to:L,value:BigInt(0),data:"0x"},Le=await ns(C,A);let Be=BigInt(0);for(const Ne of ye){const Ht=BigInt(Ne.tokenAmount),Ut=wt(Ne.tokenAddress),yt=D.find(Xe=>wt(Xe.asset.address).toLowerCase()===Ut.toLowerCase());let Qe;yt?Qe=yt.asset.decimals:Qe=await ns(Q,wt("0x0"));const He=eo(Ht,Qe,Le);Be+=He}const Me={chainId:Q,tokenTransfers:ye.map(Ne=>({from:Ne.sender,to:Ne.receiver,token:Ne.tokenAddress,amount:BigInt(Ne.tokenAmount)})),call:Te},We={chainId:C,tokenTransfers:[{from:"solver",to:M,token:A,amount:Be}],call:{to:A,value:BigInt(0),data:"0x"}},Oe={user:M,intents:[{mode:"non-7702:on-demand",chainBatches:[Me,We]}]},Pe=await we.createAction(Oe),it=Pe.actionId,mt=Pe.intentIds[0];if(!je)throw new Error("No transaction hash available");$e(mt,Et([{chainId:Q,calls:[Te]},{chainId:C,calls:[We.call]}],Ne=>st(Ne))),await we.executeStep(it,0,0,{action:"execute",hash:je}),console.log("[DepositModal] Deposit executed, solver transfer completed by API"),D[0]?.amount&&(te.current=D[0].amount),R(),r&&r(D[0].asset),ge(!1)}else throw new Error("Presign mode not yet fully supported for cross-chain deposits")}else{const L="0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",ye=[],je=[];for(const Qe of D){const He=re.parseUnits(Qe.amount,Qe.asset.decimals),Xe=wt(Qe.asset.address),Bt=Qe.asset.isNative||Dt(Xe);console.log("Sending EIP-7702 transaction via MetaMask:",{chainId:Q,isNative:Bt,tokenAddress:Xe,amount:He.toString(),recipient:J,walletChainId:z.chain?.id});const bt=Bt?await z.sendTransaction({to:J,value:He}):await z.sendTransaction({to:Xe,data:re.encodeFunctionData({abi:dt,functionName:"transfer",args:[J,He]})}),Ot=Ve(Q);console.log(`Waiting for transaction receipt (EIP-7702): ${bt}`);const Ct=await Ot.waitForTransactionReceipt({hash:bt,timeout:12e4,pollingInterval:2e3,confirmations:2});if(console.log("Transaction receipt (EIP-7702):",{hash:Ct.transactionHash,blockNumber:Ct.blockNumber,status:Ct.status,confirmations:2}),Ct.status!=="success")throw new Error(`Transfer to embedded wallet failed for ${Qe.asset.symbol}`);const Xt=await Ot.getBlockNumber()-Ct.blockNumber;console.log(`Transaction has ${Xt} confirmations`),Xt<2&&(console.log("Waiting for additional confirmations..."),await new Promise(Ts=>setTimeout(Ts,3e3))),console.log("Calling submitSpiceDeposit (EIP-7702) with:",{txHash:bt,sender:M,tokenAddress:Xe,chainId:Q,amount:He.toString(),user:J,isDeposit:!0}),await we.submitSpiceDeposit({txHash:bt,sender:M,tokenAddress:Xe,chainId:Q,amount:He.toString(),user:J,isDeposit:!0}),console.log(`Successfully submitted deposit for txHash: ${bt}`),ye.push(Bt?{to:L,value:He,data:"0x"}:{to:Xe,value:BigInt(0),data:re.encodeFunctionData({abi:dt,functionName:"transfer",args:[L,He]})}),je.push({tokenAddress:Xe,tokenAmount:He,sender:J,receiver:Bt?"":L})}if(m&&p&&J){const Qe=re.parseUnits("0.05",18);je.push({tokenAddress:"0x0",tokenAmount:Qe.toString(),sender:J,receiver:J})}const Ke=Ve(Q),Te=await Ke.getBlockNumber(),Le=[{chainId:Q,recentBlock:Te,calls:ye},...n??[]];if(!J)throw new Error("Address not available");const Be=ct(Q),Me=await Ye.getAccountNonce(J,Ke),We=await B({contractAddress:Be,chainId:Q,nonce:Number(Me)}),Oe=Ye.hashChainBatches(Le),Pe=Math.floor(Date.now()/1e3)+60*10,it=Ye.getIntentHash(0n,BigInt(Pe),Oe);if(!P)throw new Error("Embedded wallet not available for signing");const mt=await P.getEthereumProvider(),Ne=await re.createWalletClient({account:P.address,transport:re.custom(mt)}).signMessage({account:P.address,message:{raw:it}});if(!Ne)throw new Error("Failed to sign intent authorization");const Ht={mode:"7702",signatureType:"ecdsa",signature:Ne,nbf:0,exp:Pe,chainBatches:Oe.map((Qe,He)=>({hash:Qe.hash,chainId:Le[He].chainId,tokenTransfers:[],calls:Le[He].calls}))},Ut={user:J,chainAuthorizations:[{r:We.r,s:We.s,yParity:We.yParity,chainId:We.chainId,nonce:We.nonce,address:We.address}],intents:[Ht]},yt=await we.createAction(Ut);if(yt){const Qe=Et(Le,He=>st(He));$e(yt.intentIds[0],Qe),R(),r&&r(D[0].asset)}}}catch(Q){V=!0;let L="Deposit failed";Q?.code===4001||Q?.code==="ACTION_REJECTED"?L="Transaction rejected by user":Q?.code===-32603?L="Internal wallet error. Please try again.":Q?.message?.includes("insufficient funds")?L="Insufficient funds for transaction":Q?.message?.includes("User rejected")||Q?.message?.includes("user rejected")?L="Transaction rejected by user":Q?.message?.includes("does not match the target chain")||Q?.message?.includes("Current Chain ID")?L="Network mismatch detected. Please click the button again to proceed.":L=De(Q),se(L)}finally{N(!1),V||!me&&ae!=="idle"||ge(!1)}},Hs=H.length>0&&H[0]?.asset&&H[0]?.amount&&parseFloat(H[0].amount)>0&&$&&!v,Us=()=>{if(v)return"Executing Deposit...";if(!$)return"Wallet Not Connected";if(j==="7702"){if(!S)return"Loading...";if(!F)return"Authentication Required"}return H[0]?.asset?H[0]?.amount?"DEPOSIT":"ENTER AMOUNT":"SELECT TOKEN"};return t?e.jsx(xt,{isOpen:t,onClose:o,title:"Deposit to your Spicenet account",subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"3px"},children:[e.jsx("img",{src:vs,alt:"Info",style:{width:"10px",height:"10px",marginTop:"4px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"12px",color:"#6b7280",margin:"0",lineHeight:"1.4",fontFamily:"system-ui, -apple-system, sans-serif"},children:"Deposit collateral to your Spicenet Account from 9+ EVM blockchains."})]}),overlayContent:Re||me||ae!=="idle"&&w?e.jsx("div",{}):void 0,styles:c,theme:x,children:e.jsxs("div",{style:{padding:"24px 24px 5px 24px"},children:[H.map((D,V)=>{const Q=H.length===1?"Deposit":`Asset ${V+1}`;return e.jsxs("div",{style:{marginBottom:x.spacing.md,position:"relative"},children:[b&&V===0&&e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"8px"},children:[e.jsx("div",{style:{fontSize:"11px",color:K?"#b91c1c":"#047857",fontFamily:c?.fontFamily||x.typography.fontFamily,flex:1,minWidth:0},children:K||ze||""}),e.jsxs("div",{style:{display:"flex",gap:"4px",flexShrink:0,alignItems:"center"},children:[e.jsx("button",{onClick:_e,disabled:Ie,style:{padding:"4px 8px",borderRadius:"4px",border:"1px solid #D1D5DB",background:"#E5E7EB",color:"#4B5563",fontSize:"11px",fontWeight:500,cursor:Ie?"default":"pointer",transition:"all 0.2s",display:"flex",alignItems:"center"},onMouseEnter:L=>{Ie||(L.currentTarget.style.color="#1F2937",L.currentTarget.style.background="#D1D5DB")},onMouseLeave:L=>{L.currentTarget.style.color="#4B5563",L.currentTarget.style.background="#E5E7EB"},children:Ie?"Requesting...":"Airdrop"}),e.jsxs("div",{onMouseEnter:()=>ke(!0),onMouseLeave:()=>ke(!1),style:{position:"relative",width:"14px",height:"14px",borderRadius:"50%",backgroundColor:"#9CA3AF",color:"white",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"9px",fontWeight:"bold",cursor:"help",flexShrink:0},children:["i",ve&&e.jsxs("div",{style:{position:"absolute",bottom:"calc(100% + 8px)",right:0,backgroundColor:"#1F2937",color:"white",padding:"8px 12px",borderRadius:"6px",fontSize:"12px",whiteSpace:"nowrap",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:100},children:["This is testnet USDC, and it won't be available on mainnet",e.jsx("div",{style:{position:"absolute",top:"100%",right:"10px",width:0,height:0,borderLeft:"6px solid transparent",borderRight:"6px solid transparent",borderTop:"6px solid #1F2937"}})]})]})]})]}),e.jsx(ht,{assets:V===0?q:pe,selectedAsset:D||void 0,onAssetSelect:L=>at(L,V),onAmountChange:L=>et(L,V),loading:Ee,label:Q,showBalance:!0,theme:x,styles:c,allowSecondAsset:l&&V===0,onAddAsset:Ze,canAddAsset:H.length===1&&!!H[0]?.asset}),V===1&&e.jsx("button",{onClick:()=>be(V),style:{position:"absolute",top:"-2px",right:"-2px",background:"rgba(255, 255, 255, 0.9)",border:"1px solid #e5e7eb",borderRadius:"50%",cursor:"pointer",color:x.colors.textMuted,fontSize:"16px",padding:"2px",width:"22px",height:"22px",display:"flex",alignItems:"center",justifyContent:"center",transition:"all 0.2s",boxShadow:"0 1px 3px rgba(0, 0, 0, 0.1)"},onMouseEnter:L=>{L.currentTarget.style.color="#ef4444",L.currentTarget.style.background="#fff",L.currentTarget.style.borderColor="#fecaca"},onMouseLeave:L=>{L.currentTarget.style.color=x.colors.textMuted,L.currentTarget.style.background="rgba(255, 255, 255, 0.9)",L.currentTarget.style.borderColor="#e5e7eb"},title:"Remove asset",children:"\xD7"})]},`asset-${V}`)}),H.length===0&&e.jsxs("div",{style:{marginBottom:x.spacing.md},children:[b&&e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"8px"},children:[e.jsx("div",{style:{fontSize:"11px",color:K?"#b91c1c":"#047857",fontFamily:c?.fontFamily||x.typography.fontFamily,flex:1,minWidth:0},children:K||ze||""}),e.jsxs("div",{style:{display:"flex",gap:"4px",flexShrink:0,alignItems:"center"},children:[e.jsx("button",{onClick:_e,disabled:Ie,style:{padding:"4px 8px",borderRadius:"4px",border:"1px solid #D1D5DB",background:"#E5E7EB",color:"#4B5563",fontSize:"11px",fontWeight:500,cursor:Ie?"default":"pointer",transition:"all 0.2s",display:"flex",alignItems:"center"},onMouseEnter:D=>{Ie||(D.currentTarget.style.color="#1F2937",D.currentTarget.style.background="#D1D5DB")},onMouseLeave:D=>{D.currentTarget.style.color="#4B5563",D.currentTarget.style.background="#E5E7EB"},children:Ie?"Requesting...":"Airdrop"}),e.jsxs("div",{onMouseEnter:()=>ke(!0),onMouseLeave:()=>ke(!1),style:{position:"relative",width:"14px",height:"14px",borderRadius:"50%",backgroundColor:"#9CA3AF",color:"white",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"9px",fontWeight:"bold",cursor:"help",flexShrink:0},children:["i",ve&&e.jsxs("div",{style:{position:"absolute",bottom:"calc(100% + 8px)",right:0,backgroundColor:"#1F2937",color:"white",padding:"8px 12px",borderRadius:"6px",fontSize:"12px",whiteSpace:"nowrap",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:100},children:["This is testnet USDC, and it won't be available on mainnet",e.jsx("div",{style:{position:"absolute",top:"100%",right:"10px",width:0,height:0,borderLeft:"6px solid transparent",borderRight:"6px solid transparent",borderTop:"6px solid #1F2937"}})]})]})]})]}),e.jsx(ht,{assets:q,selectedAsset:void 0,onAssetSelect:D=>at(D,0),onAmountChange:D=>et(D,0),loading:Ee,label:"Deposit",showBalance:!0,theme:x,styles:c,allowSecondAsset:l,onAddAsset:Ze,canAddAsset:!1},"initial-selector")]}),xe.length>0&&e.jsx("div",{style:{marginBottom:x.spacing.sm},children:e.jsxs("div",{style:{backgroundColor:c?.infoCard?.backgroundColor||c?.tertiaryBackground||(x.mode==="light"?"#f9fafb":x.colors.surface),border:`1px solid ${c?.infoCard?.borderColor||(x.mode==="light"?"#e5e7eb":x.colors.border)}`,borderRadius:c?.infoCard?.borderRadius||x.borderRadius.md,padding:c?.infoCard?.padding||x.spacing.sm},children:[e.jsx("div",{style:{fontSize:c?.infoCard?.title?.fontSize||x.typography.fontSize.xs,fontWeight:c?.infoCard?.title?.fontWeight||x.typography.fontWeight.medium,color:c?.infoCard?.title?.color||x.colors.text,fontFamily:c?.infoCard?.title?.fontFamily||x.typography.fontFamily,marginBottom:"4px"},children:"Deposit Batches Ready"}),e.jsxs("div",{style:{fontSize:c?.infoCard?.description?.fontSize||x.typography.fontSize.xs,color:c?.infoCard?.description?.color||x.colors.textSecondary,fontFamily:c?.infoCard?.description?.fontFamily||x.typography.fontFamily},children:[xe.length," deposit batch",xe.length>1?"es":""," across chains:"," ",[...new Set(xe.map(D=>D.chainId))].join(", ")]})]})}),e.jsx(qo,{intentStatus:me,postDepositSuccess:T,postDepositAmount:le,postDepositStatus:ae,postDepositInstructionLabel:k,sourceChainName:H[0]?.asset?.chainId?st(H[0].asset.chainId):"Destination Chain"}),e.jsx(Yo,{isOpen:Re||!!me||ae!=="idle"&&!!w,onClose:()=>{ge(!1),me&&Y();const D=ae==="success"&&!me,V=me?.overallStatus==="success"&&ae==="success"&&w;(D||V)&&o()},onConfirm:Ge,data:nt,isExecuting:v,error:O,theme:x,styles:c,intentStatus:me,postDepositStatus:ae,hasPostDepositInstruction:!!w}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:0,marginBottom:0,margin:0,padding:0},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ft,loading:v,disabled:!Hs||!$,theme:x,styles:{...c,button:{...c?.button}},children:Us()})})]})}):null}),Gt=t=>{const[o,r]=a.useState(!1),n=a.useContext(Ue);if(a.useEffect(()=>{r(!0)},[]),!o)return e.jsx("div",{className:t.className,children:e.jsx("button",{disabled:!0,style:{padding:"12px 24px",fontSize:"16px",backgroundColor:"#ccc",color:"white",border:"none",borderRadius:"4px",cursor:"not-allowed"},children:"Loading..."})});if(!n){const s='ProviderLogin must be used within SpiceFlowProvider. Please wrap your app with <SpiceFlowProvider provider="privy" | "dynamic">.';return e.jsx("div",{className:t.className,children:e.jsx("button",{onClick:()=>{t.onAuthError&&t.onAuthError(s)},style:{padding:"12px 24px",fontSize:"16px",backgroundColor:"#dc2626",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"Provider Not Found"})})}return n.provider==="privy"?e.jsx(Gs.PrivyLogin,{...t}):n.provider==="dynamic"?e.jsx(Zs.DynamicLogin,{...t}):null},Po=({isOpen:t,onClose:o,styles:r,className:n="",postDepositBatches:s,allowedTokens:c,onDepositAmountChange:i,allowSecondAsset:d,destinationChainId:g,destinationTokenAddress:f,postDepositInstruction:u,postDepositInstructionLabel:l,airdrop:C=!1,sponsorGas:A=!1})=>{const w=a.useContext(Ue);if(!w)return e.jsx("div",{children:"Error: SpiceDeposit must be used within SpiceFlowProvider"});const k=(w.mode||"7702")!="7702",p=w.nativeChainId,[b,m]=a.useState("select-chain"),[j,y]=a.useState(null),[h,x]=a.useState(!1),{ready:S,authenticated:F}=Je.usePrivy(),B=gt(),{isConnected:I,address:G}=Ae.useAccount(),P=a.useCallback(z=>{const E=parseInt(z);y(E),x(!1),m(k?"connect-wallet":"provider-login")},[k]),_=a.useCallback(()=>{x(!0),m("connect-wallet")},[]),$=a.useCallback(async()=>{if((!I||!G)&&(await new Promise(z=>setTimeout(z,500)),!I||!G)){alert("Please connect your wallet first");return}m("deposit")},[I,G]),J=a.useCallback(()=>{o()},[o]),M=a.useCallback(()=>{m("select-chain")},[]);return a.useEffect(()=>{if(!t){const z=setTimeout(()=>{m("select-chain"),y(null),x(!1)},300);return()=>clearTimeout(z)}},[t]),a.useEffect(()=>{t&&b==="deposit"&&!j&&m("select-chain")},[t,b,j]),a.useEffect(()=>{if(!k&&t&&b==="provider-login"&&S&&F&&B&&!h){const z=setTimeout(()=>{x(!0),m("connect-wallet")},100);return()=>clearTimeout(z)}},[k,t,b,S,F,B,h]),t?b==="select-chain"?e.jsx(Is,{isOpen:t,onClose:J,onChainSelect:P,supportedChains:w.supportedChainIds}):b==="provider-login"&&!k?e.jsx(Gt,{onAuthSuccess:_,autoTrigger:!0}):b==="connect-wallet"?e.jsx(Es,{isOpen:t,onClose:J,onContinue:$,requiredChainId:j||void 0,onBackToChainSelector:M}):b==="deposit"&&j?e.jsx(js,{isOpen:t,onClose:J,supportedChains:[j],styles:r,className:n,externalWalletAddress:G,postDepositBatches:s,allowedTokens:c,onDepositAmountChange:i,allowSecondAsset:d,destinationChainId:g,destinationTokenAddress:f,postDepositInstruction:u,postDepositInstructionLabel:l,nativeChainId:p,airdrop:C,sponsorGas:A}):null:null},Bs=t=>a.useContext(Ue)?e.jsx(Po,{...t}):e.jsx("div",{children:"Error: SpiceDeposit must be used within SpiceFlowProvider"}),Ws=({title:t,icon:o,amount:r,children:n,defaultExpanded:s=!1})=>{const[c,i]=a.useState(s),d=g=>{g?.stopPropagation(),i(!c)};return e.jsxs("div",{style:{backgroundColor:"#FAFAFA",borderRadius:"12px",padding:"12px 16px",border:"0.5px solid #939291",boxShadow:"4px 4px 0px 0px #E1E1E1",marginBottom:"12px"},children:[e.jsxs("div",{onClick:d,onKeyDown:g=>{(g.key==="Enter"||g.key===" ")&&(g.preventDefault(),d())},role:"button",tabIndex:0,style:{display:"flex",alignItems:"center",justifyContent:"space-between",cursor:"pointer",width:"100%"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px",flex:1,minWidth:0},children:[o&&e.jsx("img",{src:o,alt:t,style:{width:"20px",height:"20px",flexShrink:0},onError:g=>{const f=g.target;f.style.display="none"}}),e.jsx("span",{className:"ibm-plex-mono",style:{fontSize:"14px",fontWeight:500,fontFamily:'"IBM Plex Mono", monospace',color:"#17171A",letterSpacing:"0.5px",textTransform:"uppercase",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:t})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",flexShrink:0},children:[e.jsx("span",{style:{fontSize:"18px",fontWeight:600,color:"#262523",whiteSpace:"nowrap"},children:r}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",style:{transform:c?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.2s ease",flexShrink:0},children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#262523",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]})]}),c&&n&&e.jsx("div",{style:{marginTop:"16px",paddingTop:"16px",borderTop:"1px solid #D0D2D8"},children:n})]})},Jo=t=>t===1||t===11155111?qe:t===8453||t===84532?rt:null,Mt=({name:t,balance:o,icon:r,subtitle:n,networks:s,onClick:c})=>e.jsxs("div",{onClick:c,style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 0",cursor:c?"pointer":"default",transition:"opacity 0.2s ease"},onMouseEnter:i=>{c&&(i.currentTarget.style.opacity="0.7")},onMouseLeave:i=>{i.currentTarget.style.opacity="1"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px"},children:[r&&e.jsx("div",{style:{width:"25px",height:"25px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",overflow:"hidden"},children:typeof r=="string"?e.jsx("img",{src:r,alt:t,style:{width:"100%",height:"100%",objectFit:"cover"},onError:i=>{console.warn(`Failed to load image: ${r}`);const d=i.target;d.style.display="none"}}):r}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"2px",flex:1},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1A1A1A",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",letterSpacing:"0.3px"},children:t}),t==="USDC"&&e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#ef4444",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("svg",{style:{width:"12px",height:"12px",color:"white"},fill:"currentColor",viewBox:"0 0 20 20",children:e.jsx("path",{fillRule:"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z",clipRule:"evenodd"})})}),s&&s.length>0&&e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:s.map(i=>{const d=Jo(i);return d?e.jsx("img",{src:d,alt:`Chain ${i}`,style:{width:"16px",height:"16px",borderRadius:"50%",objectFit:"cover"}},i):e.jsx(Ft,{chainId:i,size:16},i)})})]}),n&&e.jsx("span",{style:{fontSize:"11px",fontWeight:400,color:"#6B7280",fontFamily:'"IBM Plex Mono", monospace',textTransform:"none"},children:n})]})]}),e.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1A1A1A",fontFamily:'"IBM Plex Mono", monospace'},children:o})]}),Rs=({address:t,enabled:o=!0,refetchInterval:r})=>{const[n,s]=a.useState(null),[c,i]=a.useState(!1),[d,g]=a.useState(null),[f,u]=a.useState(!1),l=a.useCallback(async()=>{if(!t||!o){s(null),u(!1);return}i(!0),g(null);try{const C=await fetch(`${Yt}/spicedeposit/${t}`);if(!C.ok)throw new Error(`Failed to fetch balance: ${C.status}`);const A=await C.json();if(A.success&&A.data?.tokens&&Array.isArray(A.data.tokens)){const w=[];let k=0;A.data.tokens.forEach(p=>{const b=p.chainId,m=p.tokenAddress,j=parseFloat(p.amount||"0");if(j>0){const y=fe(b),h=m.toLowerCase()==="0x0"||m.toLowerCase()==="0x0000000000000000000000000000000000000000"||m.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";let x=18,S="TOKEN",F=m.slice(0,6)+"..."+m.slice(-4);if(h)x=y?.nativeCurrency?.decimals||18,S=y?.nativeCurrency?.symbol||"ETH",F=y?.nativeCurrency?.name||"Native Token";else{const I=y?.supportedTokens?.find(G=>G.address.toLowerCase()===m.toLowerCase());I&&(x=I.decimals,S=I.symbol,F=I.name)}const B=j/Math.pow(10,x);B>0&&(w.push({id:`${S.toLowerCase()}-${b}`,name:S,balance:B,subtitle:F,iconColor:"#2775CA",networks:[b]}),k+=B)}}),k>0&&w.length>0?(s({totalBalance:k,percentageChange:0,tradingAccounts:[],freeCollateral:k,freeCollateralItems:w,defiPositions:0,defiPositionsItems:[],credit:0,creditItems:[]}),u(!0)):(s(null),u(!1))}else s(null),u(!1)}catch(C){const A=C instanceof Error?C.message:"Failed to fetch balance";g(A),console.error("Error fetching Spice balance:",C),s(null),u(!1)}finally{i(!1)}},[t,o]);return a.useEffect(()=>{o&&t&&l()},[t,o,l]),a.useEffect(()=>{if(!o||!t||!r)return;const C=setInterval(()=>{l()},r);return()=>clearInterval(C)},[t,o,r,l]),{balanceData:n,loading:c,error:d,hasBalance:f,refetch:l}},Qt={1:qe,11155111:qe,421614:vt,42161:vt,8453:rt,84532:rt},Kt=a.memo(({isOpen:t,onClose:o,styles:r,externalWalletAddress:n,postWithdrawInstruction:s,postWithdrawInstructionLabel:c,nativeChainId:i,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u,filterChainIds:l,preSelectedTokens:C})=>{const A=a.useContext(Ue)?.mode||"7702",w=A==="presign"||A==="ondemand",k=de.defaultTheme,p={...k,typography:{...k.typography,fontFamily:r?.fontFamily||k.typography.fontFamily},colors:{...k.colors,primary:r?.primaryColor||k.colors.primary,primaryHover:r?.primaryColor?`${r.primaryColor}dd`:k.colors.primaryHover}},b=gt(),m=b,[j,y]=a.useState([]),[h,x]=a.useState(""),[S,F]=a.useState(!1),[B,I]=a.useState(!1),[G,P]=a.useState(null),[_,$]=a.useState(!1),J=a.useRef(null),[M,z]=a.useState(null),[E,U]=a.useState(!0),[X,ee]=a.useState(!1),H=n,{data:ne}=Ae.useWalletClient(),{balanceData:xe,refetch:ue}=Rs({address:m,enabled:!!m&&(!w||X)});a.useEffect(()=>{if(xe&&xe.freeCollateralItems){const T=[];xe.freeCollateralItems.forEach(oe=>{oe.networks&&oe.networks.length>0&&oe.networks.forEach(le=>{if(l&&l.length>0&&!l.includes(le))return;const Se=fe(le);if(Se){const ve=C&&C.length>0?C.some(ke=>ke.toLowerCase()===oe.name.toLowerCase()):!0;T.push({id:`${oe.name.toLowerCase()}-${le}`,chainId:le,chainName:Se.displayName,tokenAddress:"",tokenSymbol:oe.name,tokenName:oe.subtitle||oe.name,balance:oe.balance,selected:ve})}})}),y(T)}},[xe,l,C]),a.useEffect(()=>{const T=oe=>{J.current&&!J.current.contains(oe.target)&&$(!1)};return document.addEventListener("mousedown",T),()=>{document.removeEventListener("mousedown",T)}},[]),a.useEffect(()=>{t||(I(!1),F(!1),P(null),z(null),ee(!1))},[t]),a.useEffect(()=>{w&&g&&t&&g().then(T=>{const oe=Math.round(T*1e6)/1e6;z(oe)}).catch(T=>{console.error("Error fetching vault balance:",T),z(null)})},[w,g,t]);const Ee=a.useCallback(T=>{y(oe=>oe.map(le=>le.id===T?{...le,selected:!le.selected}:le))},[]),R=a.useMemo(()=>j.filter(T=>T.selected),[j]),q=a.useMemo(()=>R.reduce((T,oe)=>T+oe.balance,0),[R]),pe=a.useMemo(()=>f?fe(f)?.displayName||"Unknown Chain":"Arbitrum",[f]),v=a.useMemo(()=>f?Qt[f]||qe:vt,[f]),N=a.useCallback(async()=>{F(!0),P(null);try{if(w){if(!s)throw new Error("Withdraw instruction not provided");if(!h||h.trim()==="")throw new Error("Please enter an amount to withdraw");const T=parseFloat(h);if(isNaN(T)||T<=0)throw new Error("Invalid withdrawal amount");const oe=M??d;if(oe!=null&&T>oe)throw new Error(`Insufficient balance. Available: ${oe.toFixed(6).replace(/\.?0+$/,"")}`);if(console.log("Non-EIP-7702 withdraw from vault:",{amount:h,numericAmount:T,availableBalance:oe,fetchedVaultBalance:M,vaultBalance:d,withdrawToSpiceNet:X}),await s(h),X){if(!n)throw new Error("External wallet address is required for SpiceNet deposit");if(!ne)throw new Error("Wallet client not available");if(!f)throw new Error("Destination chain ID is required for SpiceNet withdrawal");if(!u)throw new Error("Destination token address is required for SpiceNet withdrawal");const le=ct(f),Se=fe(f);let ve=6;if(Se?.supportedTokens){const ie=Se.supportedTokens.find(me=>me.address.toLowerCase()===u.toLowerCase());ie?ve=ie.decimals:Se.nativeCurrency&&(ve=Se.nativeCurrency.decimals)}const ke=re.parseUnits(h,ve),Ie=u.toLowerCase()==="0x0"||u.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"||u.toLowerCase()==="0x0000000000000000000000000000000000000000",ce=Ie?await ne.sendTransaction({to:le,value:ke}):await ne.sendTransaction({to:u,data:re.encodeFunctionData({abi:dt,functionName:"transfer",args:[le,ke]})});console.log("Transferring to delegate contract:",{txHash:ce,delegateContract:le,amount:h,chainId:f});const ze=await Ve(f).waitForTransactionReceipt({hash:ce,timeout:6e4,pollingInterval:5e3,confirmations:1});console.log("Delegate contract transfer confirmed:",ze);const W=Ie?"0x0":u.toLowerCase();console.log("Calling submitSpiceDeposit with:",{user:b,txHash:ce,sender:n,tokenAddress:W,chainId:f,amount:ke.toString(),isDeposit:!1});const K=await we.submitSpiceDeposit({user:n,txHash:ce,sender:n,tokenAddress:W,chainId:f,amount:ke.toString(),isDeposit:!1});K.success?console.log("Successfully submitted SpiceNet deposit"):console.error("Failed to submit Spicenet deposit:",K.error?.message),ue&&await ue()}I(!0),F(!1),setTimeout(()=>{o()},1500)}else console.log("EIP-7702 withdraw:",{selectedAssets:R,totalAmount:q,destination:H}),I(!0),F(!1),setTimeout(()=>{o()},1500)}catch(T){console.error("Withdrawal error:",T),P(T instanceof Error?T.message:"Withdrawal failed"),F(!1),I(!1)}},[w,h,s,d,M,R,q,o,H,X,ne,f,u,ue]);if(!t)return null;const O=h||"0",se=(parseFloat(O)*1).toFixed(2),ae=w?M!==null?M:d:null,Z=w?ae!=null?ae.toFixed(6).replace(/\.?0+$/,""):"0.00":q.toFixed(2),he=w?h&&!isNaN(parseFloat(h))&&parseFloat(h)>0&&(ae==null||parseFloat(h)<=ae):h&&!isNaN(parseFloat(h))&&parseFloat(h)>0&&parseFloat(h)<=q,Ce=Array.from(new Set(R.map(T=>T.chainId)));return e.jsx(xt,{isOpen:t,onClose:o,title:"Withdraw from your account",subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"3px"},children:[e.jsx("img",{src:vs,alt:"Info",style:{width:"10px",height:"10px",marginTop:"4px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"12px",color:"#6b7280",margin:"0",lineHeight:"1.4",fontFamily:"system-ui, -apple-system, sans-serif"},children:"Withdraw collateral from your account to 10+ EVM blockchains."})]}),styles:r,theme:p,children:e.jsxs("div",{style:{padding:"24px 24px 5px 24px"},children:[e.jsxs("div",{style:{backgroundColor:"#E9E9E9",borderRadius:p.borderRadius.md,padding:`${p.spacing.sm} ${p.spacing.md}`,marginBottom:p.spacing.md},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"4px"},children:[e.jsx("span",{style:{fontSize:r?.assetSelector?.label?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.label?.color||p.colors.textMuted,fontWeight:r?.assetSelector?.label?.fontWeight,fontFamily:r?.assetSelector?.label?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:"Amount"}),e.jsxs("div",{ref:J,style:{position:"relative"},children:[e.jsxs("button",{onClick:()=>$(!_),style:{display:"flex",alignItems:"center",gap:"6px",background:"none",border:"none",cursor:"pointer",padding:"2px 4px",borderRadius:"4px",transition:"background-color 0.2s"},onMouseEnter:T=>T.currentTarget.style.backgroundColor="rgba(0,0,0,0.05)",onMouseLeave:T=>T.currentTarget.style.backgroundColor="transparent",children:[e.jsxs("span",{style:{fontSize:r?.assetSelector?.balance?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.balance?.color||p.colors.textMuted,fontFamily:r?.assetSelector?.balance?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:["Balance: ",Z]}),e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",border:"1.5px solid #EF4444",display:"flex",alignItems:"center",justifyContent:"center",color:"#EF4444",fontSize:"10px",backgroundColor:"transparent"},children:e.jsx("span",{style:{fontWeight:700,lineHeight:1},children:"\xB7\xB7\xB7"})})]}),_&&!w&&e.jsxs("div",{style:{position:"absolute",top:"100%",right:"0",marginTop:"8px",backgroundColor:"white",borderRadius:"12px",padding:"12px",boxShadow:"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)",border:"1px solid #E5E7EB",width:"220px",zIndex:50},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",fontSize:"11px",color:"#6B7280",marginBottom:"10px",fontFamily:'"IBM Plex Mono", monospace',borderBottom:"1px solid #F3F4F6",paddingBottom:"8px"},children:[e.jsx("span",{children:"TOTAL BALANCE"}),e.jsxs("span",{style:{color:"#111827",fontWeight:600},children:[Z," USDC"]})]}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:j.map(T=>e.jsxs("label",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",cursor:"pointer",fontSize:"12px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[e.jsx("input",{type:"checkbox",checked:T.selected,onChange:()=>Ee(T.id),style:{accentColor:"#EF4444",width:"14px",height:"14px"}}),e.jsx("img",{src:Qt[T.chainId]||qe,alt:T.chainName,style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",fontSize:"11px"},children:T.chainName})]}),e.jsxs("span",{style:{fontFamily:'"IBM Plex Mono", monospace',fontSize:"11px"},children:[T.balance.toFixed(2)," USDC"]})]},T.id))})]})]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",marginBottom:"6px"},children:[e.jsx("input",{type:"text",value:h,onChange:T=>{const oe=T.target.value;(oe===""||/^\d*\.?\d*$/.test(oe))&&x(oe)},placeholder:"0.0",style:{background:"transparent",border:"none",outline:"none",fontSize:r?.assetSelector?.amountInput?.fontSize||p.typography.fontSize["3xl"],fontWeight:r?.assetSelector?.amountInput?.fontWeight||p.typography.fontWeight.medium,color:r?.assetSelector?.amountInput?.color||p.colors.text,fontFamily:r?.assetSelector?.amountInput?.fontFamily||r?.fontFamily||p.typography.fontFamily,width:"50%"}}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",width:"auto",borderRadius:"10px",minWidth:"120px",border:"1px solid #CDCFD1"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#E9E9E9",borderRadius:"10px",padding:"8px 12px",cursor:"pointer",marginBottom:"4px"},children:[e.jsx("img",{src:ut,alt:"USDC",style:{width:"32px",height:"32px"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.base,fontWeight:500,color:"#3C3E42",fontFamily:r?.fontFamily||p.typography.fontFamily},children:"USDC"}),e.jsx("span",{style:{fontSize:"14px",color:"#3C3E42"},children:"\u25BC"})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",backgroundColor:"#D4D3D3",borderRadius:"0 0 10px 10px",padding:"6px 12px",borderTop:"1px solid #CDCFD1"},children:[e.jsx("img",{src:v,alt:"Network",style:{width:"16px",height:"16px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.sm,color:"#3C3E42",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",fontWeight:500},children:pe})]})]})]}),e.jsx("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:e.jsxs("span",{style:{fontSize:r?.assetSelector?.balance?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.balance?.color||p.colors.textMuted,fontFamily:r?.assetSelector?.balance?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:["$",se]})})]}),e.jsxs("div",{style:{marginBottom:p.spacing.sm},children:[e.jsxs("div",{onClick:()=>U(!E),style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:E?"12px":"0",cursor:"pointer",userSelect:"none"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Transaction Details"}),e.jsx("span",{style:{fontSize:"10px",color:p.colors.textMuted,transform:E?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.2s"},children:"\u25B2"})]}),E&&e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"10px"},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"To"}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily},children:H?`${H.slice(0,6)}...${H.slice(-4)}`:"..."})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Amount"}),e.jsxs("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontWeight:600,fontFamily:r?.fontFamily||p.typography.fontFamily},children:[O," USDC"]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Network"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("img",{src:v,alt:"Net",style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontWeight:500,fontFamily:r?.fontFamily||p.typography.fontFamily,textTransform:"capitalize"},children:pe})]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Source"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[w?e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("img",{src:Qt[i||1]||qe,style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily},children:i&&fe(i)?.displayName||"Vault"})]}):Ce.map((T,oe)=>e.jsxs("div",{style:{display:"flex",alignItems:"center"},children:[e.jsx("img",{src:Qt[T]||qe,alt:"",style:{width:"14px",height:"14px",borderRadius:"50%",marginRight:"4px"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily,textTransform:"capitalize"},children:fe(T)?.displayName||"Chain"}),oe<Ce.length-1&&e.jsx("span",{style:{marginRight:"4px"},children:","})]},T)),Ce.length===0&&!w&&e.jsx("span",{children:"-"})]})]})]})]}),w&&e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",marginBottom:p.spacing.sm,padding:"12px",backgroundColor:"#F9FAFB",borderRadius:p.borderRadius.sm,border:"1px solid #E5E7EB"},children:[e.jsx("input",{type:"checkbox",id:"withdraw-to-spicenet",checked:X,onChange:T=>ee(T.target.checked),disabled:S||B,style:{width:"18px",height:"18px",cursor:S||B?"not-allowed":"pointer",accentColor:r?.primaryColor||"#EF4444"}}),e.jsx("label",{htmlFor:"withdraw-to-spicenet",style:{fontSize:p.typography.fontSize.sm,color:p.colors.text,cursor:S||B?"not-allowed":"pointer",fontFamily:r?.fontFamily||p.typography.fontFamily,userSelect:"none"},children:"Withdraw to Spicenet"})]}),G&&e.jsx("div",{style:{padding:"10px 12px",backgroundColor:"#FEE2E2",borderRadius:p.borderRadius.sm,marginBottom:p.spacing.sm},children:e.jsx("p",{style:{fontSize:p.typography.fontSize.xs,color:"#991B1B",margin:0,fontFamily:r?.fontFamily||p.typography.fontFamily},children:G})}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:N,disabled:!he||S||B,theme:p,styles:{...r,button:{...r?.button,backgroundColor:B?"#10B981":r?.primaryColor||"#EF4444",hoverBackgroundColor:B?"#059669":r?.primaryColor?`${r.primaryColor}dd`:"#DC2626",color:"white",fontWeight:600,borderRadius:p.borderRadius.sm,padding:"14px"}},children:B?"DONE":S?"PROCESSING...":c||"WITHDRAW"})]})})});Kt.displayName="WithdrawModal";const Ds=({isOpen:t,onClose:o,styles:r,className:n="",postWithdrawBatches:s,postWithdrawInstruction:c,postWithdrawInstructionLabel:i,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u})=>{const l=a.useContext(Ue);if(!l)return e.jsx("div",{children:"Error: SpiceWithdraw must be used within SpiceFlowProvider"});const C=l.mode||"7702",A=C==="presign"||C==="ondemand",w=l.nativeChainId,[k,p]=a.useState(A?"withdraw":"provider-login"),[b,m]=a.useState(!1),{ready:j,authenticated:y}=Je.usePrivy(),h=gt(),{address:x}=Ae.useAccount(),S=a.useCallback(()=>{m(!0),p("withdraw")},[]),F=a.useCallback(()=>{o()},[o]);return a.useEffect(()=>{if(!t){const B=setTimeout(()=>{p(A?"withdraw":"provider-login"),m(!1)},300);return()=>clearTimeout(B)}},[t,A]),a.useEffect(()=>{if(!A&&t&&k==="provider-login"&&j&&y&&h&&!b){const B=setTimeout(()=>{m(!0),p("withdraw")},100);return()=>clearTimeout(B)}},[A,t,k,j,y,h,b]),t?k==="provider-login"&&!A?e.jsx(Gt,{onAuthSuccess:S,autoTrigger:!0}):k==="withdraw"?e.jsx(Kt,{isOpen:t,onClose:F,styles:r,externalWalletAddress:x,postWithdrawBatches:s,postWithdrawInstruction:c,postWithdrawInstructionLabel:i,nativeChainId:w,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u}):null:null},Ls=t=>{const o=a.useContext(Ue),{walletConnectProjectId:r,useInternalWagmi:n=!0}=t;if(!o)return e.jsx("div",{children:"Error: SpiceWithdraw must be used within SpiceFlowProvider"});const s=a.useMemo(()=>{if(!n)return null;const i=[];o.supportedChainIds.forEach(f=>{const u=fe(f);u?.viemChain&&i.push(u.viemChain)}),i.length===0&&i.push(ts.sepolia,ts.arbitrumSepolia);const d={};i.forEach(f=>{d[f.id]=Ae.http(f.rpc)});const g=[ss.metaMask()];return r&&g.push(ss.walletConnect({projectId:r,showQrModal:!0})),Ae.createConfig({chains:i,connectors:g,transports:d,ssr:!1})},[o.supportedChainIds,r,n]),c=a.useMemo(()=>new es.QueryClient({defaultOptions:{queries:{retry:1,refetchOnWindowFocus:!1}}}),[]);return n&&s?e.jsx(Ae.WagmiProvider,{config:s,children:e.jsx(es.QueryClientProvider,{client:c,children:e.jsx(Ds,{...t})})}):e.jsx(Ds,{...t})};var Zo="";const jt=t=>{const o=Math.round(t*1e5)/1e5;return new Intl.NumberFormat("en-US",{style:"currency",currency:"USD",minimumFractionDigits:0,maximumFractionDigits:5}).format(o)},Ms=t=>{const o=Math.round(t*1e5)/1e5;return new Intl.NumberFormat("en-US",{style:"currency",currency:"USD",minimumFractionDigits:0,maximumFractionDigits:5}).format(o)},Go=({balanceData:t,isLoading:o=!1,styles:r,className:n="",showHeader:s=!0,onAccountClick:c,onDepositClick:i,onWithdrawClick:d,vaultBalance:g,fetchVaultBalance:f,postWithdrawInstruction:u,postWithdrawInstructionLabel:l,destinationChainId:C,destinationTokenAddress:A,customSections:w,showDefaultSections:k=!0})=>{const p=a.useContext(Ue),b=(p?.mode||"7702")!=="7702",m=p?.appName||"Spicenet",[j,y]=a.useState(!0),[h,x]=a.useState(!1),[S,F]=a.useState(!1),[B,I]=a.useState(null),{isConnected:G}=Ae.useAccount(),{disconnect:P}=Ae.useDisconnect();a.useEffect(()=>{b&&f&&f().then(E=>{const U=Math.round(E*1e5)/1e5;I(U)}).catch(E=>{console.error("Error fetching vault balance:",E),I(null)})},[b,f]);const _=()=>{y(!j)},$=a.useMemo(()=>{if(!t.freeCollateralItems)return null;const E=t.freeCollateralItems.filter(ee=>ee.name==="USDC");if(E.length===0)return null;const U=E.reduce((ee,H)=>ee+H.balance,0),X=[];return E.forEach(ee=>{ee.networks&&ee.networks.forEach(H=>{(H===1||H===11155111||H===8453||H===84532)&&(X.includes(H)||X.push(H))})}),X.length===0&&X.push(1,8453),{name:"USDC",totalBalance:U,networks:X,subtitle:E[0]?.subtitle||"USD COIN"}},[t.freeCollateralItems]),J=a.useMemo(()=>{if(b){if(B!==null)return B;if(g!=null)return g}return t.freeCollateralItems?t.freeCollateralItems.reduce((E,U)=>E+U.balance,0):t.freeCollateral},[b,B,g,t.freeCollateralItems,t.freeCollateral]),M=E=>j?E:"******",z=()=>{P(),x(!1),F(!1)};return e.jsxs("div",{className:n,style:{borderRadius:"16px",backgroundColor:"#D5D5D5",width:"522px",padding:"8px",fontFamily:r?.fontFamily||'"Helvetica Neue", sans-serif',...r?.container},children:[e.jsxs("div",{style:{background:" white",display:"flex",flexDirection:"column"},children:[e.jsxs("div",{style:{backgroundColor:"#E9E9E9",borderRadius:"0 0 16px 16px",padding:"20px",display:"flex",flexFlow:"column"},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"4px"},children:[e.jsxs("p",{style:{fontSize:"14px",fontWeight:500,fontFamily:'"IBM Plex Mono", monospace',color:"#0E0D0B",margin:0},children:[m.toUpperCase()," BALANCE"]}),G&&e.jsx("button",{onClick:z,"aria-label":"Disconnect wallet",style:{width:"36px",height:"36px",borderRadius:"8px",border:"1px solid #E5E7EB",background:"white",display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",transition:"all 0.2s ease",padding:"8px"},onMouseEnter:E=>{E.currentTarget.style.backgroundColor="#F3F4F6"},onMouseLeave:E=>{E.currentTarget.style.backgroundColor="white"},children:e.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4"}),e.jsx("polyline",{points:"16 17 21 12 16 7"}),e.jsx("line",{x1:"21",y1:"12",x2:"9",y2:"12"})]})})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[t.percentageChange!==void 0&&t.percentageChange!==null&&e.jsxs("div",{style:{fontSize:"13px",fontWeight:700,color:t.percentageChange>=0?"#009C51":"#EF4444"},children:[t.percentageChange>=0?"+":"",t.percentageChange.toFixed(2),"%"]}),e.jsx("button",{onClick:_,style:{background:"none",border:"none",cursor:"pointer",padding:"8px",display:"flex",alignItems:"center",justifyContent:"center",transition:"opacity 0.2s ease"},onMouseEnter:E=>{E.currentTarget.style.opacity="0.7"},onMouseLeave:E=>{E.currentTarget.style.opacity="1"},children:j?e.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",children:[e.jsx("path",{d:"M12 5C7 5 2.73 8.11 1 12.5C2.73 16.89 7 20 12 20C17 20 21.27 16.89 23 12.5C21.27 8.11 17 5 12 5Z",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"}),e.jsx("circle",{cx:"12",cy:"12.5",r:"3",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"})]}):e.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",children:[e.jsx("path",{d:"M12 5C7 5 2.73 8.11 1 12.5C2.73 16.89 7 20 12 20C17 20 21.27 16.89 23 12.5C21.27 8.11 17 5 12 5Z",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"}),e.jsx("path",{d:"M3 3L21 21",stroke:"#1A1A1A",strokeWidth:"2",strokeLinecap:"round"})]})})]}),e.jsx("p",{style:{fontSize:"40px",fontWeight:700,color:"black"},children:M(jt(b&&B!==null?B:b&&g!==void 0&&g!==null?g:t.totalBalance))}),e.jsxs("div",{style:{display:"flex",gap:"12px",marginTop:"16px"},children:[e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:()=>{i?i():x(!0)},styles:r,children:"DEPOSIT"}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:()=>{d?d():F(!0)},styles:r,children:"WITHDRAW"})]})]}),e.jsxs("div",{style:{background:"white",padding:"12px 20px",borderRadius:"12px"},children:[k&&e.jsx(Ws,{title:"FREE COLLATERAL",icon:Zo,amount:M(Ms(J)),defaultExpanded:!1,children:b&&(B!==null||g!=null)?e.jsx(Mt,{name:"USDC",balance:M(jt(B!==null?B:g)),subtitle:"USD COIN",icon:ut,onClick:c?()=>c("usdc-vault"):void 0}):$?e.jsx(Mt,{name:$.name,balance:M(jt($.totalBalance)),subtitle:$.subtitle,networks:$.networks,icon:ut,onClick:c?()=>c($.name):void 0}):t.freeCollateralItems&&t.freeCollateralItems.length>0?t.freeCollateralItems.map((E,U)=>e.jsxs(a.Fragment,{children:[e.jsx(Mt,{name:E.name,balance:M(jt(E.balance)),subtitle:E.subtitle,networks:E.networks,icon:E.name==="USDC"?ut:void 0,onClick:c?()=>c(E.id):void 0}),U<t.freeCollateralItems.length-1&&e.jsx("div",{style:{height:"1px",backgroundColor:"#D0D2D8",margin:"4px 0"}})]},E.id)):e.jsx("div",{style:{padding:"12px 0",color:"#6B7280",fontSize:"13px",fontFamily:'"IBM Plex Mono", monospace'},children:"No collateral items available"})}),w&&w.length>0&&w.filter(E=>E&&E.id&&E.title&&typeof E.title=="string"&&E.title.trim().length>0).map(E=>e.jsx(Ws,{title:E.title,icon:E.icon||void 0,amount:M(Ms(E.totalBalance||0)),defaultExpanded:E.defaultExpanded!==void 0?E.defaultExpanded:!1,children:E.items&&E.items.length>0?E.items.map((U,X)=>e.jsxs(a.Fragment,{children:[e.jsx(Mt,{name:U.name,balance:M(jt(U.balance)),subtitle:U.subtitle,networks:U.networks,icon:U.name==="USDC"?ut:void 0,onClick:c?()=>c(U.id):void 0}),X<E.items.length-1&&e.jsx("div",{style:{height:"1px",backgroundColor:"#D0D2D8",margin:"4px 0"}})]},U.id||`item-${X}`)):e.jsx("div",{style:{padding:"12px 0",color:"#6B7280",fontSize:"13px",fontFamily:'"IBM Plex Mono", monospace'},children:E.emptyMessage||"No items available"})},E.id))]})]}),h&&e.jsx(Bs,{isOpen:h,onClose:()=>x(!1),styles:r,className:n}),S&&e.jsx(Ls,{isOpen:S,onClose:()=>F(!1),styles:r,className:n,vaultBalance:g,fetchVaultBalance:f,postWithdrawInstruction:u,postWithdrawInstructionLabel:l,destinationChainId:C,destinationTokenAddress:A})]})},Ko=({pairLabel:t,pairApr:o,pairAddressLabel:r,lpLabel:n,onViewPool:s,styles:c,theme:i,token1:d,token2:g})=>e.jsxs("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #a8a8a7",borderRadius:"6px",padding:"16px 16px",width:"100%",display:"flex",flexDirection:"column",gap:"10px",boxShadow:"4px 4px 0px #cdcfd1"},children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:e.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsxs("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:c?.fontFamily||i.typography.fontFamily,fontSize:"15px",fontWeight:500,color:"#0e0d0b",lineHeight:"22px"},children:t}),e.jsx("div",{style:{backgroundColor:"rgba(2, 212, 112, 0.17)",border:"0.5px solid #02d470",borderRadius:"3px",padding:"0 10px",height:"12px",display:"flex",alignItems:"center"},children:e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"8px",fontWeight:600,color:"#009c51",textTransform:"uppercase",lineHeight:"1.56"},children:o})})]}),e.jsx("div",{style:{display:"flex",gap:"24px",alignItems:"center"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"10px",fontWeight:500,color:"#7d7c7b",textTransform:"uppercase",lineHeight:"26px",width:"72px"},children:r}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",style:{cursor:"pointer"},onClick:s,children:e.jsx("path",{d:"M2 6L10 6M10 6L6 2M10 6L6 10",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})})]})}),e.jsx("div",{style:{height:"1px",backgroundColor:"#e9e9e9",width:"100%"}}),e.jsxs("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",paddingRight:"5px"},children:[d&&e.jsx("div",{style:{zIndex:2,marginRight:"-8px"},children:e.jsx(ot,{symbol:d.symbol,logoURI:d.logoURI,size:24,theme:i})}),g&&e.jsx("div",{style:{zIndex:1},children:e.jsx(ot,{symbol:g.symbol,logoURI:g.logoURI,size:24,theme:i})}),!d&&!g&&e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"24px",height:"24px",borderRadius:"50%",backgroundColor:"#2775CA",marginRight:"-5px",border:"2px solid white"}}),e.jsx("div",{style:{width:"24px",height:"24px",borderRadius:"50%",backgroundColor:"#26A17B",border:"2px solid white"}})]})]}),e.jsx("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"8px"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center",maxWidth:"199.5px"},children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:e.jsx("span",{style:{fontFamily:c?.fontFamily||i.typography.fontFamily,fontSize:"15px",fontWeight:500,color:"#0e0d0b",lineHeight:"22px"},children:n})}),e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#7d7c7b",strokeWidth:"1",fill:"none"}),e.jsx("path",{d:"M6 3V6M6 9H6.01",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]})]}),e.jsx("svg",{width:"19",height:"19",viewBox:"0 0 12 12",fill:"none",style:{cursor:"pointer"},children:e.jsx("path",{d:"M2 6L10 6M10 6L6 2M10 6L6 10",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})})]})]}),Oo=({selectedAsset:t,availableAssets:o,onAssetSelect:r,disabled:n,styles:s,theme:c})=>{const[i,d]=a.useState(!1),g=a.useRef(null);a.useEffect(()=>{const u=l=>{g.current&&!g.current.contains(l.target)&&i&&d(!1)};return i&&document.addEventListener("mousedown",u),()=>{document.removeEventListener("mousedown",u)}},[i]);const f=u=>{switch(u){case 1:return"Ethereum";case 42161:return"Arbitrum";case 8453:return"Base";case 11155111:return"Sepolia";case 421614:return"Arbitrum Sepolia";default:return`Chain ${u} `}};return e.jsxs("div",{style:{width:"128px",position:"relative"},ref:g,children:[e.jsxs("div",{style:{border:"1px solid #cdcfd1",borderRadius:"6px 6px 0 0",backgroundColor:n?"#e9e9e9":"#ffffff",padding:"8px 12px 8px 8px",display:"flex",alignItems:"center",justifyContent:"space-between",cursor:n?"not-allowed":"pointer"},onClick:()=>!n&&d(!i),children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(ot,{symbol:t.asset.symbol,logoURI:t.asset.logoURI,size:30,theme:c}),e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.asset.symbol})]}):e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"rgba(60, 62, 66, 0.44)",lineHeight:"1.5",letterSpacing:"-0.56px"},children:"Select Asset"})}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#3c3e42",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]}),e.jsx("div",{style:{backgroundColor:"#d4d3d3",border:"1px solid #cdcfd1",borderRadius:"0 0 6px 6px",padding:"0 10px",height:"24px",display:"flex",alignItems:"center",gap:"4px"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(Ft,{chainId:t.asset.chainId,theme:c,size:11}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"12px",fontWeight:400,color:"#3c3e42",textTransform:"uppercase",lineHeight:"1.56"},children:f(t.asset.chainId)})]}):e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"12px",height:"12px",borderRadius:"50%",backgroundColor:"#ffffff"}}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"12px",fontWeight:400,color:"#3c3e42",textTransform:"uppercase",lineHeight:"1.56"},children:"Solana"})]})}),i&&e.jsx("div",{style:{position:"absolute",top:"100%",left:0,right:0,marginTop:"4px",backgroundColor:"#ffffff",border:"1px solid #cdcfd1",borderRadius:"6px",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:1e3,maxHeight:"200px",overflowY:"auto"},children:o.map(u=>e.jsxs("button",{onClick:()=>{r(u),d(!1)},style:{width:"100%",padding:"12px",display:"flex",alignItems:"center",gap:"8px",border:"none",backgroundColor:"transparent",cursor:"pointer",textAlign:"left"},onMouseEnter:l=>{l.currentTarget.style.backgroundColor="#f3f4f6"},onMouseLeave:l=>{l.currentTarget.style.backgroundColor="transparent"},children:[e.jsx(ot,{symbol:u.symbol,logoURI:u.logoURI,size:24,theme:c}),e.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"4px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"#3c3e42"},children:u.symbol}),e.jsx(Ft,{chainId:u.chainId,theme:c,size:12})]}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"10px",color:"#6b7280"},children:f(u.chainId)})]})]},`${u.address} -${u.chainId} `))})]})},Xo=({progressIndex:t=0})=>{const o=(r,n)=>{const s=n===t,c=n===4,i=c?"#ea4b4b":r>0?"#3C3E42":"transparent";return e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",style:{opacity:s?1:.5},children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:c?i:"none",stroke:c?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!c&&r>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${r>.5?1:0} 1 ${7+6.84375*Math.sin(r*2*Math.PI)} ${7-6.84375*Math.cos(r*2*Math.PI)} Z`,fill:i})]},n)};return e.jsxs("div",{style:{display:"flex",gap:"10px",height:"14px",alignItems:"center",justifyContent:"flex-end",opacity:.7},children:[o(0,0),o(.25,1),o(.5,2),o(.75,3),o(1,4)]})},Qs=({assetInput:t,availableAssets:o,onAssetChange:r,disabled:n,styles:s,theme:c})=>{const i=d=>{r(d,t?.selectedAsset?.amount||"")};return e.jsx("div",{style:{backgroundColor:"#e9e9e9",border:"0.5px solid #a8a8a7",borderRadius:"6px",padding:"16px",height:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",justifyContent:"space-between",height:"100%"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"16px"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:"Amount"}),e.jsx("div",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"40px",fontWeight:700,color:n?"rgba(14, 13, 11, 0.16)":"#0e0d0b",lineHeight:"1.08",letterSpacing:"-1.2px"},children:t?.selectedAsset?.amount||"0.00"})]}),e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"#7d7c7b",lineHeight:"20px",letterSpacing:"-0.14px"},children:t?.usdValue||"$0.00"})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",justifyContent:"space-between",height:"100%",gap:"12px"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",alignItems:"flex-end"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:t?.balanceLabel||"Balance: 0.00"}),e.jsx(Oo,{selectedAsset:t?.selectedAsset,availableAssets:o,onAssetSelect:i,disabled:n,styles:s,theme:c})]}),e.jsx(Xo,{progressIndex:t?.progressIndex||0})]})]})})},$o=({isOpen:t,onClose:o,pairLabel:r,pairApr:n,pairAddressLabel:s,lpLabel:c,onViewPool:i,primaryAsset:d,secondaryAsset:g,onPrimaryAssetChange:f,onSecondaryAssetChange:u,availableAssets:l,showSecondaryAsset:C,onAddSecondaryAsset:A,alertVariant:w="none",crossNetworkCopy:k,onClickDepositCollateral:p,transactionDetailsCollapsed:b=!0,onToggleTransactionDetails:m,transactionDetails:j,isSubmitting:y=!1,canSubmit:h=!1,onSubmit:x,styles:S})=>{const F=de.defaultTheme,[B,I]=a.useState(!1),G=e.jsxs("div",{style:{display:"flex",gap:"6px",alignItems:"flex-start",flexWrap:"nowrap"},children:[e.jsxs("p",{style:{fontSize:"10px",color:"rgba(0, 0, 0, 0.4)",margin:0,lineHeight:"1.6",letterSpacing:"0.2px",fontFamily:S?.fontFamily||F.typography.fontFamily,flex:1},children:["Provide liquidity to ",r," pair using assets on 10+ networks in a one-click native UX, powered by Spice Flow"]}),e.jsxs("button",{onClick:()=>I(!B),style:{backgroundColor:"#f8c3c3",border:"0.436px solid #ea4b4b",borderRadius:"6.184px",padding:"2px 4px",height:"auto",display:"flex",alignItems:"center",gap:"4px",cursor:"pointer",fontFamily:"'IBM Plex Mono', monospace",fontSize:"7.902px",fontWeight:500,color:"#c33f3f",textTransform:"uppercase",letterSpacing:"-0.3556px",flexShrink:0,marginTop:"2px"},children:[e.jsx("span",{children:B?"Collapse":"Expand to learn more"}),e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 12 12",fill:"none",style:{transform:B?"rotate(180deg)":"none"},children:e.jsx("path",{d:"M3 4.5L6 7.5L9 4.5",stroke:"#c33f3f",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})]});return e.jsx(xt,{isOpen:t,onClose:o,title:"Provide Liquidity with Spice Flow",subtitle:G,styles:S,theme:F,maxWidth:"422px",children:e.jsxs("div",{style:{padding:"0 26px",display:"flex",flexDirection:"column",gap:"16px"},children:[w==="crossNetworkAssets"&&k&&e.jsx("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #c33f3f",borderRadius:"6px",padding:"10px 10px",display:"flex",flexDirection:"column",gap:"15px"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"flex-start"},children:[e.jsxs("svg",{width:"18",height:"18",viewBox:"0 0 12 12",fill:"none",style:{marginTop:"2px",flexShrink:0},children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#ed6969",strokeWidth:"1"}),e.jsx("text",{x:"6",y:"8",textAnchor:"middle",fontSize:"8",fill:"#ed6969",children:"i"})]}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:0,lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:k.summary}),e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:"4px 0 0 0",lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:k.body})]})]})}),w==="noCollateral"&&e.jsxs("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #c33f3f",borderRadius:"6px",padding:"15px 10px",display:"flex",flexDirection:"column",gap:"15px"},children:[e.jsx(de.Button,{variant:"primary",onClick:p,style:{backgroundColor:"#ea4b4b",border:"1px solid rgba(0, 0, 0, 0.53)",borderRadius:"3px",padding:"4px 47px",height:"37px",fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:"#0e0d0b",textTransform:"uppercase",letterSpacing:"-0.42px"},children:"Deposit collateral"}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[e.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 12 12",fill:"none",style:{flexShrink:0},children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#7d7c7b",strokeWidth:"1"}),e.jsx("text",{x:"6",y:"8",textAnchor:"middle",fontSize:"8",fill:"#7d7c7b",children:"i"})]}),e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:0,lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:"You don't have any usable collateral in your Spicenet Account to provide liquidity. Deposit USDC/USDT collateral to get started."})]})})]}),e.jsx(Ko,{pairLabel:r,pairApr:n,pairAddressLabel:s,lpLabel:c,onViewPool:i,styles:S,theme:F,token1:d?.selectedAsset?.asset,token2:g?.selectedAsset?.asset}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:[e.jsx(Qs,{assetInput:d,availableAssets:l,onAssetChange:f,styles:S,theme:F}),e.jsx("button",{onClick:A,style:{position:"absolute",left:"50%",top:"50%",transform:"translate(-50%, -50%)",width:"40px",height:"40px",borderRadius:"10px",backgroundColor:"#ea4b4b",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",zIndex:10},children:e.jsx("svg",{width:"18",height:"18",viewBox:"0 0 18 18",fill:"none",children:e.jsx("path",{d:"M9 5V13M5 9H13",stroke:"#ffffff",strokeWidth:"2",strokeLinecap:"round"})})}),e.jsx(Qs,{assetInput:g,availableAssets:l,onAssetChange:u||(()=>{}),disabled:!g?.selectedAsset,styles:S,theme:F})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[e.jsxs("button",{onClick:m,style:{display:"flex",gap:"4px",alignItems:"center",background:"none",border:"none",cursor:"pointer",padding:0},children:[e.jsx("span",{style:{fontFamily:S?.fontFamily||F.typography.fontFamily,fontSize:"12px",fontWeight:600,color:"#757171"},children:"Transaction Details"}),e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 12 12",fill:"none",style:{transform:b?"rotate(0deg)":"rotate(180deg)",transition:"transform 0.2s"},children:e.jsx("path",{d:"M3 4.5L6 7.5L9 4.5",stroke:"#757171",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]}),!b&&j&&j.length>0&&e.jsx("div",{style:{padding:"12px 0",display:"flex",flexDirection:"column",gap:"8px"},children:j.map((P,_)=>e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:"#52565b",textTransform:"uppercase",lineHeight:"1.56"},children:P.label}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:P.isPositive?"#1aa362":"#52565b",textTransform:"uppercase",lineHeight:"1.56"},children:P.value})]},_))})]}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:x,loading:y,disabled:!h,theme:F,style:{backgroundColor:"#ea4b4b",border:"1px solid #0e0d0b",color:"#0e0d0b",fontFamily:"'IBM Plex Mono', monospace",fontSize:"18px",fontWeight:500,textTransform:"uppercase",padding:"8px 0"},children:"Provide Liquidity"})]})})},_o=()=>{const[t,o]=a.useState("0");return{fromAmount:t,setFromAmount:o}},en=()=>{const[t,o]=a.useState("0"),r=a.useCallback(n=>{o(n)},[]);return{toAmount:t,setToAmount:o,updateToAmount:r}},tn=()=>{const[t,o]=a.useState("0");return{assetAmount:t,setAssetAmount:o}};exports.ConnectWalletModal=Es,exports.CrossChainDepositModal=Io,exports.DepositModal=js,exports.DepositWidget=gs,exports.DepositWidgetModal=wo,exports.LpModal=$o,exports.ProviderLogin=Gt,exports.SelectChainModal=Is,exports.SpiceBalance=Go,exports.SpiceDeposit=Bs,exports.SpiceFlowProvider=mo,exports.SpiceFlowProviderContext=Ue,exports.SpiceWithdraw=Ls,exports.SwapWidget=Ao,exports.WithdrawModal=Kt,exports.WithdrawWidget=fs,exports.WithdrawWidgetModal=Eo,exports.fetchBalances=zt,exports.relayerService=we,exports.useAssetInput=tn,exports.useAssets=Vt,exports.useEmbeddedWalletAddress=gt,exports.useFromInput=_o,exports.useSpiceAssets=us,exports.useSpiceBalance=Rs,exports.useStatus=kt,exports.useToInputUpdate=en,exports.useWallet=Lt;
|
|
123
|
+
`})]})},js=a.memo(({isOpen:t,onClose:o,onDepositSelect:r,postDepositBatches:n,supportedChains:s,styles:c,onDepositAssetChange:i,assetInputHook:d,externalWalletAddress:g,allowedTokens:f,onDepositAmountChange:u,allowSecondAsset:l=!1,destinationChainId:C,destinationTokenAddress:A,postDepositInstruction:w,postDepositInstructionLabel:k,nativeChainId:p,airdrop:b=!1,sponsorGas:m=!1})=>{const j=a.useContext(He)?.mode||"7702",y=d?.assetAmount||"",h=de.defaultTheme,x={...h,typography:{...h.typography,fontFamily:c?.fontFamily||h.typography.fontFamily},colors:{...h.colors,primary:c?.primaryColor||h.colors.primary,primaryHover:c?.primaryColor?`${c.primaryColor}dd`:h.colors.primaryHover}},{ready:S,authenticated:F}=Je.usePrivy(),{signAuthorization:B}=Je.useSign7702Authorization();Je.useSignMessage();const{wallets:I}=Je.useWallets(),G=gt(),P=I?.find(D=>D.connectorType==="embedded"),_=j!="7702",$=_?!!g:S&&F&&!!G,J=G,M=g,{data:z}=Ae.useWalletClient(),{switchChainAsync:E}=Ae.useSwitchChain(),{chain:H}=Ae.useAccount(),X=a.useRef(H);a.useEffect(()=>{X.current=H},[H]);const ee=a.useRef(null),[U,ne]=a.useState([]),[xe]=a.useState([]),{assets:ue,loading:Ee,refreshAssets:R}=Vt({address:M||J,supportedChains:s,fetchBalances:zt,refreshInterval:8e3}),q=a.useMemo(()=>{const D=s.flatMap(V=>Rt(V,ue)).filter(V=>V.balance>BigInt(0));return f&&f.length>0?D.filter(V=>f.includes(V.symbol.toLowerCase())||V.isNative&&f.includes("native")):D},[s,ue,f]),pe=a.useMemo(()=>{if(!U[0]?.asset)return[];const D=U[0].asset.chainId;return q.filter(V=>V.chainId===D)},[q,U]),[v,N]=a.useState(!1),[O,se]=a.useState(null),[ae,Z]=a.useState("idle"),[he,Ce]=a.useState(null),[T,oe]=a.useState(!1),[le,Se]=a.useState(null),[ve,ke]=a.useState(!1),[Ie,ce]=a.useState(!1),[ze,W]=a.useState(null),[K,ie]=a.useState(null),{intentStatus:me,startStatusPolling:$e,clearStatus:Y}=kt({checkStepStatus:(D,V)=>we.checkStepStatus(D,V),pollingInterval:1e3});a.useEffect(()=>{U.length>0&&y!==U[0]?.amount&&ne(D=>{if(D.length===0)return D;const V=[...D];return V[0]={...V[0],amount:y||""},V})},[y]),a.useEffect(()=>{U.length!==0&&ne(D=>D.map(V=>{if(!V.asset)return V;const Q=q.find(L=>L.chainId===V.asset.chainId&&L.address.toLowerCase()===V.asset.address.toLowerCase());return Q?{...V,asset:Q,amount:V.amount}:V}))},[ue]);const te=a.useRef(null);a.useEffect(()=>{if(_&&me?.overallStatus==="success"&&w&&ae==="idle"){const D=te.current;D&&(async()=>{try{Z("executing"),await w(D),Z("success"),Se(D),oe(!0)}catch(V){console.error("postDepositInstruction failed:",V),Z("error"),Ce(V?.message||"Post-deposit instruction failed")}finally{te.current=null,ee.current=null}})()}},[me?.overallStatus,_,ae]);const Fe=a.useCallback(()=>{se(null)},[]);a.useEffect(()=>{t||(oe(!1),Se(null))},[t]);const De=a.useCallback(D=>{const V=D?.message||String(D||""),Q=D?.details||"",L=`${V} ${Q}`.toLowerCase();return L.includes("internal json-rpc error")||L.includes("internal error")||L.includes("an internal error was received")?"RPC Network error. Try switching your MetaMask RPC endpoint or try again.":V||"Transaction failed"},[]),_e=a.useCallback(async()=>{const D=M||J,V="0x111115763723b53395308ec4c9ab9d5fb0844cae";if(W(null),ie(null),!D){ie("Connect your wallet before requesting an airdrop");return}const Q=U[0]?.asset?.chainId??s[0];if(!Q){ie("No chain selected for airdrop");return}if(!z){ie("External wallet not connected");return}ce(!0);try{if(H?.id!==Q){W("Switching network...");try{await E({chainId:Q});let Me=0;const We=20;for(;Me<We&&(await new Promise(Oe=>setTimeout(Oe,100)),X.current?.id!==Q);)Me++;if(X.current?.id!==Q)throw new Error(`Failed to switch to chain ${Q}. Please switch manually in your wallet.`)}catch(Me){throw Me.code===4902||Me.name==="ChainNotConfiguredError"?new Error(`Chain ${Q} is not configured in your wallet. Please add it manually.`):Me}}W("Estimating required gas amount...");const L=Ve(Q),ye=await L.getGasPrice(),je=BigInt(65e3)*ye,Ke=BigInt(120),Te=je*Ke/BigInt(100);W("Sending gas deposit to solver...");const Le=await z.sendTransaction({to:V,value:Te});if(W("Waiting for transaction confirmation..."),(await L.waitForTransactionReceipt({hash:Le,timeout:12e4,pollingInterval:2e3,confirmations:2})).status!=="success")throw new Error("Gas deposit transaction failed");W("Requesting airdrop...");const Be=await we.requestSpiceUsdAirdrop({chainId:Q,address:D});if(!Be.success){ie(Be.errorMessage||"Failed to request airdrop");return}if(Be.txHash||Be.amount){const Me=Be.amount?` ${Be.amount}`:"";W(`Airdrop${Me} requested successfully.`);return}W("Airdrop requested successfully.")}catch(L){const ye=De(L);ie(ye)}finally{ce(!1)}},[J,M,U,s,z,H,E,De]),it=(D,V)=>{ne(Q=>{const L=[...Q];return L[V]={asset:D,amount:L[V]?.amount||""},L}),V===0&&i?.(D),Fe()},et=a.useCallback((D,V)=>{ne(Q=>{const L=[...Q];return L[V]&&(L[V]={...L[V],amount:D}),L}),Fe(),V===0&&(d?.setAssetAmount(D),u?.(D))},[Fe,d,u]),Ze=a.useCallback(()=>{U.length<2&&ne(D=>[...D,{asset:null,amount:""}])},[U.length]),be=a.useCallback(D=>{ne(V=>V.filter((Q,L)=>L!==D)),Fe()},[Fe]),[Re,ge]=a.useState(!1),[nt,tt]=a.useState(null),ft=()=>{if(U.length===0||!U[0]?.asset)return;const D=U.filter(ye=>ye.asset&&ye.amount&&parseFloat(ye.amount)>0);if(D.length===0)return;const V=D[0],Q=fe(V.asset.chainId),L=D.map(ye=>`${ye.amount} ${ye.asset.symbol}`).join(", ");tt({network:Q?.displayName||`Chain ${V.asset.chainId}`,amount:L,symbol:"",chainId:V.asset.chainId}),ge(!0)},Ge=async()=>{const D=U.filter(Q=>Q.asset&&Q.amount&&parseFloat(Q.amount)>0);if(D.length===0){se("Please select an asset and enter an amount");return}if(!M){se("External wallet not connected. Please connect your wallet in the previous step.");return}if(console.log("IS NON 7702",_),!_){if(!J||!G){se("Missing embedded wallet address");return}if(!S||!F){se("Please authenticate with Privy to continue");return}}N(!0),se(null);let V=!1;try{const Q=D[0].asset.chainId;if(!z)throw new Error("External wallet not connected");if(H?.id!==Q){se("Wrong chain selected. Switching network..."),console.log("Attempting to switch to chain:",{chainId:Q,currentChainId:H?.id,chainName:st(Q)});try{await E({chainId:Q});let L=0;const ye=20;for(;L<ye;){if(await new Promise(je=>setTimeout(je,100)),X.current?.id===Q){se(null);break}L++}if(X.current?.id!==Q)throw new Error(`Failed to switch to chain ${Q}. Please switch manually in your wallet.`);se(null)}catch(L){throw L.code===4902||L.name==="ChainNotConfiguredError"?new Error(`Chain ${Q} is not configured in your wallet. Please add it manually.`):L}}if(_)if(p&&Q===p){if(!w)throw new Error("Post-deposit instruction is required for native chain deposits");const L=fe(Q),ye=D.map(je=>`${je.amount} ${je.asset.symbol}`).join(", ");if(tt({network:L?.displayName||`Chain ${Q}`,amount:ye,symbol:"",chainId:Q}),ge(!0),D[0]?.amount){const je=D[0].amount;Z("executing");try{await w(je),Z("success"),Se(je),oe(!0)}catch(Ke){console.error("postDepositInstruction failed:",Ke),Z("error"),Ce(Ke?.message||"Post-deposit instruction failed")}}R(),r&&r(D[0].asset)}else{if(!C)throw new Error("Destination chain ID is required for non-7702 mode");const L=pt(Q),ye=[];let je=null;for(const Te of D){const Le=re.parseUnits(Te.amount,Te.asset.decimals),Be=wt(Te.asset.address),Me=Te.asset.isNative||Dt(Be);console.log("Sending transaction via MetaMask:",{chainId:Q,isNative:Me,tokenAddress:Be,delegateContract:L,amount:Le.toString(),walletChainId:z.chain?.id});const We=Me?await z.sendTransaction({to:L,value:Le}):await z.sendTransaction({to:Be,data:re.encodeFunctionData({abi:ct,functionName:"transfer",args:[L,Le]})});je||(je=We);const Oe=Ve(Q);console.log(`Waiting for transaction receipt: ${We}`);const Pe=await Oe.waitForTransactionReceipt({hash:We,timeout:12e4,pollingInterval:2e3,confirmations:2});if(console.log("Transaction receipt:",{hash:Pe.transactionHash,blockNumber:Pe.blockNumber,status:Pe.status,confirmations:2}),Pe.status!=="success")throw new Error(`Transfer to delegate contract failed for ${Te.asset.symbol}`);const lt=await Oe.getBlockNumber()-Pe.blockNumber;console.log(`Transaction has ${lt} confirmations`),lt<2&&(console.log("Waiting for additional confirmations..."),await new Promise(mt=>setTimeout(mt,3e3))),ee.current||(ee.current=[]),ee.current.push({txHash:We,sender:M,tokenAddress:Be,chainId:Q,amount:Le.toString(),user:M}),console.log("Stored deposit data for later submission:",{txHash:We,sender:M,tokenAddress:Be,chainId:Q,amount:Le.toString()}),ye.push({tokenAddress:Be,tokenAmount:Le.toString(),sender:M,receiver:L})}if(!je)throw new Error("No transaction hash generated");const Ke=await Ve(Q).getBlockNumber();if(console.log("Final block number before relayer submission:",Ke),console.log("All transactions confirmed, submitting to relayer..."),!A)throw new Error("Destination token address is required for bridging");if(m&&p){const Te=re.parseUnits("0.05",18);ye.push({tokenAddress:"0x0",tokenAmount:Te.toString(),sender:M,receiver:L})}if(j==="ondemand"){const Te={to:L,value:BigInt(0),data:"0x"},Le=await ns(C,A);let Be=BigInt(0);for(const Ne of ye){const Ut=BigInt(Ne.tokenAmount),Ht=wt(Ne.tokenAddress),yt=D.find(Xe=>wt(Xe.asset.address).toLowerCase()===Ht.toLowerCase());let Qe;yt?Qe=yt.asset.decimals:Qe=await ns(Q,wt("0x0"));const Ue=eo(Ut,Qe,Le);Be+=Ue}const Me={chainId:Q,tokenTransfers:ye.map(Ne=>({from:Ne.sender,to:Ne.receiver,token:Ne.tokenAddress,amount:BigInt(Ne.tokenAmount)})),call:Te},We={chainId:C,tokenTransfers:[{from:"solver",to:M,token:A,amount:Be}],call:{to:A,value:BigInt(0),data:"0x"}},Oe={user:M,intents:[{mode:"non-7702:on-demand",chainBatches:[Me,We]}]},Pe=await we.createAction(Oe),lt=Pe.actionId,mt=Pe.intentIds[0];if(!je)throw new Error("No transaction hash available");$e(mt,Et([{chainId:Q,calls:[Te]},{chainId:C,calls:[We.call]}],Ne=>st(Ne))),await we.executeStep(lt,0,0,{action:"execute",hash:je}),console.log("[DepositModal] Deposit executed, solver transfer completed by API"),D[0]?.amount&&(te.current=D[0].amount),R(),r&&r(D[0].asset),ge(!1)}else throw new Error("Presign mode not yet fully supported for cross-chain deposits")}else{const L="0xeee2b52e7CFe6e2168341a34cEB783b68FEdf1A2",ye=[],je=[];for(const Qe of D){const Ue=re.parseUnits(Qe.amount,Qe.asset.decimals),Xe=wt(Qe.asset.address),Bt=Qe.asset.isNative||Dt(Xe);console.log("Sending EIP-7702 transaction via MetaMask:",{chainId:Q,isNative:Bt,tokenAddress:Xe,amount:Ue.toString(),recipient:J,walletChainId:z.chain?.id});const bt=Bt?await z.sendTransaction({to:J,value:Ue}):await z.sendTransaction({to:Xe,data:re.encodeFunctionData({abi:ct,functionName:"transfer",args:[J,Ue]})}),Ot=Ve(Q);console.log(`Waiting for transaction receipt (EIP-7702): ${bt}`);const Ct=await Ot.waitForTransactionReceipt({hash:bt,timeout:12e4,pollingInterval:2e3,confirmations:2});if(console.log("Transaction receipt (EIP-7702):",{hash:Ct.transactionHash,blockNumber:Ct.blockNumber,status:Ct.status,confirmations:2}),Ct.status!=="success")throw new Error(`Transfer to embedded wallet failed for ${Qe.asset.symbol}`);const Xt=await Ot.getBlockNumber()-Ct.blockNumber;console.log(`Transaction has ${Xt} confirmations`),Xt<2&&(console.log("Waiting for additional confirmations..."),await new Promise(Ts=>setTimeout(Ts,3e3))),console.log("Calling submitSpiceDeposit (EIP-7702) with:",{txHash:bt,sender:M,tokenAddress:Xe,chainId:Q,amount:Ue.toString(),user:J,isDeposit:!0}),await we.submitSpiceDeposit({txHash:bt,sender:M,tokenAddress:Xe,chainId:Q,amount:Ue.toString(),user:J,isDeposit:!0}),console.log(`Successfully submitted deposit for txHash: ${bt}`),ye.push(Bt?{to:L,value:Ue,data:"0x"}:{to:Xe,value:BigInt(0),data:re.encodeFunctionData({abi:ct,functionName:"transfer",args:[L,Ue]})}),je.push({tokenAddress:Xe,tokenAmount:Ue,sender:J,receiver:Bt?"":L})}if(m&&p&&J){const Qe=re.parseUnits("0.05",18);je.push({tokenAddress:"0x0",tokenAmount:Qe.toString(),sender:J,receiver:J})}const Ke=Ve(Q),Te=await Ke.getBlockNumber(),Le=[{chainId:Q,recentBlock:Te,calls:ye},...n??[]];if(!J)throw new Error("Address not available");const Be=pt(Q),Me=await Ye.getAccountNonce(J,Ke),We=await B({contractAddress:Be,chainId:Q,nonce:Number(Me)}),Oe=Ye.hashChainBatches(Le),Pe=Math.floor(Date.now()/1e3)+60*10,lt=Ye.getIntentHash(0n,BigInt(Pe),Oe);if(!P)throw new Error("Embedded wallet not available for signing");const mt=await P.getEthereumProvider(),Ne=await re.createWalletClient({account:P.address,transport:re.custom(mt)}).signMessage({account:P.address,message:{raw:lt}});if(!Ne)throw new Error("Failed to sign intent authorization");const Ut={mode:"7702",signatureType:"ecdsa",signature:Ne,nbf:0,exp:Pe,chainBatches:Oe.map((Qe,Ue)=>({hash:Qe.hash,chainId:Le[Ue].chainId,tokenTransfers:[],calls:Le[Ue].calls}))},Ht={user:J,chainAuthorizations:[{r:We.r,s:We.s,yParity:We.yParity,chainId:We.chainId,nonce:We.nonce,address:We.address}],intents:[Ut]},yt=await we.createAction(Ht);if(yt){const Qe=Et(Le,Ue=>st(Ue));$e(yt.intentIds[0],Qe),R(),r&&r(D[0].asset)}}}catch(Q){V=!0;let L="Deposit failed";Q?.code===4001||Q?.code==="ACTION_REJECTED"?L="Transaction rejected by user":Q?.code===-32603?L="Internal wallet error. Please try again.":Q?.message?.includes("insufficient funds")?L="Insufficient funds for transaction":Q?.message?.includes("User rejected")||Q?.message?.includes("user rejected")?L="Transaction rejected by user":Q?.message?.includes("does not match the target chain")||Q?.message?.includes("Current Chain ID")?L="Network mismatch detected. Please click the button again to proceed.":L=De(Q),se(L)}finally{N(!1),V||!me&&ae!=="idle"||ge(!1)}},Us=U.length>0&&U[0]?.asset&&U[0]?.amount&&parseFloat(U[0].amount)>0&&$&&!v,Hs=()=>{if(v)return"Executing Deposit...";if(!$)return"Wallet Not Connected";if(j==="7702"){if(!S)return"Loading...";if(!F)return"Authentication Required"}return U[0]?.asset?U[0]?.amount?"DEPOSIT":"ENTER AMOUNT":"SELECT TOKEN"};return t?e.jsx(xt,{isOpen:t,onClose:o,title:"Deposit to your Spicenet account",subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"3px"},children:[e.jsx("img",{src:vs,alt:"Info",style:{width:"10px",height:"10px",marginTop:"4px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"12px",color:"#6b7280",margin:"0",lineHeight:"1.4",fontFamily:"system-ui, -apple-system, sans-serif"},children:"Deposit collateral to your Spicenet Account from 9+ EVM blockchains."})]}),overlayContent:Re||me||ae!=="idle"&&w?e.jsx("div",{}):void 0,styles:c,theme:x,children:e.jsxs("div",{style:{padding:"24px 24px 5px 24px"},children:[U.map((D,V)=>{const Q=U.length===1?"Deposit":`Asset ${V+1}`;return e.jsxs("div",{style:{marginBottom:x.spacing.md,position:"relative"},children:[b&&V===0&&e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"8px"},children:[e.jsx("div",{style:{fontSize:"11px",color:K?"#b91c1c":"#047857",fontFamily:c?.fontFamily||x.typography.fontFamily,flex:1,minWidth:0},children:K||ze||""}),e.jsxs("div",{style:{display:"flex",gap:"4px",flexShrink:0,alignItems:"center"},children:[e.jsx("button",{onClick:_e,disabled:Ie,style:{padding:"4px 8px",borderRadius:"4px",border:"1px solid #D1D5DB",background:"#E5E7EB",color:"#4B5563",fontSize:"11px",fontWeight:500,cursor:Ie?"default":"pointer",transition:"all 0.2s",display:"flex",alignItems:"center"},onMouseEnter:L=>{Ie||(L.currentTarget.style.color="#1F2937",L.currentTarget.style.background="#D1D5DB")},onMouseLeave:L=>{L.currentTarget.style.color="#4B5563",L.currentTarget.style.background="#E5E7EB"},children:Ie?"Requesting...":"Airdrop"}),e.jsxs("div",{onMouseEnter:()=>ke(!0),onMouseLeave:()=>ke(!1),style:{position:"relative",width:"14px",height:"14px",borderRadius:"50%",backgroundColor:"#9CA3AF",color:"white",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"9px",fontWeight:"bold",cursor:"help",flexShrink:0},children:["i",ve&&e.jsxs("div",{style:{position:"absolute",bottom:"calc(100% + 8px)",right:0,backgroundColor:"#1F2937",color:"white",padding:"8px 12px",borderRadius:"6px",fontSize:"12px",whiteSpace:"nowrap",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:100},children:["This is testnet USDC, and it won't be available on mainnet",e.jsx("div",{style:{position:"absolute",top:"100%",right:"10px",width:0,height:0,borderLeft:"6px solid transparent",borderRight:"6px solid transparent",borderTop:"6px solid #1F2937"}})]})]})]})]}),e.jsx(ht,{assets:V===0?q:pe,selectedAsset:D||void 0,onAssetSelect:L=>it(L,V),onAmountChange:L=>et(L,V),loading:Ee,label:Q,showBalance:!0,theme:x,styles:c,allowSecondAsset:l&&V===0,onAddAsset:Ze,canAddAsset:U.length===1&&!!U[0]?.asset}),V===1&&e.jsx("button",{onClick:()=>be(V),style:{position:"absolute",top:"-2px",right:"-2px",background:"rgba(255, 255, 255, 0.9)",border:"1px solid #e5e7eb",borderRadius:"50%",cursor:"pointer",color:x.colors.textMuted,fontSize:"16px",padding:"2px",width:"22px",height:"22px",display:"flex",alignItems:"center",justifyContent:"center",transition:"all 0.2s",boxShadow:"0 1px 3px rgba(0, 0, 0, 0.1)"},onMouseEnter:L=>{L.currentTarget.style.color="#ef4444",L.currentTarget.style.background="#fff",L.currentTarget.style.borderColor="#fecaca"},onMouseLeave:L=>{L.currentTarget.style.color=x.colors.textMuted,L.currentTarget.style.background="rgba(255, 255, 255, 0.9)",L.currentTarget.style.borderColor="#e5e7eb"},title:"Remove asset",children:"\xD7"})]},`asset-${V}`)}),U.length===0&&e.jsxs("div",{style:{marginBottom:x.spacing.md},children:[b&&e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"8px"},children:[e.jsx("div",{style:{fontSize:"11px",color:K?"#b91c1c":"#047857",fontFamily:c?.fontFamily||x.typography.fontFamily,flex:1,minWidth:0},children:K||ze||""}),e.jsxs("div",{style:{display:"flex",gap:"4px",flexShrink:0,alignItems:"center"},children:[e.jsx("button",{onClick:_e,disabled:Ie,style:{padding:"4px 8px",borderRadius:"4px",border:"1px solid #D1D5DB",background:"#E5E7EB",color:"#4B5563",fontSize:"11px",fontWeight:500,cursor:Ie?"default":"pointer",transition:"all 0.2s",display:"flex",alignItems:"center"},onMouseEnter:D=>{Ie||(D.currentTarget.style.color="#1F2937",D.currentTarget.style.background="#D1D5DB")},onMouseLeave:D=>{D.currentTarget.style.color="#4B5563",D.currentTarget.style.background="#E5E7EB"},children:Ie?"Requesting...":"Airdrop"}),e.jsxs("div",{onMouseEnter:()=>ke(!0),onMouseLeave:()=>ke(!1),style:{position:"relative",width:"14px",height:"14px",borderRadius:"50%",backgroundColor:"#9CA3AF",color:"white",display:"flex",alignItems:"center",justifyContent:"center",fontSize:"9px",fontWeight:"bold",cursor:"help",flexShrink:0},children:["i",ve&&e.jsxs("div",{style:{position:"absolute",bottom:"calc(100% + 8px)",right:0,backgroundColor:"#1F2937",color:"white",padding:"8px 12px",borderRadius:"6px",fontSize:"12px",whiteSpace:"nowrap",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:100},children:["This is testnet USDC, and it won't be available on mainnet",e.jsx("div",{style:{position:"absolute",top:"100%",right:"10px",width:0,height:0,borderLeft:"6px solid transparent",borderRight:"6px solid transparent",borderTop:"6px solid #1F2937"}})]})]})]})]}),e.jsx(ht,{assets:q,selectedAsset:void 0,onAssetSelect:D=>it(D,0),onAmountChange:D=>et(D,0),loading:Ee,label:"Deposit",showBalance:!0,theme:x,styles:c,allowSecondAsset:l,onAddAsset:Ze,canAddAsset:!1},"initial-selector")]}),xe.length>0&&e.jsx("div",{style:{marginBottom:x.spacing.sm},children:e.jsxs("div",{style:{backgroundColor:c?.infoCard?.backgroundColor||c?.tertiaryBackground||(x.mode==="light"?"#f9fafb":x.colors.surface),border:`1px solid ${c?.infoCard?.borderColor||(x.mode==="light"?"#e5e7eb":x.colors.border)}`,borderRadius:c?.infoCard?.borderRadius||x.borderRadius.md,padding:c?.infoCard?.padding||x.spacing.sm},children:[e.jsx("div",{style:{fontSize:c?.infoCard?.title?.fontSize||x.typography.fontSize.xs,fontWeight:c?.infoCard?.title?.fontWeight||x.typography.fontWeight.medium,color:c?.infoCard?.title?.color||x.colors.text,fontFamily:c?.infoCard?.title?.fontFamily||x.typography.fontFamily,marginBottom:"4px"},children:"Deposit Batches Ready"}),e.jsxs("div",{style:{fontSize:c?.infoCard?.description?.fontSize||x.typography.fontSize.xs,color:c?.infoCard?.description?.color||x.colors.textSecondary,fontFamily:c?.infoCard?.description?.fontFamily||x.typography.fontFamily},children:[xe.length," deposit batch",xe.length>1?"es":""," across chains:"," ",[...new Set(xe.map(D=>D.chainId))].join(", ")]})]})}),e.jsx(qo,{intentStatus:me,postDepositSuccess:T,postDepositAmount:le,postDepositStatus:ae,postDepositInstructionLabel:k,sourceChainName:U[0]?.asset?.chainId?st(U[0].asset.chainId):"Destination Chain"}),e.jsx(Yo,{isOpen:Re||!!me||ae!=="idle"&&!!w,onClose:()=>{ge(!1),me&&Y();const D=ae==="success"&&!me,V=me?.overallStatus==="success"&&ae==="success"&&w;(D||V)&&o()},onConfirm:Ge,data:nt,isExecuting:v,error:O,theme:x,styles:c,intentStatus:me,postDepositStatus:ae,hasPostDepositInstruction:!!w}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:0,marginBottom:0,margin:0,padding:0},children:e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:ft,loading:v,disabled:!Us||!$,theme:x,styles:{...c,button:{...c?.button}},children:Hs()})})]})}):null}),Gt=t=>{const[o,r]=a.useState(!1),n=a.useContext(He);if(a.useEffect(()=>{r(!0)},[]),!o)return e.jsx("div",{className:t.className,children:e.jsx("button",{disabled:!0,style:{padding:"12px 24px",fontSize:"16px",backgroundColor:"#ccc",color:"white",border:"none",borderRadius:"4px",cursor:"not-allowed"},children:"Loading..."})});if(!n){const s='ProviderLogin must be used within SpiceFlowProvider. Please wrap your app with <SpiceFlowProvider provider="privy" | "dynamic">.';return e.jsx("div",{className:t.className,children:e.jsx("button",{onClick:()=>{t.onAuthError&&t.onAuthError(s)},style:{padding:"12px 24px",fontSize:"16px",backgroundColor:"#dc2626",color:"white",border:"none",borderRadius:"4px",cursor:"pointer"},children:"Provider Not Found"})})}return n.provider==="privy"?e.jsx(Gs.PrivyLogin,{...t}):n.provider==="dynamic"?e.jsx(Zs.DynamicLogin,{...t}):null},Po=({isOpen:t,onClose:o,styles:r,className:n="",postDepositBatches:s,allowedTokens:c,onDepositAmountChange:i,allowSecondAsset:d,destinationChainId:g,destinationTokenAddress:f,postDepositInstruction:u,postDepositInstructionLabel:l,airdrop:C=!1,sponsorGas:A=!1})=>{const w=a.useContext(He);if(!w)return e.jsx("div",{children:"Error: SpiceDeposit must be used within SpiceFlowProvider"});const k=(w.mode||"7702")!="7702",p=w.nativeChainId,[b,m]=a.useState("select-chain"),[j,y]=a.useState(null),[h,x]=a.useState(!1),{ready:S,authenticated:F}=Je.usePrivy(),B=gt(),{isConnected:I,address:G}=Ae.useAccount(),P=a.useCallback(z=>{const E=parseInt(z);y(E),x(!1),m(k?"connect-wallet":"provider-login")},[k]),_=a.useCallback(()=>{x(!0),m("connect-wallet")},[]),$=a.useCallback(async()=>{if((!I||!G)&&(await new Promise(z=>setTimeout(z,500)),!I||!G)){alert("Please connect your wallet first");return}m("deposit")},[I,G]),J=a.useCallback(()=>{o()},[o]),M=a.useCallback(()=>{m("select-chain")},[]);return a.useEffect(()=>{if(!t){const z=setTimeout(()=>{m("select-chain"),y(null),x(!1)},300);return()=>clearTimeout(z)}},[t]),a.useEffect(()=>{t&&b==="deposit"&&!j&&m("select-chain")},[t,b,j]),a.useEffect(()=>{if(!k&&t&&b==="provider-login"&&S&&F&&B&&!h){const z=setTimeout(()=>{x(!0),m("connect-wallet")},100);return()=>clearTimeout(z)}},[k,t,b,S,F,B,h]),t?b==="select-chain"?e.jsx(Is,{isOpen:t,onClose:J,onChainSelect:P,supportedChains:w.supportedChainIds}):b==="provider-login"&&!k?e.jsx(Gt,{onAuthSuccess:_,autoTrigger:!0}):b==="connect-wallet"?e.jsx(Es,{isOpen:t,onClose:J,onContinue:$,requiredChainId:j||void 0,onBackToChainSelector:M}):b==="deposit"&&j?e.jsx(js,{isOpen:t,onClose:J,supportedChains:[j],styles:r,className:n,externalWalletAddress:G,postDepositBatches:s,allowedTokens:c,onDepositAmountChange:i,allowSecondAsset:d,destinationChainId:g,destinationTokenAddress:f,postDepositInstruction:u,postDepositInstructionLabel:l,nativeChainId:p,airdrop:C,sponsorGas:A}):null:null},Bs=t=>a.useContext(He)?e.jsx(Po,{...t}):e.jsx("div",{children:"Error: SpiceDeposit must be used within SpiceFlowProvider"}),Ws=({title:t,icon:o,amount:r,children:n,defaultExpanded:s=!1})=>{const[c,i]=a.useState(s),d=g=>{g?.stopPropagation(),i(!c)};return e.jsxs("div",{style:{backgroundColor:"#FAFAFA",borderRadius:"12px",padding:"12px 16px",border:"0.5px solid #939291",boxShadow:"4px 4px 0px 0px #E1E1E1",marginBottom:"12px"},children:[e.jsxs("div",{onClick:d,onKeyDown:g=>{(g.key==="Enter"||g.key===" ")&&(g.preventDefault(),d())},role:"button",tabIndex:0,style:{display:"flex",alignItems:"center",justifyContent:"space-between",cursor:"pointer",width:"100%"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px",flex:1,minWidth:0},children:[o&&e.jsx("img",{src:o,alt:t,style:{width:"20px",height:"20px",flexShrink:0},onError:g=>{const f=g.target;f.style.display="none"}}),e.jsx("span",{className:"ibm-plex-mono",style:{fontSize:"14px",fontWeight:500,fontFamily:'"IBM Plex Mono", monospace',color:"#17171A",letterSpacing:"0.5px",textTransform:"uppercase",whiteSpace:"nowrap",overflow:"hidden",textOverflow:"ellipsis"},children:t})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",flexShrink:0},children:[e.jsx("span",{style:{fontSize:"18px",fontWeight:600,color:"#262523",whiteSpace:"nowrap"},children:r}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",style:{transform:c?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.2s ease",flexShrink:0},children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#262523",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round"})})]})]}),c&&n&&e.jsx("div",{style:{marginTop:"16px",paddingTop:"16px",borderTop:"1px solid #D0D2D8"},children:n})]})},Jo=t=>t===1||t===11155111?qe:t===8453||t===84532?at:null,Mt=({name:t,balance:o,icon:r,subtitle:n,networks:s,onClick:c})=>e.jsxs("div",{onClick:c,style:{display:"flex",alignItems:"center",justifyContent:"space-between",padding:"12px 0",cursor:c?"pointer":"default",transition:"opacity 0.2s ease"},onMouseEnter:i=>{c&&(i.currentTarget.style.opacity="0.7")},onMouseLeave:i=>{i.currentTarget.style.opacity="1"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"12px"},children:[r&&e.jsx("div",{style:{width:"25px",height:"25px",borderRadius:"50%",display:"flex",alignItems:"center",justifyContent:"center",overflow:"hidden"},children:typeof r=="string"?e.jsx("img",{src:r,alt:t,style:{width:"100%",height:"100%",objectFit:"cover"},onError:i=>{console.warn(`Failed to load image: ${r}`);const d=i.target;d.style.display="none"}}):r}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"2px",flex:1},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px"},children:[e.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1A1A1A",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",letterSpacing:"0.3px"},children:t}),t==="USDC"&&e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",backgroundColor:"#ef4444",display:"flex",alignItems:"center",justifyContent:"center",flexShrink:0},children:e.jsx("svg",{style:{width:"12px",height:"12px",color:"white"},fill:"currentColor",viewBox:"0 0 20 20",children:e.jsx("path",{fillRule:"evenodd",d:"M16.707 5.293a1 1 0 010 1.414l-8 8a1 1 0 01-1.414 0l-4-4a1 1 0 011.414-1.414L8 12.586l7.293-7.293a1 1 0 011.414 0z",clipRule:"evenodd"})})}),s&&s.length>0&&e.jsx("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:s.map(i=>{const d=Jo(i);return d?e.jsx("img",{src:d,alt:`Chain ${i}`,style:{width:"16px",height:"16px",borderRadius:"50%",objectFit:"cover"}},i):e.jsx(Ft,{chainId:i,size:16},i)})})]}),n&&e.jsx("span",{style:{fontSize:"11px",fontWeight:400,color:"#6B7280",fontFamily:'"IBM Plex Mono", monospace',textTransform:"none"},children:n})]})]}),e.jsx("span",{style:{fontSize:"14px",fontWeight:600,color:"#1A1A1A",fontFamily:'"IBM Plex Mono", monospace'},children:o})]}),Rs=({address:t,enabled:o=!0,refetchInterval:r})=>{const[n,s]=a.useState(null),[c,i]=a.useState(!1),[d,g]=a.useState(null),[f,u]=a.useState(!1),l=a.useCallback(async()=>{if(!t||!o){s(null),u(!1);return}i(!0),g(null);try{const C=await fetch(`${Yt}/spicedeposit/${t}`);if(!C.ok)throw new Error(`Failed to fetch balance: ${C.status}`);const A=await C.json();if(A.success&&A.data?.tokens&&Array.isArray(A.data.tokens)){const w=[];let k=0;A.data.tokens.forEach(p=>{const b=p.chainId,m=p.tokenAddress,j=parseFloat(p.amount||"0");if(j>0){const y=fe(b),h=m.toLowerCase()==="0x0"||m.toLowerCase()==="0x0000000000000000000000000000000000000000"||m.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee";let x=18,S="TOKEN",F=m.slice(0,6)+"..."+m.slice(-4);if(h)x=y?.nativeCurrency?.decimals||18,S=y?.nativeCurrency?.symbol||"ETH",F=y?.nativeCurrency?.name||"Native Token";else{const I=y?.supportedTokens?.find(G=>G.address.toLowerCase()===m.toLowerCase());I&&(x=I.decimals,S=I.symbol,F=I.name)}const B=j/Math.pow(10,x);B>0&&(w.push({id:`${S.toLowerCase()}-${b}`,name:S,balance:B,subtitle:F,iconColor:"#2775CA",networks:[b]}),k+=B)}}),k>0&&w.length>0?(s({totalBalance:k,percentageChange:0,tradingAccounts:[],freeCollateral:k,freeCollateralItems:w,defiPositions:0,defiPositionsItems:[],credit:0,creditItems:[]}),u(!0)):(s(null),u(!1))}else s(null),u(!1)}catch(C){const A=C instanceof Error?C.message:"Failed to fetch balance";g(A),console.error("Error fetching Spice balance:",C),s(null),u(!1)}finally{i(!1)}},[t,o]);return a.useEffect(()=>{o&&t&&l()},[t,o,l]),a.useEffect(()=>{if(!o||!t||!r)return;const C=setInterval(()=>{l()},r);return()=>clearInterval(C)},[t,o,r,l]),{balanceData:n,loading:c,error:d,hasBalance:f,refetch:l}},Qt={1:qe,11155111:qe,421614:vt,42161:vt,8453:at,84532:at},Kt=a.memo(({isOpen:t,onClose:o,styles:r,externalWalletAddress:n,postWithdrawInstruction:s,postWithdrawInstructionLabel:c,nativeChainId:i,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u,filterChainIds:l,preSelectedTokens:C})=>{const A=a.useContext(He)?.mode||"7702",w=A==="presign"||A==="ondemand",k=de.defaultTheme,p={...k,typography:{...k.typography,fontFamily:r?.fontFamily||k.typography.fontFamily},colors:{...k.colors,primary:r?.primaryColor||k.colors.primary,primaryHover:r?.primaryColor?`${r.primaryColor}dd`:k.colors.primaryHover}},b=gt(),m=b,[j,y]=a.useState([]),[h,x]=a.useState(""),[S,F]=a.useState(!1),[B,I]=a.useState(!1),[G,P]=a.useState(null),[_,$]=a.useState(!1),J=a.useRef(null),[M,z]=a.useState(null),[E,H]=a.useState(!0),[X,ee]=a.useState(!1),U=n,{data:ne}=Ae.useWalletClient(),{balanceData:xe,refetch:ue}=Rs({address:m,enabled:!!m&&(!w||X)});a.useEffect(()=>{if(xe&&xe.freeCollateralItems){const T=[];xe.freeCollateralItems.forEach(oe=>{oe.networks&&oe.networks.length>0&&oe.networks.forEach(le=>{if(l&&l.length>0&&!l.includes(le))return;const Se=fe(le);if(Se){const ve=C&&C.length>0?C.some(ke=>ke.toLowerCase()===oe.name.toLowerCase()):!0;T.push({id:`${oe.name.toLowerCase()}-${le}`,chainId:le,chainName:Se.displayName,tokenAddress:"",tokenSymbol:oe.name,tokenName:oe.subtitle||oe.name,balance:oe.balance,selected:ve})}})}),y(T)}},[xe,l,C]),a.useEffect(()=>{const T=oe=>{J.current&&!J.current.contains(oe.target)&&$(!1)};return document.addEventListener("mousedown",T),()=>{document.removeEventListener("mousedown",T)}},[]),a.useEffect(()=>{t||(I(!1),F(!1),P(null),z(null),ee(!1))},[t]),a.useEffect(()=>{w&&g&&t&&g().then(T=>{const oe=Math.round(T*1e6)/1e6;z(oe)}).catch(T=>{console.error("Error fetching vault balance:",T),z(null)})},[w,g,t]);const Ee=a.useCallback(T=>{y(oe=>oe.map(le=>le.id===T?{...le,selected:!le.selected}:le))},[]),R=a.useMemo(()=>j.filter(T=>T.selected),[j]),q=a.useMemo(()=>R.reduce((T,oe)=>T+oe.balance,0),[R]),pe=a.useMemo(()=>f?fe(f)?.displayName||"Unknown Chain":"Arbitrum",[f]),v=a.useMemo(()=>f?Qt[f]||qe:vt,[f]),N=a.useCallback(async()=>{F(!0),P(null);try{if(w){if(!s)throw new Error("Withdraw instruction not provided");if(!h||h.trim()==="")throw new Error("Please enter an amount to withdraw");const T=parseFloat(h);if(isNaN(T)||T<=0)throw new Error("Invalid withdrawal amount");const oe=M??d;if(oe!=null&&T>oe)throw new Error(`Insufficient balance. Available: ${oe.toFixed(6).replace(/\.?0+$/,"")}`);if(console.log("Non-EIP-7702 withdraw from vault:",{amount:h,numericAmount:T,availableBalance:oe,fetchedVaultBalance:M,vaultBalance:d,withdrawToSpiceNet:X}),await s(h),X){if(!n)throw new Error("External wallet address is required for SpiceNet deposit");if(!ne)throw new Error("Wallet client not available");if(!f)throw new Error("Destination chain ID is required for SpiceNet withdrawal");if(!u)throw new Error("Destination token address is required for SpiceNet withdrawal");const le=pt(f),Se=fe(f);let ve=6;if(Se?.supportedTokens){const ie=Se.supportedTokens.find(me=>me.address.toLowerCase()===u.toLowerCase());ie?ve=ie.decimals:Se.nativeCurrency&&(ve=Se.nativeCurrency.decimals)}const ke=re.parseUnits(h,ve),Ie=u.toLowerCase()==="0x0"||u.toLowerCase()==="0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"||u.toLowerCase()==="0x0000000000000000000000000000000000000000",ce=Ie?await ne.sendTransaction({to:le,value:ke}):await ne.sendTransaction({to:u,data:re.encodeFunctionData({abi:ct,functionName:"transfer",args:[le,ke]})});console.log("Transferring to delegate contract:",{txHash:ce,delegateContract:le,amount:h,chainId:f});const ze=await Ve(f).waitForTransactionReceipt({hash:ce,timeout:6e4,pollingInterval:5e3,confirmations:1});console.log("Delegate contract transfer confirmed:",ze);const W=Ie?"0x0":u.toLowerCase();console.log("Calling submitSpiceDeposit with:",{user:b,txHash:ce,sender:n,tokenAddress:W,chainId:f,amount:ke.toString(),isDeposit:!1});const K=await we.submitSpiceDeposit({user:n,txHash:ce,sender:n,tokenAddress:W,chainId:f,amount:ke.toString(),isDeposit:!1});K.success?console.log("Successfully submitted SpiceNet deposit"):console.error("Failed to submit Spicenet deposit:",K.error?.message),ue&&await ue()}I(!0),F(!1),setTimeout(()=>{o()},1500)}else console.log("EIP-7702 withdraw:",{selectedAssets:R,totalAmount:q,destination:U}),I(!0),F(!1),setTimeout(()=>{o()},1500)}catch(T){console.error("Withdrawal error:",T),P(T instanceof Error?T.message:"Withdrawal failed"),F(!1),I(!1)}},[w,h,s,d,M,R,q,o,U,X,ne,f,u,ue]);if(!t)return null;const O=h||"0",se=(parseFloat(O)*1).toFixed(2),ae=w?M!==null?M:d:null,Z=w?ae!=null?ae.toFixed(6).replace(/\.?0+$/,""):"0.00":q.toFixed(2),he=w?h&&!isNaN(parseFloat(h))&&parseFloat(h)>0&&(ae==null||parseFloat(h)<=ae):h&&!isNaN(parseFloat(h))&&parseFloat(h)>0&&parseFloat(h)<=q,Ce=Array.from(new Set(R.map(T=>T.chainId)));return e.jsx(xt,{isOpen:t,onClose:o,title:"Withdraw from your account",subtitle:e.jsxs("div",{style:{display:"flex",alignItems:"flex-start",gap:"3px"},children:[e.jsx("img",{src:vs,alt:"Info",style:{width:"10px",height:"10px",marginTop:"4px",flexShrink:0}}),e.jsx("p",{style:{fontSize:"12px",color:"#6b7280",margin:"0",lineHeight:"1.4",fontFamily:"system-ui, -apple-system, sans-serif"},children:"Withdraw collateral from your account to 10+ EVM blockchains."})]}),styles:r,theme:p,children:e.jsxs("div",{style:{padding:"24px 24px 5px 24px"},children:[e.jsxs("div",{style:{backgroundColor:"#E9E9E9",borderRadius:p.borderRadius.md,padding:`${p.spacing.sm} ${p.spacing.md}`,marginBottom:p.spacing.md},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"4px"},children:[e.jsx("span",{style:{fontSize:r?.assetSelector?.label?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.label?.color||p.colors.textMuted,fontWeight:r?.assetSelector?.label?.fontWeight,fontFamily:r?.assetSelector?.label?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:"Amount"}),e.jsxs("div",{ref:J,style:{position:"relative"},children:[e.jsxs("button",{onClick:()=>$(!_),style:{display:"flex",alignItems:"center",gap:"6px",background:"none",border:"none",cursor:"pointer",padding:"2px 4px",borderRadius:"4px",transition:"background-color 0.2s"},onMouseEnter:T=>T.currentTarget.style.backgroundColor="rgba(0,0,0,0.05)",onMouseLeave:T=>T.currentTarget.style.backgroundColor="transparent",children:[e.jsxs("span",{style:{fontSize:r?.assetSelector?.balance?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.balance?.color||p.colors.textMuted,fontFamily:r?.assetSelector?.balance?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:["Balance: ",Z]}),e.jsx("div",{style:{width:"16px",height:"16px",borderRadius:"50%",border:"1.5px solid #EF4444",display:"flex",alignItems:"center",justifyContent:"center",color:"#EF4444",fontSize:"10px",backgroundColor:"transparent"},children:e.jsx("span",{style:{fontWeight:700,lineHeight:1},children:"\xB7\xB7\xB7"})})]}),_&&!w&&e.jsxs("div",{style:{position:"absolute",top:"100%",right:"0",marginTop:"8px",backgroundColor:"white",borderRadius:"12px",padding:"12px",boxShadow:"0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05)",border:"1px solid #E5E7EB",width:"220px",zIndex:50},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",fontSize:"11px",color:"#6B7280",marginBottom:"10px",fontFamily:'"IBM Plex Mono", monospace',borderBottom:"1px solid #F3F4F6",paddingBottom:"8px"},children:[e.jsx("span",{children:"TOTAL BALANCE"}),e.jsxs("span",{style:{color:"#111827",fontWeight:600},children:[Z," USDC"]})]}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:j.map(T=>e.jsxs("label",{style:{display:"flex",alignItems:"center",justifyContent:"space-between",cursor:"pointer",fontSize:"12px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px"},children:[e.jsx("input",{type:"checkbox",checked:T.selected,onChange:()=>Ee(T.id),style:{accentColor:"#EF4444",width:"14px",height:"14px"}}),e.jsx("img",{src:Qt[T.chainId]||qe,alt:T.chainName,style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",fontSize:"11px"},children:T.chainName})]}),e.jsxs("span",{style:{fontFamily:'"IBM Plex Mono", monospace',fontSize:"11px"},children:[T.balance.toFixed(2)," USDC"]})]},T.id))})]})]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"flex-start",marginBottom:"6px"},children:[e.jsx("input",{type:"text",value:h,onChange:T=>{const oe=T.target.value;(oe===""||/^\d*\.?\d*$/.test(oe))&&x(oe)},placeholder:"0.0",style:{background:"transparent",border:"none",outline:"none",fontSize:r?.assetSelector?.amountInput?.fontSize||p.typography.fontSize["3xl"],fontWeight:r?.assetSelector?.amountInput?.fontWeight||p.typography.fontWeight.medium,color:r?.assetSelector?.amountInput?.color||p.colors.text,fontFamily:r?.assetSelector?.amountInput?.fontFamily||r?.fontFamily||p.typography.fontFamily,width:"50%"}}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",width:"auto",borderRadius:"10px",minWidth:"120px",border:"1px solid #CDCFD1"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",backgroundColor:"#E9E9E9",borderRadius:"10px",padding:"8px 12px",cursor:"pointer",marginBottom:"4px"},children:[e.jsx("img",{src:rt,alt:"USDC",style:{width:"32px",height:"32px"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.base,fontWeight:500,color:"#3C3E42",fontFamily:r?.fontFamily||p.typography.fontFamily},children:"USDC"}),e.jsx("span",{style:{fontSize:"14px",color:"#3C3E42"},children:"\u25BC"})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"6px",backgroundColor:"#D4D3D3",borderRadius:"0 0 10px 10px",padding:"6px 12px",borderTop:"1px solid #CDCFD1"},children:[e.jsx("img",{src:v,alt:"Network",style:{width:"16px",height:"16px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.sm,color:"#3C3E42",fontFamily:'"IBM Plex Mono", monospace',textTransform:"uppercase",fontWeight:500},children:pe})]})]})]}),e.jsx("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:e.jsxs("span",{style:{fontSize:r?.assetSelector?.balance?.fontSize||p.typography.fontSize.xs,color:r?.assetSelector?.balance?.color||p.colors.textMuted,fontFamily:r?.assetSelector?.balance?.fontFamily||r?.fontFamily||p.typography.fontFamily},children:["$",se]})})]}),e.jsxs("div",{style:{marginBottom:p.spacing.sm},children:[e.jsxs("div",{onClick:()=>H(!E),style:{display:"flex",alignItems:"center",gap:"6px",marginBottom:E?"12px":"0",cursor:"pointer",userSelect:"none"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Transaction Details"}),e.jsx("span",{style:{fontSize:"10px",color:p.colors.textMuted,transform:E?"rotate(180deg)":"rotate(0deg)",transition:"transform 0.2s"},children:"\u25B2"})]}),E&&e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"10px"},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"To"}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily},children:U?`${U.slice(0,6)}...${U.slice(-4)}`:"..."})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Amount"}),e.jsxs("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontWeight:600,fontFamily:r?.fontFamily||p.typography.fontFamily},children:[O," USDC"]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Network"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("img",{src:v,alt:"Net",style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontWeight:500,fontFamily:r?.fontFamily||p.typography.fontFamily,textTransform:"capitalize"},children:pe})]})]}),e.jsxs("div",{style:{display:"flex",justifyContent:"space-between"},children:[e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.textMuted,fontFamily:r?.fontFamily||p.typography.fontFamily},children:"Source"}),e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[w?e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("img",{src:Qt[i||1]||qe,style:{width:"14px",height:"14px",borderRadius:"50%"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily},children:i&&fe(i)?.displayName||"Vault"})]}):Ce.map((T,oe)=>e.jsxs("div",{style:{display:"flex",alignItems:"center"},children:[e.jsx("img",{src:Qt[T]||qe,alt:"",style:{width:"14px",height:"14px",borderRadius:"50%",marginRight:"4px"}}),e.jsx("span",{style:{fontSize:p.typography.fontSize.xs,color:p.colors.text,fontFamily:r?.fontFamily||p.typography.fontFamily,textTransform:"capitalize"},children:fe(T)?.displayName||"Chain"}),oe<Ce.length-1&&e.jsx("span",{style:{marginRight:"4px"},children:","})]},T)),Ce.length===0&&!w&&e.jsx("span",{children:"-"})]})]})]})]}),w&&e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"8px",marginBottom:p.spacing.sm,padding:"12px",backgroundColor:"#F9FAFB",borderRadius:p.borderRadius.sm,border:"1px solid #E5E7EB"},children:[e.jsx("input",{type:"checkbox",id:"withdraw-to-spicenet",checked:X,onChange:T=>ee(T.target.checked),disabled:S||B,style:{width:"18px",height:"18px",cursor:S||B?"not-allowed":"pointer",accentColor:r?.primaryColor||"#EF4444"}}),e.jsx("label",{htmlFor:"withdraw-to-spicenet",style:{fontSize:p.typography.fontSize.sm,color:p.colors.text,cursor:S||B?"not-allowed":"pointer",fontFamily:r?.fontFamily||p.typography.fontFamily,userSelect:"none"},children:"Withdraw to Spicenet"})]}),G&&e.jsx("div",{style:{padding:"10px 12px",backgroundColor:"#FEE2E2",borderRadius:p.borderRadius.sm,marginBottom:p.spacing.sm},children:e.jsx("p",{style:{fontSize:p.typography.fontSize.xs,color:"#991B1B",margin:0,fontFamily:r?.fontFamily||p.typography.fontFamily},children:G})}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:N,disabled:!he||S||B,theme:p,styles:{...r,button:{...r?.button,backgroundColor:B?"#10B981":r?.primaryColor||"#EF4444",hoverBackgroundColor:B?"#059669":r?.primaryColor?`${r.primaryColor}dd`:"#DC2626",color:"white",fontWeight:600,borderRadius:p.borderRadius.sm,padding:"14px"}},children:B?"DONE":S?"PROCESSING...":c||"WITHDRAW"})]})})});Kt.displayName="WithdrawModal";const Ds=({isOpen:t,onClose:o,styles:r,className:n="",postWithdrawBatches:s,postWithdrawInstruction:c,postWithdrawInstructionLabel:i,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u})=>{const l=a.useContext(He);if(!l)return e.jsx("div",{children:"Error: SpiceWithdraw must be used within SpiceFlowProvider"});const C=l.mode||"7702",A=C==="presign"||C==="ondemand",w=l.nativeChainId,[k,p]=a.useState(A?"withdraw":"provider-login"),[b,m]=a.useState(!1),{ready:j,authenticated:y}=Je.usePrivy(),h=gt(),{address:x}=Ae.useAccount(),S=a.useCallback(()=>{m(!0),p("withdraw")},[]),F=a.useCallback(()=>{o()},[o]);return a.useEffect(()=>{if(!t){const B=setTimeout(()=>{p(A?"withdraw":"provider-login"),m(!1)},300);return()=>clearTimeout(B)}},[t,A]),a.useEffect(()=>{if(!A&&t&&k==="provider-login"&&j&&y&&h&&!b){const B=setTimeout(()=>{m(!0),p("withdraw")},100);return()=>clearTimeout(B)}},[A,t,k,j,y,h,b]),t?k==="provider-login"&&!A?e.jsx(Gt,{onAuthSuccess:S,autoTrigger:!0}):k==="withdraw"?e.jsx(Kt,{isOpen:t,onClose:F,styles:r,externalWalletAddress:x,postWithdrawBatches:s,postWithdrawInstruction:c,postWithdrawInstructionLabel:i,nativeChainId:w,vaultBalance:d,fetchVaultBalance:g,destinationChainId:f,destinationTokenAddress:u}):null:null},Ls=t=>{const o=a.useContext(He),{walletConnectProjectId:r,useInternalWagmi:n=!0}=t;if(!o)return e.jsx("div",{children:"Error: SpiceWithdraw must be used within SpiceFlowProvider"});const s=a.useMemo(()=>{if(!n)return null;const i=[];o.supportedChainIds.forEach(f=>{const u=fe(f);u?.viemChain&&i.push(u.viemChain)}),i.length===0&&i.push(ts.sepolia,ts.arbitrumSepolia);const d={};i.forEach(f=>{d[f.id]=Ae.http(f.rpc)});const g=[ss.metaMask()];return r&&g.push(ss.walletConnect({projectId:r,showQrModal:!0})),Ae.createConfig({chains:i,connectors:g,transports:d,ssr:!1})},[o.supportedChainIds,r,n]),c=a.useMemo(()=>new es.QueryClient({defaultOptions:{queries:{retry:1,refetchOnWindowFocus:!1}}}),[]);return n&&s?e.jsx(Ae.WagmiProvider,{config:s,children:e.jsx(es.QueryClientProvider,{client:c,children:e.jsx(Ds,{...t})})}):e.jsx(Ds,{...t})};var Zo="";const jt=t=>{const o=Math.round(t*1e5)/1e5;return new Intl.NumberFormat("en-US",{style:"currency",currency:"USD",minimumFractionDigits:0,maximumFractionDigits:5}).format(o)},Ms=t=>{const o=Math.round(t*1e5)/1e5;return new Intl.NumberFormat("en-US",{style:"currency",currency:"USD",minimumFractionDigits:0,maximumFractionDigits:5}).format(o)},Go=({balanceData:t,isLoading:o=!1,styles:r,className:n="",showHeader:s=!0,onAccountClick:c,onDepositClick:i,onWithdrawClick:d,vaultBalance:g,fetchVaultBalance:f,postWithdrawInstruction:u,postWithdrawInstructionLabel:l,destinationChainId:C,destinationTokenAddress:A,customSections:w,showDefaultSections:k=!0})=>{const p=a.useContext(He),b=(p?.mode||"7702")!=="7702",m=p?.appName||"Spicenet",[j,y]=a.useState(!0),[h,x]=a.useState(!1),[S,F]=a.useState(!1),[B,I]=a.useState(null),{isConnected:G}=Ae.useAccount(),{disconnect:P}=Ae.useDisconnect();a.useEffect(()=>{b&&f&&f().then(E=>{const H=Math.round(E*1e5)/1e5;I(H)}).catch(E=>{console.error("Error fetching vault balance:",E),I(null)})},[b,f]);const _=()=>{y(!j)},$=a.useMemo(()=>{if(!t.freeCollateralItems)return null;const E=t.freeCollateralItems.filter(ee=>ee.name==="USDC");if(E.length===0)return null;const H=E.reduce((ee,U)=>ee+U.balance,0),X=[];return E.forEach(ee=>{ee.networks&&ee.networks.forEach(U=>{(U===1||U===11155111||U===8453||U===84532)&&(X.includes(U)||X.push(U))})}),X.length===0&&X.push(1,8453),{name:"USDC",totalBalance:H,networks:X,subtitle:E[0]?.subtitle||"USD COIN"}},[t.freeCollateralItems]),J=a.useMemo(()=>{if(b){if(B!==null)return B;if(g!=null)return g}return t.freeCollateralItems?t.freeCollateralItems.reduce((E,H)=>E+H.balance,0):t.freeCollateral},[b,B,g,t.freeCollateralItems,t.freeCollateral]),M=E=>j?E:"******",z=()=>{P(),x(!1),F(!1)};return e.jsxs("div",{className:n,style:{borderRadius:"16px",backgroundColor:"#D5D5D5",width:"522px",padding:"8px",fontFamily:r?.fontFamily||'"Helvetica Neue", sans-serif',...r?.container},children:[e.jsxs("div",{style:{background:" white",display:"flex",flexDirection:"column"},children:[e.jsxs("div",{style:{backgroundColor:"#E9E9E9",borderRadius:"0 0 16px 16px",padding:"20px",display:"flex",flexFlow:"column"},children:[e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center",marginBottom:"4px"},children:[e.jsxs("p",{style:{fontSize:"14px",fontWeight:500,fontFamily:'"IBM Plex Mono", monospace',color:"#0E0D0B",margin:0},children:[m.toUpperCase()," BALANCE"]}),G&&e.jsx("button",{onClick:z,"aria-label":"Disconnect wallet",style:{width:"36px",height:"36px",borderRadius:"8px",border:"1px solid #E5E7EB",background:"white",display:"flex",alignItems:"center",justifyContent:"center",cursor:"pointer",transition:"all 0.2s ease",padding:"8px"},onMouseEnter:E=>{E.currentTarget.style.backgroundColor="#F3F4F6"},onMouseLeave:E=>{E.currentTarget.style.backgroundColor="white"},children:e.jsxs("svg",{width:"20",height:"20",viewBox:"0 0 24 24",fill:"none",stroke:"currentColor",strokeWidth:"2",strokeLinecap:"round",strokeLinejoin:"round",children:[e.jsx("path",{d:"M9 21H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h4"}),e.jsx("polyline",{points:"16 17 21 12 16 7"}),e.jsx("line",{x1:"21",y1:"12",x2:"9",y2:"12"})]})})]}),e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[t.percentageChange!==void 0&&t.percentageChange!==null&&e.jsxs("div",{style:{fontSize:"13px",fontWeight:700,color:t.percentageChange>=0?"#009C51":"#EF4444"},children:[t.percentageChange>=0?"+":"",t.percentageChange.toFixed(2),"%"]}),e.jsx("button",{onClick:_,style:{background:"none",border:"none",cursor:"pointer",padding:"8px",display:"flex",alignItems:"center",justifyContent:"center",transition:"opacity 0.2s ease"},onMouseEnter:E=>{E.currentTarget.style.opacity="0.7"},onMouseLeave:E=>{E.currentTarget.style.opacity="1"},children:j?e.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",children:[e.jsx("path",{d:"M12 5C7 5 2.73 8.11 1 12.5C2.73 16.89 7 20 12 20C17 20 21.27 16.89 23 12.5C21.27 8.11 17 5 12 5Z",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"}),e.jsx("circle",{cx:"12",cy:"12.5",r:"3",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"})]}):e.jsxs("svg",{width:"32",height:"32",viewBox:"0 0 24 24",fill:"none",children:[e.jsx("path",{d:"M12 5C7 5 2.73 8.11 1 12.5C2.73 16.89 7 20 12 20C17 20 21.27 16.89 23 12.5C21.27 8.11 17 5 12 5Z",stroke:"#1A1A1A",strokeWidth:"2",fill:"none"}),e.jsx("path",{d:"M3 3L21 21",stroke:"#1A1A1A",strokeWidth:"2",strokeLinecap:"round"})]})})]}),e.jsx("p",{style:{fontSize:"40px",fontWeight:700,color:"black"},children:M(jt(b&&B!==null?B:b&&g!==void 0&&g!==null?g:t.totalBalance))}),e.jsxs("div",{style:{display:"flex",gap:"12px",marginTop:"16px"},children:[e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:()=>{i?i():x(!0)},styles:r,children:"DEPOSIT"}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:()=>{d?d():F(!0)},styles:r,children:"WITHDRAW"})]})]}),e.jsxs("div",{style:{background:"white",padding:"12px 20px",borderRadius:"12px"},children:[k&&e.jsx(Ws,{title:"FREE COLLATERAL",icon:Zo,amount:M(Ms(J)),defaultExpanded:!1,children:b&&(B!==null||g!=null)?e.jsx(Mt,{name:"USDC",balance:M(jt(B!==null?B:g)),subtitle:"USD COIN",icon:rt,onClick:c?()=>c("usdc-vault"):void 0}):$?e.jsx(Mt,{name:$.name,balance:M(jt($.totalBalance)),subtitle:$.subtitle,networks:$.networks,icon:rt,onClick:c?()=>c($.name):void 0}):t.freeCollateralItems&&t.freeCollateralItems.length>0?t.freeCollateralItems.map((E,H)=>e.jsxs(a.Fragment,{children:[e.jsx(Mt,{name:E.name,balance:M(jt(E.balance)),subtitle:E.subtitle,networks:E.networks,icon:E.name==="USDC"?rt:void 0,onClick:c?()=>c(E.id):void 0}),H<t.freeCollateralItems.length-1&&e.jsx("div",{style:{height:"1px",backgroundColor:"#D0D2D8",margin:"4px 0"}})]},E.id)):e.jsx("div",{style:{padding:"12px 0",color:"#6B7280",fontSize:"13px",fontFamily:'"IBM Plex Mono", monospace'},children:"No collateral items available"})}),w&&w.length>0&&w.filter(E=>E&&E.id&&E.title&&typeof E.title=="string"&&E.title.trim().length>0).map(E=>e.jsx(Ws,{title:E.title,icon:E.icon||void 0,amount:M(Ms(E.totalBalance||0)),defaultExpanded:E.defaultExpanded!==void 0?E.defaultExpanded:!1,children:E.items&&E.items.length>0?E.items.map((H,X)=>e.jsxs(a.Fragment,{children:[e.jsx(Mt,{name:H.name,balance:M(jt(H.balance)),subtitle:H.subtitle,networks:H.networks,icon:H.name==="USDC"?rt:void 0,onClick:c?()=>c(H.id):void 0}),X<E.items.length-1&&e.jsx("div",{style:{height:"1px",backgroundColor:"#D0D2D8",margin:"4px 0"}})]},H.id||`item-${X}`)):e.jsx("div",{style:{padding:"12px 0",color:"#6B7280",fontSize:"13px",fontFamily:'"IBM Plex Mono", monospace'},children:E.emptyMessage||"No items available"})},E.id))]})]}),h&&e.jsx(Bs,{isOpen:h,onClose:()=>x(!1),styles:r,className:n}),S&&e.jsx(Ls,{isOpen:S,onClose:()=>F(!1),styles:r,className:n,vaultBalance:g,fetchVaultBalance:f,postWithdrawInstruction:u,postWithdrawInstructionLabel:l,destinationChainId:C,destinationTokenAddress:A})]})},Ko=({pairLabel:t,pairApr:o,pairAddressLabel:r,lpLabel:n,onViewPool:s,styles:c,theme:i,token1:d,token2:g})=>e.jsxs("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #a8a8a7",borderRadius:"6px",padding:"16px 16px",width:"100%",display:"flex",flexDirection:"column",gap:"10px",boxShadow:"4px 4px 0px #cdcfd1"},children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:e.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"8px"},children:[e.jsxs("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:c?.fontFamily||i.typography.fontFamily,fontSize:"15px",fontWeight:500,color:"#0e0d0b",lineHeight:"22px"},children:t}),e.jsx("div",{style:{backgroundColor:"rgba(2, 212, 112, 0.17)",border:"0.5px solid #02d470",borderRadius:"3px",padding:"0 10px",height:"12px",display:"flex",alignItems:"center"},children:e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"8px",fontWeight:600,color:"#009c51",textTransform:"uppercase",lineHeight:"1.56"},children:o})})]}),e.jsx("div",{style:{display:"flex",gap:"24px",alignItems:"center"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"10px",fontWeight:500,color:"#7d7c7b",textTransform:"uppercase",lineHeight:"26px",width:"72px"},children:r}),e.jsx("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",style:{cursor:"pointer"},onClick:s,children:e.jsx("path",{d:"M2 6L10 6M10 6L6 2M10 6L6 10",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})})]})}),e.jsx("div",{style:{height:"1px",backgroundColor:"#e9e9e9",width:"100%"}}),e.jsxs("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",paddingRight:"5px"},children:[d&&e.jsx("div",{style:{zIndex:2,marginRight:"-8px"},children:e.jsx(ot,{symbol:d.symbol,logoURI:d.logoURI,size:24,theme:i})}),g&&e.jsx("div",{style:{zIndex:1},children:e.jsx(ot,{symbol:g.symbol,logoURI:g.logoURI,size:24,theme:i})}),!d&&!g&&e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"24px",height:"24px",borderRadius:"50%",backgroundColor:"#2775CA",marginRight:"-5px",border:"2px solid white"}}),e.jsx("div",{style:{width:"24px",height:"24px",borderRadius:"50%",backgroundColor:"#26A17B",border:"2px solid white"}})]})]}),e.jsx("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"8px"},children:e.jsxs("div",{style:{display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center",maxWidth:"199.5px"},children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:e.jsx("span",{style:{fontFamily:c?.fontFamily||i.typography.fontFamily,fontSize:"15px",fontWeight:500,color:"#0e0d0b",lineHeight:"22px"},children:n})}),e.jsxs("svg",{width:"12",height:"12",viewBox:"0 0 12 12",fill:"none",children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#7d7c7b",strokeWidth:"1",fill:"none"}),e.jsx("path",{d:"M6 3V6M6 9H6.01",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})]})]}),e.jsx("svg",{width:"19",height:"19",viewBox:"0 0 12 12",fill:"none",style:{cursor:"pointer"},children:e.jsx("path",{d:"M2 6L10 6M10 6L6 2M10 6L6 10",stroke:"#7d7c7b",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})})]})]}),Oo=({selectedAsset:t,availableAssets:o,onAssetSelect:r,disabled:n,styles:s,theme:c})=>{const[i,d]=a.useState(!1),g=a.useRef(null);a.useEffect(()=>{const u=l=>{g.current&&!g.current.contains(l.target)&&i&&d(!1)};return i&&document.addEventListener("mousedown",u),()=>{document.removeEventListener("mousedown",u)}},[i]);const f=u=>{switch(u){case 1:return"Ethereum";case 42161:return"Arbitrum";case 8453:return"Base";case 11155111:return"Sepolia";case 421614:return"Arbitrum Sepolia";default:return`Chain ${u} `}};return e.jsxs("div",{style:{width:"128px",position:"relative"},ref:g,children:[e.jsxs("div",{style:{border:"1px solid #cdcfd1",borderRadius:"6px 6px 0 0",backgroundColor:n?"#e9e9e9":"#ffffff",padding:"8px 12px 8px 8px",display:"flex",alignItems:"center",justifyContent:"space-between",cursor:n?"not-allowed":"pointer"},onClick:()=>!n&&d(!i),children:[e.jsx("div",{style:{display:"flex",gap:"8px",alignItems:"center"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(ot,{symbol:t.asset.symbol,logoURI:t.asset.logoURI,size:30,theme:c}),e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#3c3e42",lineHeight:"1.5"},children:t.asset.symbol})]}):e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"rgba(60, 62, 66, 0.44)",lineHeight:"1.5",letterSpacing:"-0.56px"},children:"Select Asset"})}),e.jsx("svg",{width:"16",height:"16",viewBox:"0 0 16 16",fill:"none",children:e.jsx("path",{d:"M4 6L8 10L12 6",stroke:"#3c3e42",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]}),e.jsx("div",{style:{backgroundColor:"#d4d3d3",border:"1px solid #cdcfd1",borderRadius:"0 0 6px 6px",padding:"0 10px",height:"24px",display:"flex",alignItems:"center",gap:"4px"},children:t?.asset?e.jsxs(e.Fragment,{children:[e.jsx(Ft,{chainId:t.asset.chainId,theme:c,size:11}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"12px",fontWeight:400,color:"#3c3e42",textTransform:"uppercase",lineHeight:"1.56"},children:f(t.asset.chainId)})]}):e.jsxs(e.Fragment,{children:[e.jsx("div",{style:{width:"12px",height:"12px",borderRadius:"50%",backgroundColor:"#ffffff"}}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"12px",fontWeight:400,color:"#3c3e42",textTransform:"uppercase",lineHeight:"1.56"},children:"Solana"})]})}),i&&e.jsx("div",{style:{position:"absolute",top:"100%",left:0,right:0,marginTop:"4px",backgroundColor:"#ffffff",border:"1px solid #cdcfd1",borderRadius:"6px",boxShadow:"0 4px 6px rgba(0, 0, 0, 0.1)",zIndex:1e3,maxHeight:"200px",overflowY:"auto"},children:o.map(u=>e.jsxs("button",{onClick:()=>{r(u),d(!1)},style:{width:"100%",padding:"12px",display:"flex",alignItems:"center",gap:"8px",border:"none",backgroundColor:"transparent",cursor:"pointer",textAlign:"left"},onMouseEnter:l=>{l.currentTarget.style.backgroundColor="#f3f4f6"},onMouseLeave:l=>{l.currentTarget.style.backgroundColor="transparent"},children:[e.jsx(ot,{symbol:u.symbol,logoURI:u.logoURI,size:24,theme:c}),e.jsxs("div",{style:{flex:1,display:"flex",flexDirection:"column",gap:"4px"},children:[e.jsxs("div",{style:{display:"flex",alignItems:"center",gap:"4px"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"#3c3e42"},children:u.symbol}),e.jsx(Ft,{chainId:u.chainId,theme:c,size:12})]}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"10px",color:"#6b7280"},children:f(u.chainId)})]})]},`${u.address} -${u.chainId} `))})]})},Xo=({progressIndex:t=0})=>{const o=(r,n)=>{const s=n===t,c=n===4,i=c?"#ea4b4b":r>0?"#3C3E42":"transparent";return e.jsxs("svg",{width:"14",height:"14",viewBox:"0 0 14 14",style:{opacity:s?1:.5},children:[e.jsx("circle",{cx:"7",cy:"7",r:"6.84375",fill:c?i:"none",stroke:c?"#ea4b4b":"#3C3E42",strokeWidth:"0.3125"}),!c&&r>0&&e.jsx("path",{d:`M 7 7 L 7 0.15625 A 6.84375 6.84375 0 ${r>.5?1:0} 1 ${7+6.84375*Math.sin(r*2*Math.PI)} ${7-6.84375*Math.cos(r*2*Math.PI)} Z`,fill:i})]},n)};return e.jsxs("div",{style:{display:"flex",gap:"10px",height:"14px",alignItems:"center",justifyContent:"flex-end",opacity:.7},children:[o(0,0),o(.25,1),o(.5,2),o(.75,3),o(1,4)]})},Qs=({assetInput:t,availableAssets:o,onAssetChange:r,disabled:n,styles:s,theme:c})=>{const i=d=>{r(d,t?.selectedAsset?.amount||"")};return e.jsx("div",{style:{backgroundColor:"#e9e9e9",border:"0.5px solid #a8a8a7",borderRadius:"6px",padding:"16px",height:"144px",display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:e.jsxs("div",{style:{flex:1,display:"flex",alignItems:"center",justifyContent:"space-between"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",justifyContent:"space-between",height:"100%"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"16px"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"16px",fontWeight:500,color:"#7d7c7b",lineHeight:"24px"},children:"Amount"}),e.jsx("div",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"40px",fontWeight:700,color:n?"rgba(14, 13, 11, 0.16)":"#0e0d0b",lineHeight:"1.08",letterSpacing:"-1.2px"},children:t?.selectedAsset?.amount||"0.00"})]}),e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"14px",fontWeight:500,color:"#7d7c7b",lineHeight:"20px",letterSpacing:"-0.14px"},children:t?.usdValue||"$0.00"})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",alignItems:"flex-end",justifyContent:"space-between",height:"100%",gap:"12px"},children:[e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",alignItems:"flex-end"},children:[e.jsx("span",{style:{fontFamily:s?.fontFamily||c.typography.fontFamily,fontSize:"12px",fontWeight:500,color:"#71757a",lineHeight:"16px"},children:t?.balanceLabel||"Balance: 0.00"}),e.jsx(Oo,{selectedAsset:t?.selectedAsset,availableAssets:o,onAssetSelect:i,disabled:n,styles:s,theme:c})]}),e.jsx(Xo,{progressIndex:t?.progressIndex||0})]})]})})},$o=({isOpen:t,onClose:o,pairLabel:r,pairApr:n,pairAddressLabel:s,lpLabel:c,onViewPool:i,primaryAsset:d,secondaryAsset:g,onPrimaryAssetChange:f,onSecondaryAssetChange:u,availableAssets:l,showSecondaryAsset:C,onAddSecondaryAsset:A,alertVariant:w="none",crossNetworkCopy:k,onClickDepositCollateral:p,transactionDetailsCollapsed:b=!0,onToggleTransactionDetails:m,transactionDetails:j,isSubmitting:y=!1,canSubmit:h=!1,onSubmit:x,styles:S})=>{const F=de.defaultTheme,[B,I]=a.useState(!1),G=e.jsxs("div",{style:{display:"flex",gap:"6px",alignItems:"flex-start",flexWrap:"nowrap"},children:[e.jsxs("p",{style:{fontSize:"10px",color:"rgba(0, 0, 0, 0.4)",margin:0,lineHeight:"1.6",letterSpacing:"0.2px",fontFamily:S?.fontFamily||F.typography.fontFamily,flex:1},children:["Provide liquidity to ",r," pair using assets on 10+ networks in a one-click native UX, powered by Spice Flow"]}),e.jsxs("button",{onClick:()=>I(!B),style:{backgroundColor:"#f8c3c3",border:"0.436px solid #ea4b4b",borderRadius:"6.184px",padding:"2px 4px",height:"auto",display:"flex",alignItems:"center",gap:"4px",cursor:"pointer",fontFamily:"'IBM Plex Mono', monospace",fontSize:"7.902px",fontWeight:500,color:"#c33f3f",textTransform:"uppercase",letterSpacing:"-0.3556px",flexShrink:0,marginTop:"2px"},children:[e.jsx("span",{children:B?"Collapse":"Expand to learn more"}),e.jsx("svg",{width:"10",height:"10",viewBox:"0 0 12 12",fill:"none",style:{transform:B?"rotate(180deg)":"none"},children:e.jsx("path",{d:"M3 4.5L6 7.5L9 4.5",stroke:"#c33f3f",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]})]});return e.jsx(xt,{isOpen:t,onClose:o,title:"Provide Liquidity with Spice Flow",subtitle:G,styles:S,theme:F,maxWidth:"422px",children:e.jsxs("div",{style:{padding:"0 26px",display:"flex",flexDirection:"column",gap:"16px"},children:[w==="crossNetworkAssets"&&k&&e.jsx("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #c33f3f",borderRadius:"6px",padding:"10px 10px",display:"flex",flexDirection:"column",gap:"15px"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"flex-start"},children:[e.jsxs("svg",{width:"18",height:"18",viewBox:"0 0 12 12",fill:"none",style:{marginTop:"2px",flexShrink:0},children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#ed6969",strokeWidth:"1"}),e.jsx("text",{x:"6",y:"8",textAnchor:"middle",fontSize:"8",fill:"#ed6969",children:"i"})]}),e.jsxs("div",{style:{flex:1},children:[e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:0,lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:k.summary}),e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:"4px 0 0 0",lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:k.body})]})]})}),w==="noCollateral"&&e.jsxs("div",{style:{backgroundColor:"#ffffff",border:"0.5px solid #c33f3f",borderRadius:"6px",padding:"15px 10px",display:"flex",flexDirection:"column",gap:"15px"},children:[e.jsx(de.Button,{variant:"primary",onClick:p,style:{backgroundColor:"#ea4b4b",border:"1px solid rgba(0, 0, 0, 0.53)",borderRadius:"3px",padding:"4px 47px",height:"37px",fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:"#0e0d0b",textTransform:"uppercase",letterSpacing:"-0.42px"},children:"Deposit collateral"}),e.jsx("div",{style:{display:"flex",flexDirection:"column",gap:"4px"},children:e.jsxs("div",{style:{display:"flex",gap:"4px",alignItems:"center"},children:[e.jsxs("svg",{width:"16",height:"16",viewBox:"0 0 12 12",fill:"none",style:{flexShrink:0},children:[e.jsx("circle",{cx:"6",cy:"6",r:"5",stroke:"#7d7c7b",strokeWidth:"1"}),e.jsx("text",{x:"6",y:"8",textAnchor:"middle",fontSize:"8",fill:"#7d7c7b",children:"i"})]}),e.jsx("p",{style:{fontSize:"12px",color:"#676665",margin:0,lineHeight:"19px",letterSpacing:"-0.45px",fontFamily:S?.fontFamily||F.typography.fontFamily},children:"You don't have any usable collateral in your Spicenet Account to provide liquidity. Deposit USDC/USDT collateral to get started."})]})})]}),e.jsx(Ko,{pairLabel:r,pairApr:n,pairAddressLabel:s,lpLabel:c,onViewPool:i,styles:S,theme:F,token1:d?.selectedAsset?.asset,token2:g?.selectedAsset?.asset}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"8px",position:"relative"},children:[e.jsx(Qs,{assetInput:d,availableAssets:l,onAssetChange:f,styles:S,theme:F}),e.jsx("button",{onClick:A,style:{position:"absolute",left:"50%",top:"50%",transform:"translate(-50%, -50%)",width:"40px",height:"40px",borderRadius:"10px",backgroundColor:"#ea4b4b",border:"none",cursor:"pointer",display:"flex",alignItems:"center",justifyContent:"center",zIndex:10},children:e.jsx("svg",{width:"18",height:"18",viewBox:"0 0 18 18",fill:"none",children:e.jsx("path",{d:"M9 5V13M5 9H13",stroke:"#ffffff",strokeWidth:"2",strokeLinecap:"round"})})}),e.jsx(Qs,{assetInput:g,availableAssets:l,onAssetChange:u||(()=>{}),disabled:!g?.selectedAsset,styles:S,theme:F})]}),e.jsxs("div",{style:{display:"flex",flexDirection:"column",gap:"6px"},children:[e.jsxs("button",{onClick:m,style:{display:"flex",gap:"4px",alignItems:"center",background:"none",border:"none",cursor:"pointer",padding:0},children:[e.jsx("span",{style:{fontFamily:S?.fontFamily||F.typography.fontFamily,fontSize:"12px",fontWeight:600,color:"#757171"},children:"Transaction Details"}),e.jsx("svg",{width:"14",height:"14",viewBox:"0 0 12 12",fill:"none",style:{transform:b?"rotate(0deg)":"rotate(180deg)",transition:"transform 0.2s"},children:e.jsx("path",{d:"M3 4.5L6 7.5L9 4.5",stroke:"#757171",strokeWidth:"1.5",strokeLinecap:"round",strokeLinejoin:"round"})})]}),!b&&j&&j.length>0&&e.jsx("div",{style:{padding:"12px 0",display:"flex",flexDirection:"column",gap:"8px"},children:j.map((P,_)=>e.jsxs("div",{style:{display:"flex",justifyContent:"space-between",alignItems:"center"},children:[e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:"#52565b",textTransform:"uppercase",lineHeight:"1.56"},children:P.label}),e.jsx("span",{style:{fontFamily:"'IBM Plex Mono', monospace",fontSize:"14px",fontWeight:500,color:P.isPositive?"#1aa362":"#52565b",textTransform:"uppercase",lineHeight:"1.56"},children:P.value})]},_))})]}),e.jsx(de.Button,{variant:"outline",fullWidth:!0,onClick:x,loading:y,disabled:!h,theme:F,style:{backgroundColor:"#ea4b4b",border:"1px solid #0e0d0b",color:"#0e0d0b",fontFamily:"'IBM Plex Mono', monospace",fontSize:"18px",fontWeight:500,textTransform:"uppercase",padding:"8px 0"},children:"Provide Liquidity"})]})})},_o=()=>{const[t,o]=a.useState("0");return{fromAmount:t,setFromAmount:o}},en=()=>{const[t,o]=a.useState("0"),r=a.useCallback(n=>{o(n)},[]);return{toAmount:t,setToAmount:o,updateToAmount:r}},tn=()=>{const[t,o]=a.useState("0");return{assetAmount:t,setAssetAmount:o}};exports.ConnectWalletModal=Es,exports.CrossChainDepositModal=Io,exports.DepositModal=js,exports.DepositWidget=gs,exports.DepositWidgetModal=wo,exports.LpModal=$o,exports.ProviderLogin=Gt,exports.SelectChainModal=Is,exports.SpiceBalance=Go,exports.SpiceDeposit=Bs,exports.SpiceFlowProvider=mo,exports.SpiceFlowProviderContext=He,exports.SpiceWithdraw=Ls,exports.SwapWidget=Ao,exports.WithdrawModal=Kt,exports.WithdrawWidget=fs,exports.WithdrawWidgetModal=Eo,exports.fetchBalances=zt,exports.relayerService=we,exports.useAssetInput=tn,exports.useAssets=Vt,exports.useEmbeddedWalletAddress=gt,exports.useFromInput=_o,exports.useSpiceAssets=us,exports.useSpiceBalance=Rs,exports.useStatus=kt,exports.useToInputUpdate=en,exports.useWallet=Lt;
|