@swapkit/wallets 4.0.0-beta.60 → 4.0.0-beta.62

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.
Files changed (39) hide show
  1. package/dist/src/coinbase/index.cjs +2 -2
  2. package/dist/src/coinbase/index.cjs.map +3 -3
  3. package/dist/src/coinbase/index.js +2 -2
  4. package/dist/src/coinbase/index.js.map +3 -3
  5. package/dist/src/cosmostation/index.cjs +2 -2
  6. package/dist/src/cosmostation/index.cjs.map +3 -3
  7. package/dist/src/cosmostation/index.js +2 -2
  8. package/dist/src/cosmostation/index.js.map +3 -3
  9. package/dist/src/ctrl/index.cjs +2 -2
  10. package/dist/src/ctrl/index.cjs.map +4 -4
  11. package/dist/src/ctrl/index.js +2 -2
  12. package/dist/src/ctrl/index.js.map +4 -4
  13. package/dist/src/index.cjs +2 -2
  14. package/dist/src/index.cjs.map +1 -1
  15. package/dist/src/index.js +2 -2
  16. package/dist/src/index.js.map +1 -1
  17. package/dist/src/keplr/index.cjs +2 -2
  18. package/dist/src/keplr/index.cjs.map +4 -4
  19. package/dist/src/keplr/index.js +2 -2
  20. package/dist/src/keplr/index.js.map +4 -4
  21. package/dist/types/bitget/helpers.d.ts +3 -3
  22. package/dist/types/bitget/helpers.d.ts.map +1 -1
  23. package/dist/types/coinbase/signer.d.ts.map +1 -1
  24. package/dist/types/cosmostation/index.d.ts +2 -2
  25. package/dist/types/cosmostation/index.d.ts.map +1 -1
  26. package/dist/types/ctrl/index.d.ts +2 -2
  27. package/dist/types/ctrl/index.d.ts.map +1 -1
  28. package/dist/types/ctrl/walletHelpers.d.ts +1 -1
  29. package/dist/types/ctrl/walletHelpers.d.ts.map +1 -1
  30. package/dist/types/keplr/chainRegistry.d.ts.map +1 -1
  31. package/dist/types/keplr/index.d.ts +2 -2
  32. package/dist/types/keplr/index.d.ts.map +1 -1
  33. package/dist/types/okx/helpers.d.ts +3 -3
  34. package/dist/types/okx/helpers.d.ts.map +1 -1
  35. package/dist/types/tronlink/helpers.d.ts +3 -3
  36. package/dist/types/tronlink/helpers.d.ts.map +1 -1
  37. package/dist/types/types.d.ts +2 -25
  38. package/dist/types/types.d.ts.map +1 -1
  39. package/package.json +8 -8
@@ -1,4 +1,4 @@
1
- var S={};P(S,{coinbaseWallet:()=>w,COINBASE_SUPPORTED_CHAINS:()=>y});module.exports=b(S);var e=require("@swapkit/helpers"),d=require("@swapkit/wallet-core");var a=require("@swapkit/helpers");async function C(o,n){let{AbstractSigner:i}=await import("ethers");class r extends i{#e;constructor(t,s){super(s);this.#e=t}async getAddress(){let t=await this.#e.request({method:"eth_requestAccounts"});if(!t[0])throw new a.SwapKitError("wallet_coinbase_no_accounts");return t[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(t){return await this.#e.request({method:"personal_sign",params:[t,await this.getAddress()]})}signTypedData=()=>{throw new a.SwapKitError("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(t){return new r(this.#e,t)}}return new r(o,n)}var u=async({chain:o,coinbaseSdk:n})=>{switch(o){case a.Chain.Ethereum:case a.Chain.Avalanche:case a.Chain.Arbitrum:case a.Chain.Optimism:case a.Chain.Polygon:case a.Chain.BinanceSmartChain:{let i=n.getProvider(),{getEvmToolbox:r,getProvider:t}=await import("@swapkit/toolboxes/evm"),s=await t(o),c=await C(i,s),p=await r(o,{provider:s,signer:c}),m=await c.getAddress();return{...p,address:m}}default:throw new a.SwapKitError("wallet_coinbase_chain_not_supported",{chain:o})}};var w=d.createWallet({name:"connectCoinbaseWallet",walletType:e.WalletOption.COINBASE_MOBILE,supportedChains:[e.Chain.Arbitrum,e.Chain.Avalanche,e.Chain.Base,e.Chain.BinanceSmartChain,e.Chain.Ethereum,e.Chain.Optimism,e.Chain.Polygon],connect:({addChain:o,walletType:n,supportedChains:i})=>async function r(t){let{createCoinbaseWalletSDK:s}=await import("@coinbase/wallet-sdk"),c=e.filterSupportedChains({chains:t,supportedChains:i,walletType:n}),p=e.SKConfig.get("integrations").coinbase||{appName:"Swapkit Playground"},m=s({...p,appChainIds:c.map((l)=>Number(e.ChainToChainId[l]))});return await Promise.all(c.map(async(l)=>{let g=await u({chain:l,coinbaseSdk:m});o({...g,chain:l,walletType:n})})),!0}}),y=d.getWalletSupportedChains(w);
1
+ var S={};P(S,{coinbaseWallet:()=>w,COINBASE_SUPPORTED_CHAINS:()=>y});module.exports=b(S);var e=require("@swapkit/helpers"),d=require("@swapkit/wallet-core");var a=require("@swapkit/helpers");async function C(o,n){let{AbstractSigner:i}=await import("ethers");class s extends i{#e;constructor(t,r){super(r);this.#e=t}async getAddress(){let t=await this.#e.request({method:"eth_requestAccounts"});if(!t[0])throw new a.SwapKitError("wallet_coinbase_no_accounts");return t[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(t){return await this.#e.request({method:"personal_sign",params:[t,await this.getAddress()]})}signTypedData=()=>{throw new a.SwapKitError("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(t){return new s(this.#e,t)}}return new s(o,n)}var u=async({chain:o,coinbaseSdk:n})=>{switch(o){case a.Chain.Ethereum:case a.Chain.Avalanche:case a.Chain.Arbitrum:case a.Chain.Optimism:case a.Chain.Polygon:case a.Chain.Base:case a.Chain.BinanceSmartChain:{let i=n.getProvider(),{getEvmToolbox:s,getProvider:t}=await import("@swapkit/toolboxes/evm"),r=await t(o),c=await C(i,r),p=await s(o,{provider:r,signer:c}),m=await c.getAddress();return{...p,address:m}}default:throw new a.SwapKitError("wallet_coinbase_chain_not_supported",{chain:o})}};var w=d.createWallet({name:"connectCoinbaseWallet",walletType:e.WalletOption.COINBASE_MOBILE,supportedChains:[e.Chain.Arbitrum,e.Chain.Avalanche,e.Chain.Base,e.Chain.BinanceSmartChain,e.Chain.Ethereum,e.Chain.Optimism,e.Chain.Polygon],connect:({addChain:o,walletType:n,supportedChains:i})=>async function s(t){let{createCoinbaseWalletSDK:r}=await import("@coinbase/wallet-sdk"),c=e.filterSupportedChains({chains:t,supportedChains:i,walletType:n}),p=e.SKConfig.get("integrations").coinbase||{appName:"Swapkit Playground"},m=r({...p,appChainIds:c.map((l)=>Number(e.ChainToChainId[l]))});return await Promise.all(c.map(async(l)=>{let g=await u({chain:l,coinbaseSdk:m});o({...g,chain:l,walletType:n})})),!0}}),y=d.getWalletSupportedChains(w);
2
2
 
3
- //# debugId=2DF0B5BB39432D9564756E2164756E21
3
+ //# debugId=3C1052A336FE276F64756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -3,9 +3,9 @@
3
3
  "sources": ["../src/coinbase/index.ts", "../src/coinbase/signer.ts"],
4
4
  "sourcesContent": [
5
5
  "import {\n Chain,\n ChainToChainId,\n SKConfig,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./signer\";\n\nexport const coinbaseWallet = createWallet({\n name: \"connectCoinbaseWallet\",\n walletType: WalletOption.COINBASE_MOBILE,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCoinbaseWallet(chains: Chain[]) {\n const { createCoinbaseWalletSDK } = await import(\"@coinbase/wallet-sdk\");\n\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const coinbaseConfig = SKConfig.get(\"integrations\").coinbase || {\n appName: \"Swapkit Playground\",\n };\n\n const coinbaseSdk = createCoinbaseWalletSDK({\n ...coinbaseConfig,\n appChainIds: filteredChains.map((chain) => Number(ChainToChainId[chain])),\n });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({ chain, coinbaseSdk });\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const COINBASE_SUPPORTED_CHAINS = getWalletSupportedChains(coinbaseWallet);\n",
6
- "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\nimport { Chain, SwapKitError } from \"@swapkit/helpers\";\nimport type { Provider } from \"ethers\";\n\nasync function getCoinbaseMobileSigner(\n walletProvider: CoinbaseWalletProvider,\n provider?: Provider,\n) {\n const { AbstractSigner } = await import(\"ethers\");\n\n class CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new SwapKitError(\"wallet_coinbase_no_accounts\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new SwapKitError(\"wallet_coinbase_method_not_supported\", { method: \"signTypedData\" });\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n }\n\n return new CoinbaseMobileSigner(walletProvider, provider);\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}) => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n const { getEvmToolbox, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getCoinbaseMobileSigner(walletProvider, provider);\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const address = await signer.getAddress();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_coinbase_chain_not_supported\", { chain });\n }\n};\n"
6
+ "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\nimport { Chain, SwapKitError } from \"@swapkit/helpers\";\nimport type { Provider } from \"ethers\";\n\nasync function getCoinbaseMobileSigner(\n walletProvider: CoinbaseWalletProvider,\n provider?: Provider,\n) {\n const { AbstractSigner } = await import(\"ethers\");\n\n class CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new SwapKitError(\"wallet_coinbase_no_accounts\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new SwapKitError(\"wallet_coinbase_method_not_supported\", { method: \"signTypedData\" });\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n }\n\n return new CoinbaseMobileSigner(walletProvider, provider);\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}) => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Base:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n const { getEvmToolbox, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getCoinbaseMobileSigner(walletProvider, provider);\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const address = await signer.getAddress();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_coinbase_chain_not_supported\", { chain });\n }\n};\n"
7
7
  ],
8
- "mappings": "yFAMO,IANP,8BAOA,kCCLoC,IAApC,8BAGA,eAAe,CAAuB,CACpC,EACA,EACA,CACA,IAAQ,kBAAmB,KAAa,kBAExC,MAAM,UAA6B,CAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,eAAa,6BAA6B,EAEtE,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,eAAa,uCAAwC,CAAE,OAAQ,eAAgB,CAAC,GAG5F,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEA,OAAO,IAAI,EAAqB,EAAgB,CAAQ,EAGnD,IAAM,EAAmB,OAC9B,QACA,iBAII,CACJ,OAAQ,QACD,QAAM,cACN,QAAM,eACN,QAAM,cACN,QAAM,cACN,QAAM,aACN,QAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GACvC,gBAAe,eAAgB,KAAa,kCAE9C,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAwB,EAAgB,CAAQ,EAC/D,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAU,MAAM,EAAO,WAAW,EAExC,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,eAAa,sCAAuC,CAAE,OAAM,CAAC,IDrEtE,IAAM,EAAiB,eAAa,CACzC,KAAM,wBACN,WAAY,eAAa,gBACzB,gBAAiB,CACf,QAAM,SACN,QAAM,UACN,QAAM,KACN,QAAM,kBACN,QAAM,SACN,QAAM,SACN,QAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,WAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,iBAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,2BAAyB,CAAc",
9
- "debugId": "2DF0B5BB39432D9564756E2164756E21",
8
+ "mappings": "yFAMO,IANP,8BAOA,kCCLoC,IAApC,8BAGA,eAAe,CAAuB,CACpC,EACA,EACA,CACA,IAAQ,kBAAmB,KAAa,kBAExC,MAAM,UAA6B,CAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,eAAa,6BAA6B,EAEtE,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,eAAa,uCAAwC,CAAE,OAAQ,eAAgB,CAAC,GAG5F,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEA,OAAO,IAAI,EAAqB,EAAgB,CAAQ,EAGnD,IAAM,EAAmB,OAC9B,QACA,iBAII,CACJ,OAAQ,QACD,QAAM,cACN,QAAM,eACN,QAAM,cACN,QAAM,cACN,QAAM,aACN,QAAM,UACN,QAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GACvC,gBAAe,eAAgB,KAAa,kCAE9C,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAwB,EAAgB,CAAQ,EAC/D,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAU,MAAM,EAAO,WAAW,EAExC,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,eAAa,sCAAuC,CAAE,OAAM,CAAC,IDtEtE,IAAM,EAAiB,eAAa,CACzC,KAAM,wBACN,WAAY,eAAa,gBACzB,gBAAiB,CACf,QAAM,SACN,QAAM,UACN,QAAM,KACN,QAAM,kBACN,QAAM,SACN,QAAM,SACN,QAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,WAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,iBAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,2BAAyB,CAAc",
9
+ "debugId": "3C1052A336FE276F64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- import{F as h,G as u}from"../../chunk-yqaz2d25.js";import{Chain as a,ChainToChainId as b,SKConfig as P,WalletOption as y,filterSupportedChains as S}from"@swapkit/helpers";import{createWallet as v,getWalletSupportedChains as W}from"@swapkit/wallet-core";import{Chain as s,SwapKitError as m}from"@swapkit/helpers";async function C(t,o){let{AbstractSigner:i}=await import("ethers");class n extends i{#e;constructor(e,r){super(r);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new m("wallet_coinbase_no_accounts");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new m("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(e){return new n(this.#e,e)}}return new n(t,o)}var w=async({chain:t,coinbaseSdk:o})=>{switch(t){case s.Ethereum:case s.Avalanche:case s.Arbitrum:case s.Optimism:case s.Polygon:case s.BinanceSmartChain:{let i=o.getProvider(),{getEvmToolbox:n,getProvider:e}=await import("@swapkit/toolboxes/evm"),r=await e(t),c=await C(i,r),d=await n(t,{provider:r,signer:c}),p=await c.getAddress();return{...d,address:p}}default:throw new m("wallet_coinbase_chain_not_supported",{chain:t})}};var _=v({name:"connectCoinbaseWallet",walletType:y.COINBASE_MOBILE,supportedChains:[a.Arbitrum,a.Avalanche,a.Base,a.BinanceSmartChain,a.Ethereum,a.Optimism,a.Polygon],connect:({addChain:t,walletType:o,supportedChains:i})=>async function n(e){let{createCoinbaseWalletSDK:r}=await import("@coinbase/wallet-sdk"),c=S({chains:e,supportedChains:i,walletType:o}),d=P.get("integrations").coinbase||{appName:"Swapkit Playground"},p=r({...d,appChainIds:c.map((l)=>Number(b[l]))});return await Promise.all(c.map(async(l)=>{let g=await w({chain:l,coinbaseSdk:p});t({...g,chain:l,walletType:o})})),!0}}),O=W(_);export{_ as coinbaseWallet,O as COINBASE_SUPPORTED_CHAINS};
1
+ import{F as h,G as u}from"../../chunk-yqaz2d25.js";import{Chain as o,ChainToChainId as b,SKConfig as P,WalletOption as y,filterSupportedChains as S}from"@swapkit/helpers";import{createWallet as v,getWalletSupportedChains as W}from"@swapkit/wallet-core";import{Chain as a,SwapKitError as m}from"@swapkit/helpers";async function C(t,n){let{AbstractSigner:i}=await import("ethers");class s extends i{#e;constructor(e,r){super(r);this.#e=e}async getAddress(){let e=await this.#e.request({method:"eth_requestAccounts"});if(!e[0])throw new m("wallet_coinbase_no_accounts");return e[0]}async signTransaction(){return await this.#e.request({method:"eth_signTransaction"})}async signMessage(e){return await this.#e.request({method:"personal_sign",params:[e,await this.getAddress()]})}signTypedData=()=>{throw new m("wallet_coinbase_method_not_supported",{method:"signTypedData"})};connect(e){return new s(this.#e,e)}}return new s(t,n)}var w=async({chain:t,coinbaseSdk:n})=>{switch(t){case a.Ethereum:case a.Avalanche:case a.Arbitrum:case a.Optimism:case a.Polygon:case a.Base:case a.BinanceSmartChain:{let i=n.getProvider(),{getEvmToolbox:s,getProvider:e}=await import("@swapkit/toolboxes/evm"),r=await e(t),c=await C(i,r),d=await s(t,{provider:r,signer:c}),p=await c.getAddress();return{...d,address:p}}default:throw new m("wallet_coinbase_chain_not_supported",{chain:t})}};var _=v({name:"connectCoinbaseWallet",walletType:y.COINBASE_MOBILE,supportedChains:[o.Arbitrum,o.Avalanche,o.Base,o.BinanceSmartChain,o.Ethereum,o.Optimism,o.Polygon],connect:({addChain:t,walletType:n,supportedChains:i})=>async function s(e){let{createCoinbaseWalletSDK:r}=await import("@coinbase/wallet-sdk"),c=S({chains:e,supportedChains:i,walletType:n}),d=P.get("integrations").coinbase||{appName:"Swapkit Playground"},p=r({...d,appChainIds:c.map((l)=>Number(b[l]))});return await Promise.all(c.map(async(l)=>{let g=await w({chain:l,coinbaseSdk:p});t({...g,chain:l,walletType:n})})),!0}}),D=W(_);export{_ as coinbaseWallet,D as COINBASE_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=8BF88FB854DE1FC564756E2164756E21
3
+ //# debugId=444F8D6BB238450F64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -3,9 +3,9 @@
3
3
  "sources": ["../src/coinbase/index.ts", "../src/coinbase/signer.ts"],
4
4
  "sourcesContent": [
5
5
  "import {\n Chain,\n ChainToChainId,\n SKConfig,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./signer\";\n\nexport const coinbaseWallet = createWallet({\n name: \"connectCoinbaseWallet\",\n walletType: WalletOption.COINBASE_MOBILE,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCoinbaseWallet(chains: Chain[]) {\n const { createCoinbaseWalletSDK } = await import(\"@coinbase/wallet-sdk\");\n\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const coinbaseConfig = SKConfig.get(\"integrations\").coinbase || {\n appName: \"Swapkit Playground\",\n };\n\n const coinbaseSdk = createCoinbaseWalletSDK({\n ...coinbaseConfig,\n appChainIds: filteredChains.map((chain) => Number(ChainToChainId[chain])),\n });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods({ chain, coinbaseSdk });\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const COINBASE_SUPPORTED_CHAINS = getWalletSupportedChains(coinbaseWallet);\n",
6
- "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\nimport { Chain, SwapKitError } from \"@swapkit/helpers\";\nimport type { Provider } from \"ethers\";\n\nasync function getCoinbaseMobileSigner(\n walletProvider: CoinbaseWalletProvider,\n provider?: Provider,\n) {\n const { AbstractSigner } = await import(\"ethers\");\n\n class CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new SwapKitError(\"wallet_coinbase_no_accounts\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new SwapKitError(\"wallet_coinbase_method_not_supported\", { method: \"signTypedData\" });\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n }\n\n return new CoinbaseMobileSigner(walletProvider, provider);\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}) => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n const { getEvmToolbox, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getCoinbaseMobileSigner(walletProvider, provider);\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const address = await signer.getAddress();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_coinbase_chain_not_supported\", { chain });\n }\n};\n"
6
+ "import type { CoinbaseWalletProvider } from \"@coinbase/wallet-sdk\";\nimport type { createCoinbaseWalletSDK } from \"@coinbase/wallet-sdk/dist/createCoinbaseWalletSDK.js\";\nimport { Chain, SwapKitError } from \"@swapkit/helpers\";\nimport type { Provider } from \"ethers\";\n\nasync function getCoinbaseMobileSigner(\n walletProvider: CoinbaseWalletProvider,\n provider?: Provider,\n) {\n const { AbstractSigner } = await import(\"ethers\");\n\n class CoinbaseMobileSigner extends AbstractSigner {\n #coinbaseProvider: CoinbaseWalletProvider;\n\n constructor(coinbaseProvider: CoinbaseWalletProvider, provider?: Provider) {\n super(provider);\n this.#coinbaseProvider = coinbaseProvider;\n }\n\n async getAddress() {\n const accounts = await this.#coinbaseProvider.request<string[]>({\n method: \"eth_requestAccounts\",\n });\n\n if (!accounts[0]) throw new SwapKitError(\"wallet_coinbase_no_accounts\");\n\n return accounts[0];\n }\n\n async signTransaction() {\n return await this.#coinbaseProvider.request<string>({\n method: \"eth_signTransaction\",\n });\n }\n\n async signMessage(message: string | Uint8Array) {\n return await this.#coinbaseProvider.request<string>({\n method: \"personal_sign\",\n params: [message, await this.getAddress()],\n });\n }\n\n signTypedData = () => {\n throw new SwapKitError(\"wallet_coinbase_method_not_supported\", { method: \"signTypedData\" });\n };\n\n connect(provider: Provider) {\n return new CoinbaseMobileSigner(this.#coinbaseProvider, provider);\n }\n }\n\n return new CoinbaseMobileSigner(walletProvider, provider);\n}\n\nexport const getWalletMethods = async ({\n chain,\n coinbaseSdk,\n}: {\n chain: Chain;\n coinbaseSdk: ReturnType<typeof createCoinbaseWalletSDK>;\n}) => {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Avalanche:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Base:\n case Chain.BinanceSmartChain: {\n const walletProvider = coinbaseSdk.getProvider() as CoinbaseWalletProvider;\n const { getEvmToolbox, getProvider } = await import(\"@swapkit/toolboxes/evm\");\n\n const provider = await getProvider(chain);\n const signer = await getCoinbaseMobileSigner(walletProvider, provider);\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const address = await signer.getAddress();\n\n return { ...toolbox, address };\n }\n\n default:\n throw new SwapKitError(\"wallet_coinbase_chain_not_supported\", { chain });\n }\n};\n"
7
7
  ],
8
- "mappings": "mDAAA,gBACE,oBACA,cACA,kBACA,2BACA,yBAEF,uBAAS,8BAAc,6BCLvB,gBAAS,kBAAO,yBAGhB,eAAe,CAAuB,CACpC,EACA,EACA,CACA,IAAQ,kBAAmB,KAAa,kBAExC,MAAM,UAA6B,CAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,EAAa,6BAA6B,EAEtE,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,EAAa,uCAAwC,CAAE,OAAQ,eAAgB,CAAC,GAG5F,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEA,OAAO,IAAI,EAAqB,EAAgB,CAAQ,EAGnD,IAAM,EAAmB,OAC9B,QACA,iBAII,CACJ,OAAQ,QACD,EAAM,cACN,EAAM,eACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GACvC,gBAAe,eAAgB,KAAa,kCAE9C,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAwB,EAAgB,CAAQ,EAC/D,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAU,MAAM,EAAO,WAAW,EAExC,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,EAAa,sCAAuC,CAAE,OAAM,CAAC,IDrEtE,IAAM,EAAiB,EAAa,CACzC,KAAM,wBACN,WAAY,EAAa,gBACzB,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,EAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,EAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
9
- "debugId": "8BF88FB854DE1FC564756E2164756E21",
8
+ "mappings": "mDAAA,gBACE,oBACA,cACA,kBACA,2BACA,yBAEF,uBAAS,8BAAc,6BCLvB,gBAAS,kBAAO,yBAGhB,eAAe,CAAuB,CACpC,EACA,EACA,CACA,IAAQ,kBAAmB,KAAa,kBAExC,MAAM,UAA6B,CAAe,CAChD,GAEA,WAAW,CAAC,EAA0C,EAAqB,CACzE,MAAM,CAAQ,EACd,KAAK,GAAoB,OAGrB,WAAU,EAAG,CACjB,IAAM,EAAW,MAAM,KAAK,GAAkB,QAAkB,CAC9D,OAAQ,qBACV,CAAC,EAED,IAAK,EAAS,GAAI,MAAM,IAAI,EAAa,6BAA6B,EAEtE,OAAO,EAAS,QAGZ,gBAAe,EAAG,CACtB,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,qBACV,CAAC,OAGG,YAAW,CAAC,EAA8B,CAC9C,OAAO,MAAM,KAAK,GAAkB,QAAgB,CAClD,OAAQ,gBACR,OAAQ,CAAC,EAAS,MAAM,KAAK,WAAW,CAAC,CAC3C,CAAC,EAGH,cAAgB,IAAM,CACpB,MAAM,IAAI,EAAa,uCAAwC,CAAE,OAAQ,eAAgB,CAAC,GAG5F,OAAO,CAAC,EAAoB,CAC1B,OAAO,IAAI,EAAqB,KAAK,GAAmB,CAAQ,EAEpE,CAEA,OAAO,IAAI,EAAqB,EAAgB,CAAQ,EAGnD,IAAM,EAAmB,OAC9B,QACA,iBAII,CACJ,OAAQ,QACD,EAAM,cACN,EAAM,eACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,UACN,EAAM,kBAAmB,CAC5B,IAAM,EAAiB,EAAY,YAAY,GACvC,gBAAe,eAAgB,KAAa,kCAE9C,EAAW,MAAM,EAAY,CAAK,EAClC,EAAS,MAAM,EAAwB,EAAgB,CAAQ,EAC/D,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAU,MAAM,EAAO,WAAW,EAExC,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,EAAa,sCAAuC,CAAE,OAAM,CAAC,IDtEtE,IAAM,EAAiB,EAAa,CACzC,KAAM,wBACN,WAAY,EAAa,gBACzB,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,OACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAqB,CAAC,EAAiB,CACpD,IAAQ,2BAA4B,KAAa,gCAE3C,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAiB,EAAS,IAAI,cAAc,EAAE,UAAY,CAC9D,QAAS,oBACX,EAEM,EAAc,EAAwB,IACvC,EACH,YAAa,EAAe,IAAI,CAAC,IAAU,OAAO,EAAe,EAAM,CAAC,CAC1E,CAAC,EAUD,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAE,QAAO,aAAY,CAAC,EAEnE,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,GAEb,CAAC,EAEY,EAA4B,EAAyB,CAAc",
9
+ "debugId": "444F8D6BB238450F64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var S={};u(S,{cosmostationWallet:()=>p,COSMOSTATION_SUPPORTED_CHAINS:()=>y});module.exports=d(S);var o=require("@swapkit/helpers"),l=require("@swapkit/wallet-core"),C=[o.ChainId.Cosmos,o.ChainId.Kujira,o.ChainId.THORChain],_=[o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base];async function f(i,c,a){await Promise.all(i.map(async(n)=>{let e=o.ChainToChainId[n];await a.enable(e);let s=a.getOfflineSignerOnlyAmino(e);if(!s)throw new o.SwapKitError("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),t=await s.getAccounts();if(!t?.[0]?.address)throw new o.SwapKitError("wallet_cosmostation_no_accounts");let[{address:w}]=t,h=r(n,{signer:s});c({...h,chain:n,address:w,walletType:o.WalletOption.COSMOSTATION})}))}async function O(i,c){let a=window.ethereum;if(!a)throw new o.SwapKitError("wallet_cosmostation_evm_provider_not_found");let n=await a.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new o.SwapKitError("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");for(let s of i){let r=e(s,{provider:a}),[t]=n;if(!t)throw new o.SwapKitError("wallet_cosmostation_no_evm_address");c({...r,chain:s,address:t,walletType:o.WalletOption.COSMOSTATION})}}var p=l.createWallet({name:"connectCosmostation",supportedChains:[o.Chain.Cosmos,o.Chain.Kujira,o.Chain.THORChain,o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base],connect:({addChain:i,supportedChains:c})=>async function a(n){let e=o.filterSupportedChains({chains:n,supportedChains:c,walletType:o.WalletOption.COSMOSTATION});if(!window.cosmostation)throw new o.SwapKitError("wallet_cosmostation_not_found");let s=e.filter((t)=>C.includes(o.ChainToChainId[t])),r=e.filter((t)=>_.includes(t));if(s.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new o.SwapKitError("wallet_cosmostation_keplr_provider_not_found");await f(s,i,t)}if(r.length>0)await O(r,i);return!0}}),y=l.getWalletSupportedChains(p);
1
+ var S={};u(S,{cosmostationWallet:()=>p,COSMOSTATION_SUPPORTED_CHAINS:()=>y});module.exports=d(S);var o=require("@swapkit/helpers"),l=require("@swapkit/wallet-core"),C=[o.ChainId.Cosmos,o.ChainId.Kujira,o.ChainId.Noble,o.ChainId.THORChain],_=[o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base];async function f(i,c,a){await Promise.all(i.map(async(n)=>{let e=o.ChainToChainId[n];await a.enable(e);let s=a.getOfflineSignerOnlyAmino(e);if(!s)throw new o.SwapKitError("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:r}=await import("@swapkit/toolboxes/cosmos"),t=await s.getAccounts();if(!t?.[0]?.address)throw new o.SwapKitError("wallet_cosmostation_no_accounts");let[{address:w}]=t,h=r(n,{signer:s});c({...h,chain:n,address:w,walletType:o.WalletOption.COSMOSTATION})}))}async function O(i,c){let a=window.ethereum;if(!a)throw new o.SwapKitError("wallet_cosmostation_evm_provider_not_found");let n=await a.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new o.SwapKitError("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");for(let s of i){let r=e(s,{provider:a}),[t]=n;if(!t)throw new o.SwapKitError("wallet_cosmostation_no_evm_address");c({...r,chain:s,address:t,walletType:o.WalletOption.COSMOSTATION})}}var p=l.createWallet({name:"connectCosmostation",supportedChains:[o.Chain.Cosmos,o.Chain.Kujira,o.Chain.Noble,o.Chain.THORChain,o.Chain.Ethereum,o.Chain.BinanceSmartChain,o.Chain.Avalanche,o.Chain.Polygon,o.Chain.Arbitrum,o.Chain.Optimism,o.Chain.Base],connect:({addChain:i,supportedChains:c})=>async function a(n){let e=o.filterSupportedChains({chains:n,supportedChains:c,walletType:o.WalletOption.COSMOSTATION});if(!window.cosmostation)throw new o.SwapKitError("wallet_cosmostation_not_found");let s=e.filter((t)=>C.includes(o.ChainToChainId[t])),r=e.filter((t)=>_.includes(t));if(s.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new o.SwapKitError("wallet_cosmostation_keplr_provider_not_found");await f(s,i,t)}if(r.length>0)await O(r,i);return!0}}),y=l.getWalletSupportedChains(p);
2
2
 
3
- //# debugId=E1DD3228895C0F1164756E2164756E21
3
+ //# debugId=E0B327791930A4FB64756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,9 +2,9 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/cosmostation/index.ts"],
4
4
  "sourcesContent": [
5
- "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n Chain,\n ChainId,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nconst cosmostationSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.THORChain] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: {\n providers?: {\n keplr?: Keplr;\n };\n };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(chain as any, { signer });\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({\n method: \"eth_requestAccounts\",\n })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n ],\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({\n chains,\n supportedChains,\n walletType: WalletOption.COSMOSTATION,\n });\n\n if (!window.cosmostation) {\n throw new SwapKitError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) =>\n cosmostationSupportedEVMChains.includes(chain as any),\n );\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new SwapKitError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
5
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n Chain,\n ChainId,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nconst cosmostationSupportedChainIds = [\n ChainId.Cosmos,\n ChainId.Kujira,\n ChainId.Noble,\n ChainId.THORChain,\n] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: {\n providers?: {\n keplr?: Keplr;\n };\n };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(chain as any, { signer });\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({\n method: \"eth_requestAccounts\",\n })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.Noble,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n ],\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({\n chains,\n supportedChains,\n walletType: WalletOption.COSMOSTATION,\n });\n\n if (!window.cosmostation) {\n throw new SwapKitError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) =>\n cosmostationSupportedEVMChains.includes(chain as any),\n );\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new SwapKitError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
6
6
  ],
7
- "mappings": "iGAQO,IAPP,8BAQA,kCAEM,EAAgC,CAAC,UAAQ,OAAQ,UAAQ,OAAQ,UAAQ,SAAS,EAClF,EAAiC,CACrC,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,IACR,EAYA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,iBAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,IAAK,EAAQ,MAAM,IAAI,eAAa,sCAAsC,EAE1E,IAAQ,oBAAqB,KAAa,qCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,IAAK,IAAW,IAAI,QAAS,MAAM,IAAI,eAAa,iCAAiC,EAErF,KAAS,YAAa,EAChB,EAAU,EAAiB,EAAc,CAAE,QAAO,CAAC,EAEzD,EAAS,IACJ,EACH,QACA,UACA,WAAY,eAAa,YAC3B,CAAC,EACF,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,IAAK,EACH,MAAM,IAAI,eAAa,4CAA4C,EAGrE,IAAM,EAAY,MAAM,EAAS,QAAQ,CACvC,OAAQ,qBACV,CAAC,EAED,IAAK,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,eAAa,qCAAqC,EAG9D,IAAQ,iBAAkB,KAAa,kCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,IAAK,EACH,MAAM,IAAI,eAAa,oCAAoC,EAG7D,EAAS,IACJ,EACH,QACA,UACA,WAAY,eAAa,YAC3B,CAAC,GAIE,IAAM,EAAqB,eAAa,CAC7C,KAAM,sBACN,gBAAiB,CACf,QAAM,OACN,QAAM,OACN,QAAM,UACN,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,IACR,EACA,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAmB,CAAC,EAAiB,CAClD,IAAM,EAAiB,wBAAsB,CAC3C,SACA,kBACA,WAAY,eAAa,YAC3B,CAAC,EAED,IAAK,OAAO,aACV,MAAM,IAAI,eAAa,+BAA+B,EAGxD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,iBAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IACvC,EAA+B,SAAS,CAAY,CACtD,EAEA,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,IAAK,EACH,MAAM,IAAI,eAAa,8CAA8C,EAGvE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,GAEb,CAAC,EAEY,EAAgC,2BAAyB,CAAkB",
8
- "debugId": "E1DD3228895C0F1164756E2164756E21",
7
+ "mappings": "iGAQO,IAPP,8BAQA,kCAEM,EAAgC,CACpC,UAAQ,OACR,UAAQ,OACR,UAAQ,MACR,UAAQ,SACV,EACM,EAAiC,CACrC,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,IACR,EAYA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,iBAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,IAAK,EAAQ,MAAM,IAAI,eAAa,sCAAsC,EAE1E,IAAQ,oBAAqB,KAAa,qCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,IAAK,IAAW,IAAI,QAAS,MAAM,IAAI,eAAa,iCAAiC,EAErF,KAAS,YAAa,EAChB,EAAU,EAAiB,EAAc,CAAE,QAAO,CAAC,EAEzD,EAAS,IACJ,EACH,QACA,UACA,WAAY,eAAa,YAC3B,CAAC,EACF,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,IAAK,EACH,MAAM,IAAI,eAAa,4CAA4C,EAGrE,IAAM,EAAY,MAAM,EAAS,QAAQ,CACvC,OAAQ,qBACV,CAAC,EAED,IAAK,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,eAAa,qCAAqC,EAG9D,IAAQ,iBAAkB,KAAa,kCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,IAAK,EACH,MAAM,IAAI,eAAa,oCAAoC,EAG7D,EAAS,IACJ,EACH,QACA,UACA,WAAY,eAAa,YAC3B,CAAC,GAIE,IAAM,EAAqB,eAAa,CAC7C,KAAM,sBACN,gBAAiB,CACf,QAAM,OACN,QAAM,OACN,QAAM,MACN,QAAM,UACN,QAAM,SACN,QAAM,kBACN,QAAM,UACN,QAAM,QACN,QAAM,SACN,QAAM,SACN,QAAM,IACR,EACA,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAmB,CAAC,EAAiB,CAClD,IAAM,EAAiB,wBAAsB,CAC3C,SACA,kBACA,WAAY,eAAa,YAC3B,CAAC,EAED,IAAK,OAAO,aACV,MAAM,IAAI,eAAa,+BAA+B,EAGxD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,iBAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IACvC,EAA+B,SAAS,CAAY,CACtD,EAEA,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,IAAK,EACH,MAAM,IAAI,eAAa,8CAA8C,EAGvE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,GAEb,CAAC,EAEY,EAAgC,2BAAyB,CAAkB",
8
+ "debugId": "E0B327791930A4FB64756E2164756E21",
9
9
  "names": []
10
10
  }
@@ -1,4 +1,4 @@
1
- import{F as w,G as h}from"../../chunk-yqaz2d25.js";import{Chain as o,ChainId as m,ChainToChainId as d,SwapKitError as i,WalletOption as p,filterSupportedChains as _}from"@swapkit/helpers";import{createWallet as f,getWalletSupportedChains as O}from"@swapkit/wallet-core";var y=[m.Cosmos,m.Kujira,m.THORChain],S=[o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base];async function T(r,l,a){await Promise.all(r.map(async(n)=>{let e=d[n];await a.enable(e);let s=a.getOfflineSignerOnlyAmino(e);if(!s)throw new i("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),t=await s.getAccounts();if(!t?.[0]?.address)throw new i("wallet_cosmostation_no_accounts");let[{address:u}]=t,C=c(n,{signer:s});l({...C,chain:n,address:u,walletType:p.COSMOSTATION})}))}async function g(r,l){let a=window.ethereum;if(!a)throw new i("wallet_cosmostation_evm_provider_not_found");let n=await a.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new i("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");for(let s of r){let c=e(s,{provider:a}),[t]=n;if(!t)throw new i("wallet_cosmostation_no_evm_address");l({...c,chain:s,address:t,walletType:p.COSMOSTATION})}}var v=f({name:"connectCosmostation",supportedChains:[o.Cosmos,o.Kujira,o.THORChain,o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base],connect:({addChain:r,supportedChains:l})=>async function a(n){let e=_({chains:n,supportedChains:l,walletType:p.COSMOSTATION});if(!window.cosmostation)throw new i("wallet_cosmostation_not_found");let s=e.filter((t)=>y.includes(d[t])),c=e.filter((t)=>S.includes(t));if(s.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new i("wallet_cosmostation_keplr_provider_not_found");await T(s,r,t)}if(c.length>0)await g(c,r);return!0}}),b=O(v);export{v as cosmostationWallet,b as COSMOSTATION_SUPPORTED_CHAINS};
1
+ import{F as w,G as h}from"../../chunk-yqaz2d25.js";import{Chain as o,ChainId as m,ChainToChainId as d,SwapKitError as i,WalletOption as p,filterSupportedChains as _}from"@swapkit/helpers";import{createWallet as f,getWalletSupportedChains as O}from"@swapkit/wallet-core";var y=[m.Cosmos,m.Kujira,m.Noble,m.THORChain],S=[o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base];async function T(r,l,a){await Promise.all(r.map(async(n)=>{let e=d[n];await a.enable(e);let s=a.getOfflineSignerOnlyAmino(e);if(!s)throw new i("wallet_cosmostation_signer_not_found");let{getCosmosToolbox:c}=await import("@swapkit/toolboxes/cosmos"),t=await s.getAccounts();if(!t?.[0]?.address)throw new i("wallet_cosmostation_no_accounts");let[{address:u}]=t,C=c(n,{signer:s});l({...C,chain:n,address:u,walletType:p.COSMOSTATION})}))}async function g(r,l){let a=window.ethereum;if(!a)throw new i("wallet_cosmostation_evm_provider_not_found");let n=await a.request({method:"eth_requestAccounts"});if(!n||n.length===0)throw new i("wallet_cosmostation_no_evm_accounts");let{getEvmToolbox:e}=await import("@swapkit/toolboxes/evm");for(let s of r){let c=e(s,{provider:a}),[t]=n;if(!t)throw new i("wallet_cosmostation_no_evm_address");l({...c,chain:s,address:t,walletType:p.COSMOSTATION})}}var v=f({name:"connectCosmostation",supportedChains:[o.Cosmos,o.Kujira,o.Noble,o.THORChain,o.Ethereum,o.BinanceSmartChain,o.Avalanche,o.Polygon,o.Arbitrum,o.Optimism,o.Base],connect:({addChain:r,supportedChains:l})=>async function a(n){let e=_({chains:n,supportedChains:l,walletType:p.COSMOSTATION});if(!window.cosmostation)throw new i("wallet_cosmostation_not_found");let s=e.filter((t)=>y.includes(d[t])),c=e.filter((t)=>S.includes(t));if(s.length>0){let t=window.cosmostation.providers?.keplr;if(!t)throw new i("wallet_cosmostation_keplr_provider_not_found");await T(s,r,t)}if(c.length>0)await g(c,r);return!0}}),I=O(v);export{v as cosmostationWallet,I as COSMOSTATION_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=65EE6BB9DFB1917D64756E2164756E21
3
+ //# debugId=29783CC8488EF3BE64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,9 +2,9 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/cosmostation/index.ts"],
4
4
  "sourcesContent": [
5
- "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n Chain,\n ChainId,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nconst cosmostationSupportedChainIds = [ChainId.Cosmos, ChainId.Kujira, ChainId.THORChain] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: {\n providers?: {\n keplr?: Keplr;\n };\n };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(chain as any, { signer });\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({\n method: \"eth_requestAccounts\",\n })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n ],\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({\n chains,\n supportedChains,\n walletType: WalletOption.COSMOSTATION,\n });\n\n if (!window.cosmostation) {\n throw new SwapKitError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) =>\n cosmostationSupportedEVMChains.includes(chain as any),\n );\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new SwapKitError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
5
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n Chain,\n ChainId,\n ChainToChainId,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nconst cosmostationSupportedChainIds = [\n ChainId.Cosmos,\n ChainId.Kujira,\n ChainId.Noble,\n ChainId.THORChain,\n] as const;\nconst cosmostationSupportedEVMChains = [\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n] as const;\n\ndeclare global {\n interface Window {\n cosmostation?: {\n providers?: {\n keplr?: Keplr;\n };\n };\n }\n}\n\nasync function connectCosmosChains(chains: Chain[], addChain: any, keplrProvider: Keplr) {\n await Promise.all(\n chains.map(async (chain) => {\n const chainId = ChainToChainId[chain] as (typeof cosmostationSupportedChainIds)[number];\n\n await keplrProvider.enable(chainId);\n const signer = keplrProvider.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_cosmostation_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_cosmostation_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(chain as any, { signer });\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }),\n );\n}\n\nasync function connectEvmChains(chains: Chain[], addChain: any) {\n const provider = window.ethereum;\n\n if (!provider) {\n throw new SwapKitError(\"wallet_cosmostation_evm_provider_not_found\");\n }\n\n const accounts = (await provider.request({\n method: \"eth_requestAccounts\",\n })) as string[];\n\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_accounts\");\n }\n\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n\n for (const chain of chains) {\n const toolbox = getEvmToolbox(chain as any, { provider });\n const [address] = accounts;\n\n if (!address) {\n throw new SwapKitError(\"wallet_cosmostation_no_evm_address\");\n }\n\n addChain({\n ...toolbox,\n chain,\n address,\n walletType: WalletOption.COSMOSTATION,\n });\n }\n}\n\nexport const cosmostationWallet = createWallet({\n name: \"connectCosmostation\",\n supportedChains: [\n Chain.Cosmos,\n Chain.Kujira,\n Chain.Noble,\n Chain.THORChain,\n Chain.Ethereum,\n Chain.BinanceSmartChain,\n Chain.Avalanche,\n Chain.Polygon,\n Chain.Arbitrum,\n Chain.Optimism,\n Chain.Base,\n ],\n connect: ({ addChain, supportedChains }) =>\n async function connectCosmostation(chains: Chain[]) {\n const filteredChains = filterSupportedChains({\n chains,\n supportedChains,\n walletType: WalletOption.COSMOSTATION,\n });\n\n if (!window.cosmostation) {\n throw new SwapKitError(\"wallet_cosmostation_not_found\");\n }\n\n const cosmosChains = filteredChains.filter((chain) =>\n cosmostationSupportedChainIds.includes(ChainToChainId[chain] as any),\n );\n const evmChains = filteredChains.filter((chain) =>\n cosmostationSupportedEVMChains.includes(chain as any),\n );\n\n if (cosmosChains.length > 0) {\n const keplrProvider = window.cosmostation.providers?.keplr;\n if (!keplrProvider) {\n throw new SwapKitError(\"wallet_cosmostation_keplr_provider_not_found\");\n }\n\n await connectCosmosChains(cosmosChains, addChain, keplrProvider);\n }\n\n if (evmChains.length > 0) {\n await connectEvmChains(evmChains, addChain);\n }\n\n return true;\n },\n});\n\nexport const COSMOSTATION_SUPPORTED_CHAINS = getWalletSupportedChains(cosmostationWallet);\n"
6
6
  ],
7
- "mappings": "mDACA,gBACE,aACA,oBACA,kBACA,kBACA,2BACA,yBAEF,uBAAS,8BAAc,6BAEvB,IAAM,EAAgC,CAAC,EAAQ,OAAQ,EAAQ,OAAQ,EAAQ,SAAS,EAClF,EAAiC,CACrC,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,IACR,EAYA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,EAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,IAAK,EAAQ,MAAM,IAAI,EAAa,sCAAsC,EAE1E,IAAQ,oBAAqB,KAAa,qCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,IAAK,IAAW,IAAI,QAAS,MAAM,IAAI,EAAa,iCAAiC,EAErF,KAAS,YAAa,EAChB,EAAU,EAAiB,EAAc,CAAE,QAAO,CAAC,EAEzD,EAAS,IACJ,EACH,QACA,UACA,WAAY,EAAa,YAC3B,CAAC,EACF,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,IAAK,EACH,MAAM,IAAI,EAAa,4CAA4C,EAGrE,IAAM,EAAY,MAAM,EAAS,QAAQ,CACvC,OAAQ,qBACV,CAAC,EAED,IAAK,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,EAAa,qCAAqC,EAG9D,IAAQ,iBAAkB,KAAa,kCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,IAAK,EACH,MAAM,IAAI,EAAa,oCAAoC,EAG7D,EAAS,IACJ,EACH,QACA,UACA,WAAY,EAAa,YAC3B,CAAC,GAIE,IAAM,EAAqB,EAAa,CAC7C,KAAM,sBACN,gBAAiB,CACf,EAAM,OACN,EAAM,OACN,EAAM,UACN,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,IACR,EACA,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAmB,CAAC,EAAiB,CAClD,IAAM,EAAiB,EAAsB,CAC3C,SACA,kBACA,WAAY,EAAa,YAC3B,CAAC,EAED,IAAK,OAAO,aACV,MAAM,IAAI,EAAa,+BAA+B,EAGxD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,EAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IACvC,EAA+B,SAAS,CAAY,CACtD,EAEA,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,IAAK,EACH,MAAM,IAAI,EAAa,8CAA8C,EAGvE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,GAEb,CAAC,EAEY,EAAgC,EAAyB,CAAkB",
8
- "debugId": "65EE6BB9DFB1917D64756E2164756E21",
7
+ "mappings": "mDACA,gBACE,aACA,oBACA,kBACA,kBACA,2BACA,yBAEF,uBAAS,8BAAc,6BAEvB,IAAM,EAAgC,CACpC,EAAQ,OACR,EAAQ,OACR,EAAQ,MACR,EAAQ,SACV,EACM,EAAiC,CACrC,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,IACR,EAYA,eAAe,CAAmB,CAAC,EAAiB,EAAe,EAAsB,CACvF,MAAM,QAAQ,IACZ,EAAO,IAAI,MAAO,IAAU,CAC1B,IAAM,EAAU,EAAe,GAE/B,MAAM,EAAc,OAAO,CAAO,EAClC,IAAM,EAAS,EAAc,0BAA0B,CAAO,EAC9D,IAAK,EAAQ,MAAM,IAAI,EAAa,sCAAsC,EAE1E,IAAQ,oBAAqB,KAAa,qCAEpC,EAAW,MAAM,EAAO,YAAY,EAC1C,IAAK,IAAW,IAAI,QAAS,MAAM,IAAI,EAAa,iCAAiC,EAErF,KAAS,YAAa,EAChB,EAAU,EAAiB,EAAc,CAAE,QAAO,CAAC,EAEzD,EAAS,IACJ,EACH,QACA,UACA,WAAY,EAAa,YAC3B,CAAC,EACF,CACH,EAGF,eAAe,CAAgB,CAAC,EAAiB,EAAe,CAC9D,IAAM,EAAW,OAAO,SAExB,IAAK,EACH,MAAM,IAAI,EAAa,4CAA4C,EAGrE,IAAM,EAAY,MAAM,EAAS,QAAQ,CACvC,OAAQ,qBACV,CAAC,EAED,IAAK,GAAY,EAAS,SAAW,EACnC,MAAM,IAAI,EAAa,qCAAqC,EAG9D,IAAQ,iBAAkB,KAAa,kCAEvC,QAAW,KAAS,EAAQ,CAC1B,IAAM,EAAU,EAAc,EAAc,CAAE,UAAS,CAAC,GACjD,GAAW,EAElB,IAAK,EACH,MAAM,IAAI,EAAa,oCAAoC,EAG7D,EAAS,IACJ,EACH,QACA,UACA,WAAY,EAAa,YAC3B,CAAC,GAIE,IAAM,EAAqB,EAAa,CAC7C,KAAM,sBACN,gBAAiB,CACf,EAAM,OACN,EAAM,OACN,EAAM,MACN,EAAM,UACN,EAAM,SACN,EAAM,kBACN,EAAM,UACN,EAAM,QACN,EAAM,SACN,EAAM,SACN,EAAM,IACR,EACA,QAAS,EAAG,WAAU,qBACpB,eAAe,CAAmB,CAAC,EAAiB,CAClD,IAAM,EAAiB,EAAsB,CAC3C,SACA,kBACA,WAAY,EAAa,YAC3B,CAAC,EAED,IAAK,OAAO,aACV,MAAM,IAAI,EAAa,+BAA+B,EAGxD,IAAM,EAAe,EAAe,OAAO,CAAC,IAC1C,EAA8B,SAAS,EAAe,EAAa,CACrE,EACM,EAAY,EAAe,OAAO,CAAC,IACvC,EAA+B,SAAS,CAAY,CACtD,EAEA,GAAI,EAAa,OAAS,EAAG,CAC3B,IAAM,EAAgB,OAAO,aAAa,WAAW,MACrD,IAAK,EACH,MAAM,IAAI,EAAa,8CAA8C,EAGvE,MAAM,EAAoB,EAAc,EAAU,CAAa,EAGjE,GAAI,EAAU,OAAS,EACrB,MAAM,EAAiB,EAAW,CAAQ,EAG5C,MAAO,GAEb,CAAC,EAEY,EAAgC,EAAyB,CAAkB",
8
+ "debugId": "29783CC8488EF3BE64756E2164756E21",
9
9
  "names": []
10
10
  }
@@ -1,4 +1,4 @@
1
- var f={};A(f,{ctrlWallet:()=>V,CTRL_SUPPORTED_CHAINS:()=>b});module.exports=T(f);var z=require("@swapkit/helpers"),K=require("@swapkit/wallet-core");var Q=require("@swapkit/helpers"),k=require("@swapkit/helpers/contracts");async function _(J){if(!window.xfi)throw new Q.SwapKitError("wallet_ctrl_not_found");let{match:$}=await import("ts-pattern");return $(J).with(Q.Chain.Arbitrum,Q.Chain.Aurora,Q.Chain.Avalanche,Q.Chain.Base,Q.Chain.Berachain,Q.Chain.BinanceSmartChain,Q.Chain.Ethereum,Q.Chain.Gnosis,Q.Chain.Optimism,Q.Chain.Polygon,()=>window.xfi?.ethereum).with(Q.Chain.Cosmos,Q.Chain.Kujira,()=>window.xfi?.keplr).with(Q.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(Q.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(Q.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(Q.Chain.Litecoin,()=>window.xfi?.litecoin).with(Q.Chain.Solana,()=>window.xfi?.solana).with(Q.Chain.THORChain,()=>window.xfi?.thorchain).with(Q.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function S({method:J,params:$,chain:F}){let Z=await _(F);return new Promise((D,X)=>{if(Z&&"request"in Z)Z.request({method:J,params:$},(q,H)=>{q?X(q):D(H)})})}async function O(J){try{let $=await _(J);if(!$)throw new Q.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:Q.WalletOption.CTRL,chain:J}});if([Q.Chain.Cosmos,Q.Chain.Kujira].includes(J)){let Z=await _(Q.Chain.Cosmos);if(!Z||"request"in Z)throw new Q.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:Q.WalletOption.CTRL,chain:J}});let D=Q.ChainToChainId[J];await Z.enable(D);let X=Z.getOfflineSigner(D),[q]=await X.getAccounts();return q?.address}if(Q.EVMChains.includes(J)){if("request"in $&&typeof $.request==="function")return(await $.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Z}=await import("ethers"),D=new Z($,"any"),[X]=await Q.providerRequest({provider:D,method:"eth_requestAccounts",params:[]});return X}if(J===Q.Chain.Solana)return(await(await _(Q.Chain.Solana)).connect()).publicKey.toString();if(J===Q.Chain.Near){if(!window.xfi?.near)throw new Q.SwapKitError("wallet_ctrl_not_found",{chain:Q.Chain.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await $.request({method:"request_accounts",params:[]}))[0]}catch($){throw new Q.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:Q.WalletOption.CTRL,chain:J}})}}async function I({assetValue:J,recipient:$,memo:F,gasLimit:Z},D="transfer"){if(!J)throw new Q.SwapKitError("wallet_ctrl_asset_not_defined");let X=await O(J.chain),q=[{amount:{amount:J.getBaseValue("number"),decimals:J.decimal},asset:{chain:J.chain,symbol:J.symbol.toUpperCase(),ticker:J.symbol.toUpperCase()},memo:F||"",from:X,recipient:$,gasLimit:Z}];return S({method:D,params:q,chain:J.chain})}function E(J,$){return{call:async({contractAddress:F,abi:Z,funcName:D,funcParams:X=[],txOverrides:q})=>{if(!F)throw new Q.SwapKitError("wallet_ctrl_contract_address_not_provided");let{createContract:H,getCreateContractTxObject:Y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Z,funcName:D})){let R=Y({provider:J,chain:$}),{value:L,from:M,to:W,data:N}=await R({contractAddress:F,abi:Z,funcName:D,funcParams:X,txOverrides:q});return(await(await J.getSigner()).sendTransaction({value:BigInt(L||0),from:M,to:W,data:N||"0x"})).hash}let U=await H(F,Z,J)[D]?.(...X);return typeof U?.hash==="string"?U?.hash:U},approve:async({assetAddress:F,spenderAddress:Z,amount:D,from:X})=>{let{MAX_APPROVAL:q,getCreateContractTxObject:H}=await import("@swapkit/toolboxes/evm"),Y=[Z,BigInt(D||q)],y={contractAddress:F,abi:k.erc20ABI,funcName:"approve",funcParams:Y,txOverrides:{from:X}},j=H({provider:J,chain:$}),{value:U,to:R,data:L}=await j(y);return(await(await J.getSigner()).sendTransaction({value:BigInt(U||0),from:X,to:R,data:L||"0x"})).hash},sendTransaction:async(F)=>{let{from:Z,to:D,data:X,value:q}=F;if(!D)throw new Q.SwapKitError("wallet_ctrl_send_transaction_no_address");return(await(await J.getSigner()).sendTransaction({value:BigInt(q||0),from:Z,to:D,data:X||"0x"})).hash}}}var V=K.createWallet({name:"connectCtrl",walletType:z.WalletOption.CTRL,supportedChains:[z.Chain.Arbitrum,z.Chain.Aurora,z.Chain.Avalanche,z.Chain.Base,z.Chain.Berachain,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dogecoin,z.Chain.Ethereum,z.Chain.Gnosis,z.Chain.Kujira,z.Chain.Litecoin,z.Chain.Maya,z.Chain.Near,z.Chain.Optimism,z.Chain.Polygon,z.Chain.Solana,z.Chain.THORChain],connect:({addChain:J,walletType:$,supportedChains:F})=>async function Z(D){let q=z.filterSupportedChains({chains:D,supportedChains:F,walletType:$}).map(async(H)=>{let Y=await O(H),B=await P(H);J({...B,address:Y,chain:H,walletType:$})});return await Promise.all(q),!0}}),b=K.getWalletSupportedChains(V);async function P(J){switch(J){case z.Chain.Solana:{let{getSolanaToolbox:$}=await import("@swapkit/toolboxes/solana"),F=window.xfi?.solana;if(!F)throw new z.SwapKitError("wallet_ctrl_not_found");return{...$({signer:F})}}case z.Chain.Maya:case z.Chain.THORChain:{let{getCosmosToolbox:$,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:Z}=await import("@swapkit/toolboxes/cosmos"),D=J===z.Chain.Maya?Z:F;return{...await $(J),deposit:(q)=>I({...q,recipient:""},"deposit"),transfer:(q)=>I({...q,gasLimit:D},"transfer")}}case z.Chain.Cosmos:case z.Chain.Kujira:{let{getCosmosToolbox:$}=await import("@swapkit/toolboxes/cosmos"),F=z.ChainToChainId[J],Z=await _(J);await Z?.enable(F);let D=Z?.getOfflineSignerOnlyAmino(F);if(!D)throw new z.SwapKitError("wallet_ctrl_not_found");return $(J,{signer:D})}case z.Chain.Bitcoin:case z.Chain.BitcoinCash:case z.Chain.Dogecoin:case z.Chain.Litecoin:{let{getUtxoToolbox:$}=await import("@swapkit/toolboxes/utxo");return{...await $(J),transfer:I}}case z.Chain.Arbitrum:case z.Chain.Aurora:case z.Chain.Avalanche:case z.Chain.Base:case z.Chain.Berachain:case z.Chain.BinanceSmartChain:case z.Chain.Ethereum:case z.Chain.Gnosis:case z.Chain.Optimism:case z.Chain.Polygon:{let{prepareNetworkSwitch:$,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:D}=await import("ethers"),X=await _(J);if(!X)throw new z.SwapKitError("wallet_ctrl_not_found");let q=new D(X,"any"),H=await q.getSigner(),Y=await Z(J,{provider:q,signer:H}),B=E(q,J);try{if(J!==z.Chain.Ethereum){let y=Y.getNetworkParams();await F(q,J,y)}}catch(y){throw new z.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:z.WalletOption.CTRL,chain:J}})}return $({provider:window.xfi?.ethereum,chain:J,toolbox:{...Y,...B}})}case z.Chain.Near:{if(!window.xfi?.near)throw new z.SwapKitError("wallet_ctrl_not_found",{chain:z.Chain.Near});let{createNearSignerFromProvider:$}=await import("../../chunk-wfattb4a.js"),{getNearToolbox:F}=await import("@swapkit/toolboxes/near"),Z=window.xfi.near,D=await $(Z,"CTRL"),X=await D.getAddress();return{...await F({signer:D}),transfer:async(B)=>{let{transfer:y}=await import("near-api-js/lib/transaction"),j=B.assetValue.getBaseValue("string"),U=y(BigInt(j)),R={signerId:X,receiverId:B.recipient,actions:[U]};return await Z.request({method:"signAndSendTransaction",params:{transaction:R}})},createTransaction:async(B)=>{let{functionCall:y,transfer:j}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:L,args:M,attachedDeposit:W}=B.functionCall,N=y(L,M,BigInt("30000000000000"),BigInt(W||"0"));return{signerId:X,receiverId:B.recipient,actions:[N]}}let U=B.assetValue.getBaseValue("string"),R=j(BigInt(U));return{signerId:X,receiverId:B.recipient,actions:[R]}}}}default:return null}}
1
+ var f={};A(f,{ctrlWallet:()=>V,CTRL_SUPPORTED_CHAINS:()=>b});module.exports=T(f);var z=require("@swapkit/helpers"),K=require("@swapkit/wallet-core");var J=require("@swapkit/helpers"),k=require("@swapkit/helpers/contracts");async function _(Q){if(!window.xfi)throw new J.SwapKitError("wallet_ctrl_not_found");let{match:$}=await import("ts-pattern");return $(Q).with(J.Chain.Arbitrum,J.Chain.Aurora,J.Chain.Avalanche,J.Chain.Base,J.Chain.Berachain,J.Chain.BinanceSmartChain,J.Chain.Ethereum,J.Chain.Gnosis,J.Chain.Optimism,J.Chain.Polygon,()=>window.xfi?.ethereum).with(J.Chain.Cosmos,J.Chain.Kujira,J.Chain.Noble,()=>window.xfi?.keplr).with(J.Chain.Bitcoin,()=>window.xfi?.bitcoin).with(J.Chain.BitcoinCash,()=>window.xfi?.bitcoincash).with(J.Chain.Dogecoin,()=>window.xfi?.dogecoin).with(J.Chain.Litecoin,()=>window.xfi?.litecoin).with(J.Chain.Solana,()=>window.xfi?.solana).with(J.Chain.THORChain,()=>window.xfi?.thorchain).with(J.Chain.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function S({method:Q,params:$,chain:F}){let Z=await _(F);return new Promise((D,X)=>{if(Z&&"request"in Z)Z.request({method:Q,params:$},(q,H)=>{q?X(q):D(H)})})}async function O(Q){try{let $=await _(Q);if(!$)throw new J.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:J.WalletOption.CTRL,chain:Q}});if([J.Chain.Cosmos,J.Chain.Kujira,J.Chain.Noble].includes(Q)){let Z=await _(J.Chain.Cosmos);if(!Z||"request"in Z)throw new J.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:J.WalletOption.CTRL,chain:Q}});let D=J.ChainToChainId[Q];await Z.enable(D);let X=Z.getOfflineSigner(D),[q]=await X.getAccounts();return q?.address}if(J.EVMChains.includes(Q)){if("request"in $&&typeof $.request==="function")return(await $.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Z}=await import("ethers"),D=new Z($,"any"),[X]=await J.providerRequest({provider:D,method:"eth_requestAccounts",params:[]});return X}if(Q===J.Chain.Solana)return(await(await _(J.Chain.Solana)).connect()).publicKey.toString();if(Q===J.Chain.Near){if(!window.xfi?.near)throw new J.SwapKitError("wallet_ctrl_not_found",{chain:J.Chain.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await $.request({method:"request_accounts",params:[]}))[0]}catch($){throw new J.SwapKitError({errorKey:"wallet_provider_not_found",info:{wallet:J.WalletOption.CTRL,chain:Q}})}}async function I({assetValue:Q,recipient:$,memo:F,gasLimit:Z},D="transfer"){if(!Q)throw new J.SwapKitError("wallet_ctrl_asset_not_defined");let X=await O(Q.chain),q=[{amount:{amount:Q.getBaseValue("number"),decimals:Q.decimal},asset:{chain:Q.chain,symbol:Q.symbol.toUpperCase(),ticker:Q.symbol.toUpperCase()},memo:F||"",from:X,recipient:$,gasLimit:Z}];return S({method:D,params:q,chain:Q.chain})}function E(Q,$){return{call:async({contractAddress:F,abi:Z,funcName:D,funcParams:X=[],txOverrides:q})=>{if(!F)throw new J.SwapKitError("wallet_ctrl_contract_address_not_provided");let{createContract:H,getCreateContractTxObject:Y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Z,funcName:D})){let R=Y({provider:Q,chain:$}),{value:L,from:M,to:W,data:N}=await R({contractAddress:F,abi:Z,funcName:D,funcParams:X,txOverrides:q});return(await(await Q.getSigner()).sendTransaction({value:BigInt(L||0),from:M,to:W,data:N||"0x"})).hash}let U=await H(F,Z,Q)[D]?.(...X);return typeof U?.hash==="string"?U?.hash:U},approve:async({assetAddress:F,spenderAddress:Z,amount:D,from:X})=>{let{MAX_APPROVAL:q,getCreateContractTxObject:H}=await import("@swapkit/toolboxes/evm"),Y=[Z,BigInt(D||q)],y={contractAddress:F,abi:k.erc20ABI,funcName:"approve",funcParams:Y,txOverrides:{from:X}},j=H({provider:Q,chain:$}),{value:U,to:R,data:L}=await j(y);return(await(await Q.getSigner()).sendTransaction({value:BigInt(U||0),from:X,to:R,data:L||"0x"})).hash},sendTransaction:async(F)=>{let{from:Z,to:D,data:X,value:q}=F;if(!D)throw new J.SwapKitError("wallet_ctrl_send_transaction_no_address");return(await(await Q.getSigner()).sendTransaction({value:BigInt(q||0),from:Z,to:D,data:X||"0x"})).hash}}}var V=K.createWallet({name:"connectCtrl",walletType:z.WalletOption.CTRL,supportedChains:[z.Chain.Arbitrum,z.Chain.Aurora,z.Chain.Avalanche,z.Chain.Base,z.Chain.Berachain,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dogecoin,z.Chain.Ethereum,z.Chain.Gnosis,z.Chain.Kujira,z.Chain.Litecoin,z.Chain.Maya,z.Chain.Near,z.Chain.Noble,z.Chain.Optimism,z.Chain.Polygon,z.Chain.Solana,z.Chain.THORChain],connect:({addChain:Q,walletType:$,supportedChains:F})=>async function Z(D){let q=z.filterSupportedChains({chains:D,supportedChains:F,walletType:$}).map(async(H)=>{let Y=await O(H),B=await P(H);Q({...B,address:Y,chain:H,walletType:$})});return await Promise.all(q),!0}}),b=K.getWalletSupportedChains(V);async function P(Q){switch(Q){case z.Chain.Solana:{let{getSolanaToolbox:$}=await import("@swapkit/toolboxes/solana"),F=window.xfi?.solana;if(!F)throw new z.SwapKitError("wallet_ctrl_not_found");return{...$({signer:F})}}case z.Chain.Maya:case z.Chain.THORChain:{let{getCosmosToolbox:$,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:Z}=await import("@swapkit/toolboxes/cosmos"),D=Q===z.Chain.Maya?Z:F;return{...await $(Q),deposit:(q)=>I({...q,recipient:""},"deposit"),transfer:(q)=>I({...q,gasLimit:D},"transfer")}}case z.Chain.Cosmos:case z.Chain.Kujira:case z.Chain.Noble:{let{getCosmosToolbox:$}=await import("@swapkit/toolboxes/cosmos"),F=z.ChainToChainId[Q],Z=await _(Q);await Z?.enable(F);let D=Z?.getOfflineSignerOnlyAmino(F);if(!D)throw new z.SwapKitError("wallet_ctrl_not_found");return $(Q,{signer:D})}case z.Chain.Bitcoin:case z.Chain.BitcoinCash:case z.Chain.Dogecoin:case z.Chain.Litecoin:{let{getUtxoToolbox:$}=await import("@swapkit/toolboxes/utxo");return{...await $(Q),transfer:I}}case z.Chain.Arbitrum:case z.Chain.Aurora:case z.Chain.Avalanche:case z.Chain.Base:case z.Chain.Berachain:case z.Chain.BinanceSmartChain:case z.Chain.Ethereum:case z.Chain.Gnosis:case z.Chain.Optimism:case z.Chain.Polygon:{let{prepareNetworkSwitch:$,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:D}=await import("ethers"),X=await _(Q);if(!X)throw new z.SwapKitError("wallet_ctrl_not_found");let q=new D(X,"any"),H=await q.getSigner(),Y=await Z(Q,{provider:q,signer:H}),B=E(q,Q);try{if(Q!==z.Chain.Ethereum){let y=Y.getNetworkParams();await F(q,Q,y)}}catch(y){throw new z.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:z.WalletOption.CTRL,chain:Q}})}return $({provider:window.xfi?.ethereum,chain:Q,toolbox:{...Y,...B}})}case z.Chain.Near:{if(!window.xfi?.near)throw new z.SwapKitError("wallet_ctrl_not_found",{chain:z.Chain.Near});let{createNearSignerFromProvider:$}=await import("../../chunk-wfattb4a.js"),{getNearToolbox:F}=await import("@swapkit/toolboxes/near"),Z=window.xfi.near,D=await $(Z,"CTRL"),X=await D.getAddress();return{...await F({signer:D}),transfer:async(B)=>{let{transfer:y}=await import("near-api-js/lib/transaction"),j=B.assetValue.getBaseValue("string"),U=y(BigInt(j)),R={signerId:X,receiverId:B.recipient,actions:[U]};return await Z.request({method:"signAndSendTransaction",params:{transaction:R}})},createTransaction:async(B)=>{let{functionCall:y,transfer:j}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:L,args:M,attachedDeposit:W}=B.functionCall,N=y(L,M,BigInt("30000000000000"),BigInt(W||"0"));return{signerId:X,receiverId:B.recipient,actions:[N]}}let U=B.assetValue.getBaseValue("string"),R=j(BigInt(U));return{signerId:X,receiverId:B.recipient,actions:[R]}}}}default:return null}}
2
2
 
3
- //# debugId=0EC4FB8D4344166564756E2164756E21
3
+ //# debugId=373515D03ABE6BAB64756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n // Override transfer method to use CTRL's direct API\n const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n // Convert AssetValue to NEAR amount (yoctoNEAR)\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n\n // Create transfer action\n const action = transferAction(BigInt(amountInYocto));\n\n // Create transaction object for CTRL\n const transaction = {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n\n const txHash: string = await provider.request({\n method: \"signAndSendTransaction\",\n params: {\n transaction,\n },\n });\n\n return txHash;\n };\n\n // Override createTransaction to build NEAR transactions for CTRL\n const createTransaction = async (params: NearCreateTransactionParams) => {\n const { functionCall, transfer: transferAction } = await import(\n \"near-api-js/lib/transaction\"\n );\n\n if (params.functionCall) {\n // Function call transaction\n const { methodName, args, attachedDeposit } = params.functionCall;\n const action = functionCall(\n methodName,\n args,\n BigInt(\"30000000000000\"), // 30 TGas default\n BigInt(attachedDeposit || \"0\"),\n );\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n };\n\n return {\n ...toolbox,\n transfer,\n createTransaction,\n };\n }\n\n default:\n return null;\n }\n}\n",
6
- "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({\n method: \"connect\",\n });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
5
+ "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n // Override transfer method to use CTRL's direct API\n const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n // Convert AssetValue to NEAR amount (yoctoNEAR)\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n\n // Create transfer action\n const action = transferAction(BigInt(amountInYocto));\n\n // Create transaction object for CTRL\n const transaction = {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n\n const txHash: string = await provider.request({\n method: \"signAndSendTransaction\",\n params: {\n transaction,\n },\n });\n\n return txHash;\n };\n\n // Override createTransaction to build NEAR transactions for CTRL\n const createTransaction = async (params: NearCreateTransactionParams) => {\n const { functionCall, transfer: transferAction } = await import(\n \"near-api-js/lib/transaction\"\n );\n\n if (params.functionCall) {\n // Function call transaction\n const { methodName, args, attachedDeposit } = params.functionCall;\n const action = functionCall(\n methodName,\n args,\n BigInt(\"30000000000000\"), // 30 TGas default\n BigInt(attachedDeposit || \"0\"),\n );\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n };\n\n return {\n ...toolbox,\n transfer,\n createTransaction,\n };\n }\n\n default:\n return null;\n }\n}\n",
6
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira | Chain.Noble\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({\n method: \"connect\",\n });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "0EC4FB8D4344166564756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "373515D03ABE6BAB64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- import{F as G,G as H}from"../../chunk-yqaz2d25.js";import{Chain as J,ChainToChainId as x,SwapKitError as I,WalletOption as T,filterSupportedChains as w}from"@swapkit/helpers";import{createWallet as v,getWalletSupportedChains as u}from"@swapkit/wallet-core";import{Chain as F,ChainToChainId as A,EVMChains as b,SwapKitError as _,WalletOption as E,providerRequest as P}from"@swapkit/helpers";import{erc20ABI as f}from"@swapkit/helpers/contracts";async function L(z){if(!window.xfi)throw new _("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(F.Arbitrum,F.Aurora,F.Avalanche,F.Base,F.Berachain,F.BinanceSmartChain,F.Ethereum,F.Gnosis,F.Optimism,F.Polygon,()=>window.xfi?.ethereum).with(F.Cosmos,F.Kujira,()=>window.xfi?.keplr).with(F.Bitcoin,()=>window.xfi?.bitcoin).with(F.BitcoinCash,()=>window.xfi?.bitcoincash).with(F.Dogecoin,()=>window.xfi?.dogecoin).with(F.Litecoin,()=>window.xfi?.litecoin).with(F.Solana,()=>window.xfi?.solana).with(F.THORChain,()=>window.xfi?.thorchain).with(F.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function g({method:z,params:Z,chain:D}){let Q=await L(D);return new Promise(($,X)=>{if(Q&&"request"in Q)Q.request({method:z,params:Z},(q,Y)=>{q?X(q):$(Y)})})}async function V(z){try{let Z=await L(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});if([F.Cosmos,F.Kujira].includes(z)){let Q=await L(F.Cosmos);if(!Q||"request"in Q)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});let $=A[z];await Q.enable($);let X=Q.getOfflineSigner($),[q]=await X.getAccounts();return q?.address}if(b.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Q}=await import("ethers"),$=new Q(Z,"any"),[X]=await P({provider:$,method:"eth_requestAccounts",params:[]});return X}if(z===F.Solana)return(await(await L(F.Solana)).connect()).publicKey.toString();if(z===F.Near){if(!window.xfi?.near)throw new _("wallet_ctrl_not_found",{chain:F.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}})}}async function O({assetValue:z,recipient:Z,memo:D,gasLimit:Q},$="transfer"){if(!z)throw new _("wallet_ctrl_asset_not_defined");let X=await V(z.chain),q=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},memo:D||"",from:X,recipient:Z,gasLimit:Q}];return g({method:$,params:q,chain:z.chain})}function S(z,Z){return{call:async({contractAddress:D,abi:Q,funcName:$,funcParams:X=[],txOverrides:q})=>{if(!D)throw new _("wallet_ctrl_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Q,funcName:$})){let j=y({provider:z,chain:Z}),{value:W,from:K,to:N,data:k}=await j({contractAddress:D,abi:Q,funcName:$,funcParams:X,txOverrides:q});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:K,to:N,data:k||"0x"})).hash}let R=await Y(D,Q,z)[$]?.(...X);return typeof R?.hash==="string"?R?.hash:R},approve:async({assetAddress:D,spenderAddress:Q,amount:$,from:X})=>{let{MAX_APPROVAL:q,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),y=[Q,BigInt($||q)],U={contractAddress:D,abi:f,funcName:"approve",funcParams:y,txOverrides:{from:X}},M=Y({provider:z,chain:Z}),{value:R,to:j,data:W}=await M(U);return(await(await z.getSigner()).sendTransaction({value:BigInt(R||0),from:X,to:j,data:W||"0x"})).hash},sendTransaction:async(D)=>{let{from:Q,to:$,data:X,value:q}=D;if(!$)throw new _("wallet_ctrl_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(q||0),from:Q,to:$,data:X||"0x"})).hash}}}var m=v({name:"connectCtrl",walletType:T.CTRL,supportedChains:[J.Arbitrum,J.Aurora,J.Avalanche,J.Base,J.Berachain,J.BinanceSmartChain,J.Bitcoin,J.BitcoinCash,J.Cosmos,J.Dogecoin,J.Ethereum,J.Gnosis,J.Kujira,J.Litecoin,J.Maya,J.Near,J.Optimism,J.Polygon,J.Solana,J.THORChain],connect:({addChain:z,walletType:Z,supportedChains:D})=>async function Q($){let q=w({chains:$,supportedChains:D,walletType:Z}).map(async(Y)=>{let y=await V(Y),B=await C(Y);z({...B,address:y,chain:Y,walletType:Z})});return await Promise.all(q),!0}}),n=u(m);async function C(z){switch(z){case J.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),D=window.xfi?.solana;if(!D)throw new I("wallet_ctrl_not_found");return{...Z({signer:D})}}case J.Maya:case J.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:D,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===J.Maya?Q:D;return{...await Z(z),deposit:(q)=>O({...q,recipient:""},"deposit"),transfer:(q)=>O({...q,gasLimit:$},"transfer")}}case J.Cosmos:case J.Kujira:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),D=x[z],Q=await L(z);await Q?.enable(D);let $=Q?.getOfflineSignerOnlyAmino(D);if(!$)throw new I("wallet_ctrl_not_found");return Z(z,{signer:$})}case J.Bitcoin:case J.BitcoinCash:case J.Dogecoin:case J.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(z),transfer:O}}case J.Arbitrum:case J.Aurora:case J.Avalanche:case J.Base:case J.Berachain:case J.BinanceSmartChain:case J.Ethereum:case J.Gnosis:case J.Optimism:case J.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:D}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),X=await L(z);if(!X)throw new I("wallet_ctrl_not_found");let q=new $(X,"any"),Y=await q.getSigner(),y=await Q(z,{provider:q,signer:Y}),B=S(q,z);try{if(z!==J.Ethereum){let U=y.getNetworkParams();await D(q,z,U)}}catch(U){throw new I({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:T.CTRL,chain:z}})}return Z({provider:window.xfi?.ethereum,chain:z,toolbox:{...y,...B}})}case J.Near:{if(!window.xfi?.near)throw new I("wallet_ctrl_not_found",{chain:J.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-mcrgqfr9.js"),{getNearToolbox:D}=await import("@swapkit/toolboxes/near"),Q=window.xfi.near,$=await Z(Q,"CTRL"),X=await $.getAddress();return{...await D({signer:$}),transfer:async(B)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),M=B.assetValue.getBaseValue("string"),R=U(BigInt(M)),j={signerId:X,receiverId:B.recipient,actions:[R]};return await Q.request({method:"signAndSendTransaction",params:{transaction:j}})},createTransaction:async(B)=>{let{functionCall:U,transfer:M}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:W,args:K,attachedDeposit:N}=B.functionCall,k=U(W,K,BigInt("30000000000000"),BigInt(N||"0"));return{signerId:X,receiverId:B.recipient,actions:[k]}}let R=B.assetValue.getBaseValue("string"),j=M(BigInt(R));return{signerId:X,receiverId:B.recipient,actions:[j]}}}}default:return null}}export{m as ctrlWallet,n as CTRL_SUPPORTED_CHAINS};
1
+ import{F as G,G as H}from"../../chunk-yqaz2d25.js";import{Chain as J,ChainToChainId as x,SwapKitError as I,WalletOption as T,filterSupportedChains as w}from"@swapkit/helpers";import{createWallet as v,getWalletSupportedChains as u}from"@swapkit/wallet-core";import{Chain as D,ChainToChainId as A,EVMChains as b,SwapKitError as _,WalletOption as E,providerRequest as P}from"@swapkit/helpers";import{erc20ABI as f}from"@swapkit/helpers/contracts";async function L(z){if(!window.xfi)throw new _("wallet_ctrl_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(D.Arbitrum,D.Aurora,D.Avalanche,D.Base,D.Berachain,D.BinanceSmartChain,D.Ethereum,D.Gnosis,D.Optimism,D.Polygon,()=>window.xfi?.ethereum).with(D.Cosmos,D.Kujira,D.Noble,()=>window.xfi?.keplr).with(D.Bitcoin,()=>window.xfi?.bitcoin).with(D.BitcoinCash,()=>window.xfi?.bitcoincash).with(D.Dogecoin,()=>window.xfi?.dogecoin).with(D.Litecoin,()=>window.xfi?.litecoin).with(D.Solana,()=>window.xfi?.solana).with(D.THORChain,()=>window.xfi?.thorchain).with(D.Maya,()=>window.xfi?.mayachain).otherwise(()=>{return})}async function g({method:z,params:Z,chain:F}){let Q=await L(F);return new Promise(($,X)=>{if(Q&&"request"in Q)Q.request({method:z,params:Z},(q,Y)=>{q?X(q):$(Y)})})}async function V(z){try{let Z=await L(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});if([D.Cosmos,D.Kujira,D.Noble].includes(z)){let Q=await L(D.Cosmos);if(!Q||"request"in Q)throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}});let $=A[z];await Q.enable($);let X=Q.getOfflineSigner($),[q]=await X.getAccounts();return q?.address}if(b.includes(z)){if("request"in Z&&typeof Z.request==="function")return(await Z.request({method:"eth_requestAccounts"}))[0];let{BrowserProvider:Q}=await import("ethers"),$=new Q(Z,"any"),[X]=await P({provider:$,method:"eth_requestAccounts",params:[]});return X}if(z===D.Solana)return(await(await L(D.Solana)).connect()).publicKey.toString();if(z===D.Near){if(!window.xfi?.near)throw new _("wallet_ctrl_not_found",{chain:D.Near});if(!window.xfi.near.isSignedIn?.())return(await window.xfi.near.request?.({method:"connect"}))?.[0]||"";return window.xfi.near.getAccountId?.()||""}return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{wallet:E.CTRL,chain:z}})}}async function O({assetValue:z,recipient:Z,memo:F,gasLimit:Q},$="transfer"){if(!z)throw new _("wallet_ctrl_asset_not_defined");let X=await V(z.chain),q=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},memo:F||"",from:X,recipient:Z,gasLimit:Q}];return g({method:$,params:q,chain:z.chain})}function S(z,Z){return{call:async({contractAddress:F,abi:Q,funcName:$,funcParams:X=[],txOverrides:q})=>{if(!F)throw new _("wallet_ctrl_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:y,isStateChangingCall:B}=await import("@swapkit/toolboxes/evm");if(B({abi:Q,funcName:$})){let j=y({provider:z,chain:Z}),{value:W,from:K,to:N,data:k}=await j({contractAddress:F,abi:Q,funcName:$,funcParams:X,txOverrides:q});return(await(await z.getSigner()).sendTransaction({value:BigInt(W||0),from:K,to:N,data:k||"0x"})).hash}let R=await Y(F,Q,z)[$]?.(...X);return typeof R?.hash==="string"?R?.hash:R},approve:async({assetAddress:F,spenderAddress:Q,amount:$,from:X})=>{let{MAX_APPROVAL:q,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),y=[Q,BigInt($||q)],U={contractAddress:F,abi:f,funcName:"approve",funcParams:y,txOverrides:{from:X}},M=Y({provider:z,chain:Z}),{value:R,to:j,data:W}=await M(U);return(await(await z.getSigner()).sendTransaction({value:BigInt(R||0),from:X,to:j,data:W||"0x"})).hash},sendTransaction:async(F)=>{let{from:Q,to:$,data:X,value:q}=F;if(!$)throw new _("wallet_ctrl_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({value:BigInt(q||0),from:Q,to:$,data:X||"0x"})).hash}}}var m=v({name:"connectCtrl",walletType:T.CTRL,supportedChains:[J.Arbitrum,J.Aurora,J.Avalanche,J.Base,J.Berachain,J.BinanceSmartChain,J.Bitcoin,J.BitcoinCash,J.Cosmos,J.Dogecoin,J.Ethereum,J.Gnosis,J.Kujira,J.Litecoin,J.Maya,J.Near,J.Noble,J.Optimism,J.Polygon,J.Solana,J.THORChain],connect:({addChain:z,walletType:Z,supportedChains:F})=>async function Q($){let q=w({chains:$,supportedChains:F,walletType:Z}).map(async(Y)=>{let y=await V(Y),B=await C(Y);z({...B,address:y,chain:Y,walletType:Z})});return await Promise.all(q),!0}}),n=u(m);async function C(z){switch(z){case J.Solana:{let{getSolanaToolbox:Z}=await import("@swapkit/toolboxes/solana"),F=window.xfi?.solana;if(!F)throw new I("wallet_ctrl_not_found");return{...Z({signer:F})}}case J.Maya:case J.THORChain:{let{getCosmosToolbox:Z,THORCHAIN_GAS_VALUE:F,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===J.Maya?Q:F;return{...await Z(z),deposit:(q)=>O({...q,recipient:""},"deposit"),transfer:(q)=>O({...q,gasLimit:$},"transfer")}}case J.Cosmos:case J.Kujira:case J.Noble:{let{getCosmosToolbox:Z}=await import("@swapkit/toolboxes/cosmos"),F=x[z],Q=await L(z);await Q?.enable(F);let $=Q?.getOfflineSignerOnlyAmino(F);if(!$)throw new I("wallet_ctrl_not_found");return Z(z,{signer:$})}case J.Bitcoin:case J.BitcoinCash:case J.Dogecoin:case J.Litecoin:{let{getUtxoToolbox:Z}=await import("@swapkit/toolboxes/utxo");return{...await Z(z),transfer:O}}case J.Arbitrum:case J.Aurora:case J.Avalanche:case J.Base:case J.Berachain:case J.BinanceSmartChain:case J.Ethereum:case J.Gnosis:case J.Optimism:case J.Polygon:{let{prepareNetworkSwitch:Z,switchEVMWalletNetwork:F}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),X=await L(z);if(!X)throw new I("wallet_ctrl_not_found");let q=new $(X,"any"),Y=await q.getSigner(),y=await Q(z,{provider:q,signer:Y}),B=S(q,z);try{if(z!==J.Ethereum){let U=y.getNetworkParams();await F(q,z,U)}}catch(U){throw new I({errorKey:"wallet_failed_to_add_or_switch_network",info:{wallet:T.CTRL,chain:z}})}return Z({provider:window.xfi?.ethereum,chain:z,toolbox:{...y,...B}})}case J.Near:{if(!window.xfi?.near)throw new I("wallet_ctrl_not_found",{chain:J.Near});let{createNearSignerFromProvider:Z}=await import("../../chunk-mcrgqfr9.js"),{getNearToolbox:F}=await import("@swapkit/toolboxes/near"),Q=window.xfi.near,$=await Z(Q,"CTRL"),X=await $.getAddress();return{...await F({signer:$}),transfer:async(B)=>{let{transfer:U}=await import("near-api-js/lib/transaction"),M=B.assetValue.getBaseValue("string"),R=U(BigInt(M)),j={signerId:X,receiverId:B.recipient,actions:[R]};return await Q.request({method:"signAndSendTransaction",params:{transaction:j}})},createTransaction:async(B)=>{let{functionCall:U,transfer:M}=await import("near-api-js/lib/transaction");if(B.functionCall){let{methodName:W,args:K,attachedDeposit:N}=B.functionCall,k=U(W,K,BigInt("30000000000000"),BigInt(N||"0"));return{signerId:X,receiverId:B.recipient,actions:[k]}}let R=B.assetValue.getBaseValue("string"),j=M(BigInt(R));return{signerId:X,receiverId:B.recipient,actions:[j]}}}}default:return null}}export{m as ctrlWallet,n as CTRL_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=2E98026AA639FED464756E2164756E21
3
+ //# debugId=6F68F4EBEE258A0764756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/ctrl/index.ts", "../src/ctrl/walletHelpers.ts"],
4
4
  "sourcesContent": [
5
- "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n // Override transfer method to use CTRL's direct API\n const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n // Convert AssetValue to NEAR amount (yoctoNEAR)\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n\n // Create transfer action\n const action = transferAction(BigInt(amountInYocto));\n\n // Create transaction object for CTRL\n const transaction = {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n\n const txHash: string = await provider.request({\n method: \"signAndSendTransaction\",\n params: {\n transaction,\n },\n });\n\n return txHash;\n };\n\n // Override createTransaction to build NEAR transactions for CTRL\n const createTransaction = async (params: NearCreateTransactionParams) => {\n const { functionCall, transfer: transferAction } = await import(\n \"near-api-js/lib/transaction\"\n );\n\n if (params.functionCall) {\n // Function call transaction\n const { methodName, args, attachedDeposit } = params.functionCall;\n const action = functionCall(\n methodName,\n args,\n BigInt(\"30000000000000\"), // 30 TGas default\n BigInt(attachedDeposit || \"0\"),\n );\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n };\n\n return {\n ...toolbox,\n transfer,\n createTransaction,\n };\n }\n\n default:\n return null;\n }\n}\n",
6
- "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({\n method: \"connect\",\n });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
5
+ "import {\n Chain,\n ChainToChainId,\n type GenericTransferParams,\n SwapKitError,\n WalletOption,\n filterSupportedChains,\n} from \"@swapkit/helpers\";\nimport type { NearCreateTransactionParams } from \"@swapkit/toolboxes/near\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getCtrlAddress, getCtrlMethods, getCtrlProvider, walletTransfer } from \"./walletHelpers\";\n\nexport const ctrlWallet = createWallet({\n name: \"connectCtrl\",\n walletType: WalletOption.CTRL,\n supportedChains: [\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Near,\n Chain.Noble,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Solana,\n Chain.THORChain,\n ],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectCtrl(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains.map(async (chain) => {\n const address = await getCtrlAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n await Promise.all(promises);\n\n return true;\n },\n});\n\nexport const CTRL_SUPPORTED_CHAINS = getWalletSupportedChains(ctrlWallet);\n\nasync function getWalletMethods(chain: (typeof CTRL_SUPPORTED_CHAINS)[number]) {\n switch (chain) {\n case Chain.Solana: {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n\n const solanaProvider = window.xfi?.solana;\n\n if (!solanaProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n const toolbox = getSolanaToolbox({ signer: solanaProvider });\n\n return { ...toolbox };\n }\n\n case Chain.Maya:\n case Chain.THORChain: {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\n \"@swapkit/toolboxes/cosmos\"\n );\n\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain);\n\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"transfer\"),\n };\n }\n\n case Chain.Cosmos:\n case Chain.Kujira:\n case Chain.Noble: {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const chainId = ChainToChainId[chain];\n const provider = await getCtrlProvider(chain);\n\n await provider?.enable(chainId);\n const signer = provider?.getOfflineSignerOnlyAmino(chainId);\n\n if (!signer) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const toolbox = getCosmosToolbox(chain, { signer });\n\n return toolbox;\n }\n\n case Chain.Bitcoin:\n case Chain.BitcoinCash:\n case Chain.Dogecoin:\n case Chain.Litecoin: {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain);\n\n return { ...toolbox, transfer: walletTransfer };\n }\n\n case Chain.Arbitrum:\n case Chain.Aurora:\n case Chain.Avalanche:\n case Chain.Base:\n case Chain.Berachain:\n case Chain.BinanceSmartChain:\n case Chain.Ethereum:\n case Chain.Gnosis:\n case Chain.Optimism:\n case Chain.Polygon: {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getCtrlProvider(chain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_ctrl_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n const ctrlMethods = getCtrlMethods(provider, chain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n return prepareNetworkSwitch({\n provider: window.xfi?.ethereum,\n chain,\n toolbox: {\n ...toolbox,\n ...ctrlMethods,\n },\n });\n }\n\n case Chain.Near: {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n const { createNearSignerFromProvider } = await import(\"../helpers/near\");\n const { getNearToolbox } = await import(\"@swapkit/toolboxes/near\");\n\n const provider = window.xfi.near;\n const signer = await createNearSignerFromProvider(provider, \"CTRL\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n // Override transfer method to use CTRL's direct API\n const transfer = async (params: GenericTransferParams) => {\n const { transfer: transferAction } = await import(\"near-api-js/lib/transaction\");\n\n // Convert AssetValue to NEAR amount (yoctoNEAR)\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n\n // Create transfer action\n const action = transferAction(BigInt(amountInYocto));\n\n // Create transaction object for CTRL\n const transaction = {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n\n const txHash: string = await provider.request({\n method: \"signAndSendTransaction\",\n params: {\n transaction,\n },\n });\n\n return txHash;\n };\n\n // Override createTransaction to build NEAR transactions for CTRL\n const createTransaction = async (params: NearCreateTransactionParams) => {\n const { functionCall, transfer: transferAction } = await import(\n \"near-api-js/lib/transaction\"\n );\n\n if (params.functionCall) {\n // Function call transaction\n const { methodName, args, attachedDeposit } = params.functionCall;\n const action = functionCall(\n methodName,\n args,\n BigInt(\"30000000000000\"), // 30 TGas default\n BigInt(attachedDeposit || \"0\"),\n );\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n }\n\n // Simple transfer transaction\n const amountInYocto = params.assetValue.getBaseValue(\"string\");\n const action = transferAction(BigInt(amountInYocto));\n\n return {\n signerId: accountId,\n receiverId: params.recipient,\n actions: [action],\n };\n };\n\n return {\n ...toolbox,\n transfer,\n createTransaction,\n };\n }\n\n default:\n return null;\n }\n}\n",
6
+ "import type { Keplr } from \"@keplr-wallet/types\";\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n SwapKitError,\n WalletOption,\n providerRequest,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\n\ntype TransactionMethod = \"transfer\" | \"deposit\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n recipient: string;\n memo?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\nexport async function getCtrlProvider<T extends Chain>(\n chain: T,\n): Promise<\n T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira | Chain.Noble\n ? Keplr\n : T extends EVMChain\n ? Eip1193Provider\n : undefined\n> {\n if (!window.xfi) throw new SwapKitError(\"wallet_ctrl_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n // @ts-expect-error\n return match(chain as Chain)\n .with(\n Chain.Arbitrum,\n Chain.Aurora,\n Chain.Avalanche,\n Chain.Base,\n Chain.Berachain,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Optimism,\n Chain.Polygon,\n () => window.xfi?.ethereum,\n )\n .with(Chain.Cosmos, Chain.Kujira, Chain.Noble, () => window.xfi?.keplr)\n .with(Chain.Bitcoin, () => window.xfi?.bitcoin)\n .with(Chain.BitcoinCash, () => window.xfi?.bitcoincash)\n .with(Chain.Dogecoin, () => window.xfi?.dogecoin)\n .with(Chain.Litecoin, () => window.xfi?.litecoin)\n .with(Chain.Solana, () => window.xfi?.solana)\n .with(Chain.THORChain, () => window.xfi?.thorchain)\n .with(Chain.Maya, () => window.xfi?.mayachain)\n .otherwise(() => undefined);\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getCtrlProvider(chain);\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-ignore\n client.request({ method, params }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\n// biome-ignore lint/complexity/noExcessiveCognitiveComplexity: <explanation>\nexport async function getCtrlAddress(chain: Chain) {\n try {\n const eipProvider = (await getCtrlProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n if ([Chain.Cosmos, Chain.Kujira, Chain.Noble].includes(chain)) {\n const provider = await getCtrlProvider(Chain.Cosmos);\n if (!provider || \"request\" in provider) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n\n // Enabling before using the Keplr is recommended.\n // This method will ask the user whether to allow access if they haven't visited this website.\n // Also, it will request that the user unlock the wallet if the wallet is locked.\n const chainId = ChainToChainId[chain];\n await provider.enable(chainId);\n\n const offlineSigner = provider.getOfflineSigner(chainId);\n\n const [item] = await offlineSigner.getAccounts();\n return item?.address;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n // For CTRL wallet, we need to use the request method directly on the provider\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({\n provider,\n method: \"eth_requestAccounts\",\n params: [],\n });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getCtrlProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n if (chain === Chain.Near) {\n if (!window.xfi?.near) {\n throw new SwapKitError(\"wallet_ctrl_not_found\", { chain: Chain.Near });\n }\n\n if (!window.xfi.near.isSignedIn?.()) {\n const result = await window.xfi.near.request<string[]>?.({\n method: \"connect\",\n });\n return result?.[0] || \"\";\n }\n\n return window.xfi.near.getAccountId?.() || \"\";\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_provider_not_found\",\n info: { wallet: WalletOption.CTRL, chain },\n });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"transfer\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_ctrl_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getCtrlAddress(assetValue.chain);\n const params = [\n {\n amount: {\n amount: assetValue.getBaseValue(\"number\"),\n decimals: assetValue.decimal,\n },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n memo: memo || \"\",\n from,\n recipient,\n gasLimit,\n },\n ];\n\n return transaction({ method, params, chain: assetValue.chain });\n}\n\nexport function getCtrlMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n call: async <T>({\n contractAddress,\n abi,\n funcName,\n funcParams = [],\n txOverrides,\n }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_ctrl_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\n \"@swapkit/toolboxes/evm\"\n );\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, from, to, data } = await createTx({\n contractAddress,\n abi,\n funcName,\n funcParams,\n txOverrides,\n });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n contractAddress: assetAddress,\n abi: erc20ABI,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ provider, chain });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_ctrl_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({\n value: BigInt(value || 0),\n from,\n to,\n data: data || \"0x\",\n });\n return tx.hash;\n },\n };\n}\n"
7
7
  ],
8
- "mappings": "mDAAA,gBACE,oBACA,kBAEA,kBACA,2BACA,yBAGF,uBAAS,8BAAc,6BCRvB,gBAEE,oBACA,eAEA,kBAEA,kBACA,qBACA,yBAEF,mBAAS,mCAwBT,eAAsB,CAAgC,CACpD,EASA,CACA,IAAK,OAAO,IAAK,MAAM,IAAI,EAAa,uBAAuB,EAC/D,IAAQ,SAAU,KAAa,sBAG/B,OAAO,EAAM,CAAc,EACxB,KACC,EAAM,SACN,EAAM,OACN,EAAM,UACN,EAAM,KACN,EAAM,UACN,EAAM,kBACN,EAAM,SACN,EAAM,OACN,EAAM,SACN,EAAM,QACN,IAAM,OAAO,KAAK,QACpB,EACC,KAAK,EAAM,OAAQ,EAAM,OAAQ,IAAM,OAAO,KAAK,KAAK,EACxD,KAAK,EAAM,QAAS,IAAM,OAAO,KAAK,OAAO,EAC7C,KAAK,EAAM,YAAa,IAAM,OAAO,KAAK,WAAW,EACrD,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,SAAU,IAAM,OAAO,KAAK,QAAQ,EAC/C,KAAK,EAAM,OAAQ,IAAM,OAAO,KAAK,MAAM,EAC3C,KAAK,EAAM,UAAW,IAAM,OAAO,KAAK,SAAS,EACjD,KAAK,EAAM,KAAM,IAAM,OAAO,KAAK,SAAS,EAC5C,UAAU,IAAG,CAAG,OAAS,EAG9B,eAAe,CAAW,EACxB,SACA,SACA,SAKkB,CAClB,IAAM,EAAS,MAAM,EAAgB,CAAK,EAE1C,OAAO,IAAI,QAAgB,CAAC,EAAS,IAAW,CAC9C,GAAI,GAAU,YAAa,EAEzB,EAAO,QAAQ,CAAE,SAAQ,QAAO,EAAG,CAAC,EAAa,IAAe,CAC9D,EAAM,EAAO,CAAG,EAAI,EAAQ,CAAE,EAC/B,EAEJ,EAIH,eAAsB,CAAc,CAAC,EAAc,CACjD,GAAI,CACF,IAAM,EAAe,MAAM,EAAgB,CAAK,EAChD,IAAK,EACH,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAGH,GAAI,CAAC,EAAM,OAAQ,EAAM,MAAM,EAAE,SAAS,CAAK,EAAG,CAChD,IAAM,EAAW,MAAM,EAAgB,EAAM,MAAM,EACnD,IAAK,GAAY,YAAa,EAC5B,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAMH,IAAM,EAAU,EAAe,GAC/B,MAAM,EAAS,OAAO,CAAO,EAE7B,IAAM,EAAgB,EAAS,iBAAiB,CAAO,GAEhD,GAAQ,MAAM,EAAc,YAAY,EAC/C,OAAO,GAAM,QAGf,GAAI,EAAU,SAAS,CAAiB,EAAG,CAEzC,GAAI,YAAa,GAAe,OAAO,EAAY,UAAY,WAE7D,OADiB,MAAM,EAAY,QAAQ,CAAE,OAAQ,qBAAsB,CAAC,GAC5D,GAElB,IAAQ,mBAAoB,KAAa,kBACnC,EAAW,IAAI,EAAgB,EAAa,KAAK,GAChD,GAAY,MAAM,EAAgB,CACvC,WACA,OAAQ,sBACR,OAAQ,CAAC,CACX,CAAC,EACD,OAAO,EAGT,GAAI,IAAU,EAAM,OAIlB,OADiB,MAFA,MAAM,EAAgB,EAAM,MAAM,GAEnB,QAAQ,GACxB,UAAU,SAAS,EAGrC,GAAI,IAAU,EAAM,KAAM,CACxB,IAAK,OAAO,KAAK,KACf,MAAM,IAAI,EAAa,wBAAyB,CAAE,MAAO,EAAM,IAAK,CAAC,EAGvE,IAAK,OAAO,IAAI,KAAK,aAAa,EAIhC,OAHe,MAAM,OAAO,IAAI,KAAK,UAAoB,CACvD,OAAQ,SACV,CAAC,KACe,IAAM,GAGxB,OAAO,OAAO,IAAI,KAAK,eAAe,GAAK,GAI7C,OADiB,MAAM,EAAY,QAAQ,CAAE,OAAQ,mBAAoB,OAAQ,CAAC,CAAE,CAAC,GACrE,GAChB,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,CACrB,SAAU,4BACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,GAIL,eAAsB,CAAc,EAChC,aAAY,YAAW,OAAM,YAC/B,EAA4B,WAC5B,CACA,IAAK,EACH,MAAM,IAAI,EAAa,+BAA+B,EAQxD,IAAM,EAAO,MAAM,EAAe,EAAW,KAAK,EAC5C,EAAS,CACb,CACE,OAAQ,CACN,OAAQ,EAAW,aAAa,QAAQ,EACxC,SAAU,EAAW,OACvB,EACA,MAAO,CACL,MAAO,EAAW,MAClB,OAAQ,EAAW,OAAO,YAAY,EACtC,OAAQ,EAAW,OAAO,YAAY,CACxC,EACA,KAAM,GAAQ,GACd,OACA,YACA,UACF,CACF,EAEA,OAAO,EAAY,CAAE,SAAQ,SAAQ,MAAO,EAAW,KAAM,CAAC,EAGzD,SAAS,CAAc,CAAC,EAA2B,EAAiB,CACzE,MAAO,CACL,KAAM,OACJ,kBACA,MACA,WACA,aAAa,CAAC,EACd,iBAC4B,CAC5B,IAAK,EACH,MAAM,IAAI,EAAa,2CAA2C,EAEpE,IAAQ,iBAAgB,4BAA2B,uBAAwB,KACzE,kCAKF,GAFwB,EAAoB,CAAE,MAAK,UAAS,CAAC,EAExC,CACnB,IAAM,EAAW,EAA0B,CAAE,WAAU,OAAM,CAAC,GACtD,QAAO,OAAM,KAAI,QAAS,MAAM,EAAS,CAC/C,kBACA,MACA,WACA,aACA,aACF,CAAC,EASD,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,KAIZ,IAAM,EAAS,MAFE,EAAe,EAAiB,EAAK,CAAQ,EAEhC,KAAY,GAAG,CAAU,EAEvD,OAAO,OAAO,GAAQ,OAAS,SAAW,GAAQ,KAAO,GAE3D,QAAS,OAAS,eAAc,iBAAgB,SAAQ,UAA0B,CAChF,IAAQ,eAAc,6BAA8B,KAAa,kCAC3D,EAAa,CAAC,EAAgB,OAAO,GAAU,CAAY,CAAC,EAG5D,EAAqB,CACzB,gBAAiB,EACjB,IAAK,EACL,SAAU,UACV,aACA,YAPkB,CAAE,MAAK,CAQ3B,EAEM,EAAW,EAA0B,CAAE,WAAU,OAAM,CAAC,GACtD,QAAO,KAAI,QAAS,MAAM,EAAS,CAAkB,EAS7D,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,MAEZ,gBAAiB,MAAO,IAA0B,CAChD,IAAQ,OAAM,KAAI,OAAM,SAAU,EAClC,IAAK,EACH,MAAM,IAAI,EAAa,yCAAyC,EAUlE,OANW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CACtC,MAAO,OAAO,GAAS,CAAC,EACxB,OACA,KACA,KAAM,GAAQ,IAChB,CAAC,GACS,KAEd,ED1RK,IAAM,EAAa,EAAa,CACrC,KAAM,cACN,WAAY,EAAa,KACzB,gBAAiB,CACf,EAAM,SACN,EAAM,OACN,EAAM,UACN,EAAM,KACN,EAAM,UACN,EAAM,kBACN,EAAM,QACN,EAAM,YACN,EAAM,OACN,EAAM,SACN,EAAM,SACN,EAAM,OACN,EAAM,OACN,EAAM,SACN,EAAM,KACN,EAAM,KACN,EAAM,SACN,EAAM,QACN,EAAM,OACN,EAAM,SACR,EACA,QAAS,EAAG,WAAU,aAAY,qBAChC,eAAe,CAAW,CAAC,EAAiB,CAG1C,IAAM,EAFiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAEpD,IAAI,MAAO,IAAU,CACnD,IAAM,EAAU,MAAM,EAAe,CAAK,EACpC,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,EAID,OAFA,MAAM,QAAQ,IAAI,CAAQ,EAEnB,GAEb,CAAC,EAEY,EAAwB,EAAyB,CAAU,EAExE,eAAe,CAAgB,CAAC,EAA+C,CAC7E,OAAQ,QACD,EAAM,OAAQ,CACjB,IAAQ,oBAAqB,KAAa,qCAEpC,EAAiB,OAAO,KAAK,OAEnC,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAIhD,MAAO,IAFS,EAAiB,CAAE,OAAQ,CAAe,CAAC,CAEvC,CACtB,MAEK,EAAM,UACN,EAAM,UAAW,CACpB,IAAQ,mBAAkB,sBAAqB,kBAAmB,KAChE,qCAGI,EAAW,IAAU,EAAM,KAAO,EAAiB,EAGzD,MAAO,IAFS,MAAM,EAAiB,CAAK,EAI1C,QAAS,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAW,EAAG,EAAG,SAAS,EAC1F,SAAU,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAS,EAAG,UAAU,CACzF,CACF,MAEK,EAAM,YACN,EAAM,OAAQ,CACjB,IAAQ,oBAAqB,KAAa,qCACpC,EAAU,EAAe,GACzB,EAAW,MAAM,EAAgB,CAAK,EAE5C,MAAM,GAAU,OAAO,CAAO,EAC9B,IAAM,EAAS,GAAU,0BAA0B,CAAO,EAE1D,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAKhD,OAFgB,EAAiB,EAAO,CAAE,QAAO,CAAC,CAGpD,MAEK,EAAM,aACN,EAAM,iBACN,EAAM,cACN,EAAM,SAAU,CACnB,IAAQ,kBAAmB,KAAa,mCAGxC,MAAO,IAFS,MAAM,EAAe,CAAK,EAErB,SAAU,CAAe,CAChD,MAEK,EAAM,cACN,EAAM,YACN,EAAM,eACN,EAAM,UACN,EAAM,eACN,EAAM,uBACN,EAAM,cACN,EAAM,YACN,EAAM,cACN,EAAM,QAAS,CAClB,IAAQ,uBAAsB,0BAA2B,KAAa,6BAC9D,iBAAkB,KAAa,mCAC/B,mBAAoB,KAAa,kBACnC,EAAyB,MAAM,EAAgB,CAAK,EAE1D,IAAK,EACH,MAAM,IAAI,EAAa,uBAAuB,EAGhD,IAAM,EAAW,IAAI,EAAgB,EAAwB,KAAK,EAC5D,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EACzD,EAAc,EAAe,EAAU,CAAK,EAElD,GAAI,CACF,GAAI,IAAU,EAAM,SAAU,CAC5B,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,GAE7D,MAAO,EAAQ,CACf,MAAM,IAAI,EAAa,CACrB,SAAU,yCACV,KAAM,CAAE,OAAQ,EAAa,KAAM,OAAM,CAC3C,CAAC,EAGH,OAAO,EAAqB,CAC1B,SAAU,OAAO,KAAK,SACtB,QACA,QAAS,IACJ,KACA,CACL,CACF,CAAC,CACH,MAEK,EAAM,KAAM,CACf,IAAK,OAAO,KAAK,KACf,MAAM,IAAI,EAAa,wBAAyB,CAAE,MAAO,EAAM,IAAK,CAAC,EAGvE,IAAQ,gCAAiC,KAAa,oCAC9C,kBAAmB,KAAa,mCAElC,EAAW,OAAO,IAAI,KACtB,EAAS,MAAM,EAA6B,EAAU,MAAM,EAC5D,EAAY,MAAM,EAAO,WAAW,EAgE1C,MAAO,IA/DS,MAAM,EAAe,CAAE,QAAO,CAAC,EAiE7C,SA9De,MAAO,IAAkC,CACxD,IAAQ,SAAU,GAAmB,KAAa,uCAG5C,EAAgB,EAAO,WAAW,aAAa,QAAQ,EAGvD,EAAS,EAAe,OAAO,CAAa,CAAC,EAG7C,EAAc,CAClB,SAAU,EACV,WAAY,EAAO,UACnB,QAAS,CAAC,CAAM,CAClB,EASA,OAPuB,MAAM,EAAS,QAAQ,CAC5C,OAAQ,yBACR,OAAQ,CACN,aACF,CACF,CAAC,GA0CD,kBApCwB,MAAO,IAAwC,CACvE,IAAQ,eAAc,SAAU,GAAmB,KACjD,uCAGF,GAAI,EAAO,aAAc,CAEvB,IAAQ,aAAY,OAAM,mBAAoB,EAAO,aAC/C,EAAS,EACb,EACA,EACA,OAAO,gBAAgB,EACvB,OAAO,GAAmB,GAAG,CAC/B,EAEA,MAAO,CACL,SAAU,EACV,WAAY,EAAO,UACnB,QAAS,CAAC,CAAM,CAClB,EAIF,IAAM,EAAgB,EAAO,WAAW,aAAa,QAAQ,EACvD,EAAS,EAAe,OAAO,CAAa,CAAC,EAEnD,MAAO,CACL,SAAU,EACV,WAAY,EAAO,UACnB,QAAS,CAAC,CAAM,CAClB,EAOF,CACF,SAGE,OAAO",
9
- "debugId": "2E98026AA639FED464756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "6F68F4EBEE258A0764756E2164756E21",
10
10
  "names": []
11
11
  }