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

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.
@@ -1,4 +1,4 @@
1
- var Y={};V(Y,{bitgetWallet:()=>J,BITGET_SUPPORTED_CHAINS:()=>X});module.exports=U(Y);var f=require("@swapkit/helpers"),M=require("@swapkit/wallet-core");var m=require("@swapkit/helpers"),z=require("bitcoinjs-lib");async function F(u){let{match:D,P:I}=await import("ts-pattern"),B=window.bitkeep;return D(u).with(I.union(m.Chain.Arbitrum,m.Chain.Aurora,m.Chain.Avalanche,m.Chain.Base,m.Chain.Berachain,m.Chain.BinanceSmartChain,m.Chain.Ethereum,m.Chain.Gnosis,m.Chain.Optimism,m.Chain.Polygon),async()=>{if(!(B&&("ethereum"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let y=B.ethereum,[G]=await y.send("eth_requestAccounts",[]);return{...await Q({chain:u,walletProvider:y}),address:G}}).with(m.Chain.Bitcoin,async()=>{if(!(B&&("unisat"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{unisat:y}=B,{getUtxoToolbox:G}=await import("@swapkit/toolboxes/utxo"),[A]=await y.requestAccounts();async function O(W){let q=await y.signPsbt(W.toHex(),{autoFinalized:!1});return z.Psbt.fromHex(q)}let _={getAddress:()=>Promise.resolve(A),signTransaction:O};return{...await G(m.Chain.Bitcoin,{signer:_}),address:A}}).with(m.Chain.Cosmos,async()=>{if(!(B&&("keplr"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{keplr:y}=B;await y.enable(m.ChainId.Cosmos);let G=y.getOfflineSignerOnlyAmino(m.ChainId.Cosmos),A=await G.getAccounts();if(!A?.[0])throw new m.SwapKitError("wallet_bitkeep_no_accounts",{chain:m.Chain.Cosmos});let{getCosmosToolbox:O}=await import("@swapkit/toolboxes/cosmos"),[{address:_}]=A,R={...G,getAddress:()=>Promise.resolve(_),signTransaction:async()=>Promise.resolve({})};return{...O(m.Chain.Cosmos,{signer:R}),address:_}}).with(m.Chain.Solana,async()=>{if(!(B&&("solana"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{getSolanaToolbox:y}=await import("@swapkit/toolboxes/solana"),G=B?.solana,A=y({signer:G}),_=(await G.connect()).publicKey.toString();return{...A,address:_}}).with(m.Chain.Tron,async()=>{if(!(B&&("tronLink"in B)&&("tronWeb"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{createTronToolbox:y}=await import("@swapkit/toolboxes/tron"),{tronLink:G,tronWeb:A}=B,O=await G.request({method:"tron_requestAccounts"});if(!O?.base58)throw new m.SwapKitError("wallet_bitkeep_no_accounts",{chain:m.Chain.Tron});let _=O.base58;return{...await y({signer:{getAddress:()=>Promise.resolve(_),signTransaction:async(q)=>{return await A.trx.sign(q)}}}),address:_}}).otherwise(()=>{throw new m.SwapKitError("wallet_chain_not_supported")})}var Q=async({chain:u,walletProvider:D})=>{let{getEvmToolbox:I}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:B}=await import("ethers");if(!D)throw new m.SwapKitError("wallet_provider_not_found");let y=new B(D,"any"),G=await y.getSigner(),A=await I(u,{provider:y,signer:G});try{if(u!==m.Chain.Ethereum&&"getNetworkParams"in A)await m.switchEVMWalletNetwork(y,u,A.getNetworkParams())}catch(O){throw new m.SwapKitError("wallet_bitkeep_failed_to_switch_network",{chain:u})}return m.prepareNetworkSwitch({chain:u,toolbox:A,provider:y})};var J=M.createWallet({name:"connectBitget",walletType:f.WalletOption.BITGET,supportedChains:[...f.EVMChains,f.Chain.Cosmos,f.Chain.Bitcoin,f.Chain.Solana,f.Chain.Tron],connect:({addChain:u,walletType:D,supportedChains:I})=>async function B(y){let G=f.filterSupportedChains({chains:y,supportedChains:I,walletType:D});return await Promise.all(G.map(async(A)=>{let O=await F(A),_=await O.getAddress()||"";u({...O,address:_,chain:A,walletType:D})})),!0}}),X=M.getWalletSupportedChains(J);
1
+ var Y={};W(Y,{bitgetWallet:()=>Q,BITGET_SUPPORTED_CHAINS:()=>X});module.exports=V(Y);var _=require("@swapkit/helpers"),R=require("@swapkit/wallet-core");var m=require("@swapkit/helpers"),F=require("bitcoinjs-lib");async function J(f){let{match:D,P:I}=await import("ts-pattern"),B=window.bitkeep;return D(f).with(I.union(m.Chain.Arbitrum,m.Chain.Aurora,m.Chain.Avalanche,m.Chain.Base,m.Chain.Berachain,m.Chain.BinanceSmartChain,m.Chain.Ethereum,m.Chain.Gnosis,m.Chain.Optimism,m.Chain.Polygon),async()=>{if(!(B&&("ethereum"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let u=B.ethereum,[G]=await u.send("eth_requestAccounts",[]);return{...await U({chain:f,walletProvider:u}),address:G}}).with(m.Chain.Bitcoin,async()=>{if(!(B&&("unisat"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{unisat:u}=B,{getUtxoToolbox:G}=await import("@swapkit/toolboxes/utxo"),[y]=await u.requestAccounts();async function O(q){let z=await u.signPsbt(q.toHex(),{autoFinalized:!1});return F.Psbt.fromHex(z)}let A={getAddress:()=>Promise.resolve(y),signTransaction:O};return{...await G(m.Chain.Bitcoin,{signer:A}),address:y}}).with(m.Chain.Cosmos,async()=>{if(!(B&&("keplr"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{keplr:u}=B;await u.enable(m.ChainId.Cosmos);let G=u.getOfflineSignerOnlyAmino(m.ChainId.Cosmos),y=await G.getAccounts();if(!y?.[0])throw new m.SwapKitError("wallet_bitkeep_no_accounts",{chain:m.Chain.Cosmos});let{getCosmosToolbox:O}=await import("@swapkit/toolboxes/cosmos"),[{address:A}]=y,M={...G,getAddress:()=>Promise.resolve(A),signTransaction:async()=>Promise.resolve({})};return{...await O(m.Chain.Cosmos,{signer:M}),address:A}}).with(m.Chain.Solana,async()=>{if(!(B&&("solana"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{getSolanaToolbox:u}=await import("@swapkit/toolboxes/solana"),G=B?.solana,y=await G.connect(),O=y.publicKey.toString(),A={...G,publicKey:y.publicKey,getAddress:async()=>O};return{...await u({signer:A}),address:O}}).with(m.Chain.Tron,async()=>{if(!(B&&("tronLink"in B)&&("tronWeb"in B)))throw new m.SwapKitError("wallet_bitkeep_not_found");let{createTronToolbox:u}=await import("@swapkit/toolboxes/tron"),{tronLink:G,tronWeb:y}=B,O=await G.request({method:"tron_requestAccounts"});if(O.code!==200)throw new m.SwapKitError("wallet_connection_rejected_by_user",{message:O.message||"User rejected connection"});let A=y.defaultAddress?.base58;if(!A)throw new m.SwapKitError("wallet_bitkeep_no_accounts",{chain:m.Chain.Tron});return{...await u({signer:{getAddress:()=>Promise.resolve(A),signTransaction:async(z)=>{return await y.trx.sign(z)}}}),address:A}}).otherwise(()=>{throw new m.SwapKitError("wallet_chain_not_supported")})}var U=async({chain:f,walletProvider:D})=>{let{getEvmToolbox:I}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:B}=await import("ethers");if(!D)throw new m.SwapKitError("wallet_provider_not_found");let u=new B(D,"any"),G=await u.getSigner(),y=await I(f,{provider:u,signer:G});try{if(f!==m.Chain.Ethereum&&"getNetworkParams"in y)await m.switchEVMWalletNetwork(u,f,y.getNetworkParams())}catch(O){throw new m.SwapKitError("wallet_bitkeep_failed_to_switch_network",{chain:f})}return m.prepareNetworkSwitch({chain:f,toolbox:y,provider:u})};var Q=R.createWallet({name:"connectBitget",walletType:_.WalletOption.BITGET,supportedChains:[..._.EVMChains,_.Chain.Cosmos,_.Chain.Bitcoin,_.Chain.Solana,_.Chain.Tron],connect:({addChain:f,walletType:D,supportedChains:I})=>async function B(u){let G=_.filterSupportedChains({chains:u,supportedChains:I,walletType:D});return await Promise.all(G.map(async(y)=>{let O=await J(y);f({...O,chain:y,walletType:D})})),!0}}),X=R.getWalletSupportedChains(Q);
2
2
 
3
- //# debugId=ECD3C51C938261E264756E2164756E21
3
+ //# debugId=1B995311F7ED2D4364756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, EVMChains, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
- "import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: wallet,\n });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0])\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const toolbox = getSolanaToolbox({ signer: provider });\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const account = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!account?.base58) {\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = account.base58;\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
5
+ "import { Chain, EVMChains, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
+ "import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: wallet,\n });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0])\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = await getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n // Connect to get the public key\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n // Create a proper signer object that wraps the provider\n const signer = {\n ...provider,\n publicKey: providerConnection.publicKey,\n getAddress: async () => address,\n };\n\n const toolbox = await getSolanaToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check if the request was successful\n if (response.code !== 200) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: response.message || \"User rejected connection\",\n });\n }\n\n // After successful approval, the address should be available in tronWeb.defaultAddress\n const address = tronWeb.defaultAddress?.base58;\n\n if (!address) {\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "ECD3C51C938261E264756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "1B995311F7ED2D4364756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- import{F as H,G as I}from"../../chunk-yqaz2d25.js";import{Chain as R,EVMChains as Y,WalletOption as Z,filterSupportedChains as $}from"@swapkit/helpers";import{createWallet as j,getWalletSupportedChains as L}from"@swapkit/wallet-core";import{Chain as y,ChainId as F,SwapKitError as u,prepareNetworkSwitch as Q,switchEVMWalletNetwork as U}from"@swapkit/helpers";import{Psbt as V}from"bitcoinjs-lib";async function J(f){let{match:D,P:M}=await import("ts-pattern"),m=window.bitkeep;return D(f).with(M.union(y.Arbitrum,y.Aurora,y.Avalanche,y.Base,y.Berachain,y.BinanceSmartChain,y.Ethereum,y.Gnosis,y.Optimism,y.Polygon),async()=>{if(!(m&&("ethereum"in m)))throw new u("wallet_bitkeep_not_found");let B=m.ethereum,[G]=await B.send("eth_requestAccounts",[]);return{...await X({chain:f,walletProvider:B}),address:G}}).with(y.Bitcoin,async()=>{if(!(m&&("unisat"in m)))throw new u("wallet_bitkeep_not_found");let{unisat:B}=m,{getUtxoToolbox:G}=await import("@swapkit/toolboxes/utxo"),[A]=await B.requestAccounts();async function O(q){let z=await B.signPsbt(q.toHex(),{autoFinalized:!1});return V.fromHex(z)}let _={getAddress:()=>Promise.resolve(A),signTransaction:O};return{...await G(y.Bitcoin,{signer:_}),address:A}}).with(y.Cosmos,async()=>{if(!(m&&("keplr"in m)))throw new u("wallet_bitkeep_not_found");let{keplr:B}=m;await B.enable(F.Cosmos);let G=B.getOfflineSignerOnlyAmino(F.Cosmos),A=await G.getAccounts();if(!A?.[0])throw new u("wallet_bitkeep_no_accounts",{chain:y.Cosmos});let{getCosmosToolbox:O}=await import("@swapkit/toolboxes/cosmos"),[{address:_}]=A,W={...G,getAddress:()=>Promise.resolve(_),signTransaction:async()=>Promise.resolve({})};return{...O(y.Cosmos,{signer:W}),address:_}}).with(y.Solana,async()=>{if(!(m&&("solana"in m)))throw new u("wallet_bitkeep_not_found");let{getSolanaToolbox:B}=await import("@swapkit/toolboxes/solana"),G=m?.solana,A=B({signer:G}),_=(await G.connect()).publicKey.toString();return{...A,address:_}}).with(y.Tron,async()=>{if(!(m&&("tronLink"in m)&&("tronWeb"in m)))throw new u("wallet_bitkeep_not_found");let{createTronToolbox:B}=await import("@swapkit/toolboxes/tron"),{tronLink:G,tronWeb:A}=m,O=await G.request({method:"tron_requestAccounts"});if(!O?.base58)throw new u("wallet_bitkeep_no_accounts",{chain:y.Tron});let _=O.base58;return{...await B({signer:{getAddress:()=>Promise.resolve(_),signTransaction:async(z)=>{return await A.trx.sign(z)}}}),address:_}}).otherwise(()=>{throw new u("wallet_chain_not_supported")})}var X=async({chain:f,walletProvider:D})=>{let{getEvmToolbox:M}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:m}=await import("ethers");if(!D)throw new u("wallet_provider_not_found");let B=new m(D,"any"),G=await B.getSigner(),A=await M(f,{provider:B,signer:G});try{if(f!==y.Ethereum&&"getNetworkParams"in A)await U(B,f,A.getNetworkParams())}catch(O){throw new u("wallet_bitkeep_failed_to_switch_network",{chain:f})}return Q({chain:f,toolbox:A,provider:B})};var N=j({name:"connectBitget",walletType:Z.BITGET,supportedChains:[...Y,R.Cosmos,R.Bitcoin,R.Solana,R.Tron],connect:({addChain:f,walletType:D,supportedChains:M})=>async function m(B){let G=$({chains:B,supportedChains:M,walletType:D});return await Promise.all(G.map(async(A)=>{let O=await J(A),_=await O.getAddress()||"";f({...O,address:_,chain:A,walletType:D})})),!0}}),x=L(N);export{N as bitgetWallet,x as BITGET_SUPPORTED_CHAINS};
1
+ import{F as H,G as I}from"../../chunk-yqaz2d25.js";import{Chain as q,EVMChains as Y,WalletOption as Z,filterSupportedChains as $}from"@swapkit/helpers";import{createWallet as j,getWalletSupportedChains as L}from"@swapkit/wallet-core";import{Chain as y,ChainId as J,SwapKitError as _,prepareNetworkSwitch as U,switchEVMWalletNetwork as V}from"@swapkit/helpers";import{Psbt as W}from"bitcoinjs-lib";async function Q(f){let{match:D,P:M}=await import("ts-pattern"),m=window.bitkeep;return D(f).with(M.union(y.Arbitrum,y.Aurora,y.Avalanche,y.Base,y.Berachain,y.BinanceSmartChain,y.Ethereum,y.Gnosis,y.Optimism,y.Polygon),async()=>{if(!(m&&("ethereum"in m)))throw new _("wallet_bitkeep_not_found");let B=m.ethereum,[G]=await B.send("eth_requestAccounts",[]);return{...await X({chain:f,walletProvider:B}),address:G}}).with(y.Bitcoin,async()=>{if(!(m&&("unisat"in m)))throw new _("wallet_bitkeep_not_found");let{unisat:B}=m,{getUtxoToolbox:G}=await import("@swapkit/toolboxes/utxo"),[u]=await B.requestAccounts();async function O(z){let F=await B.signPsbt(z.toHex(),{autoFinalized:!1});return W.fromHex(F)}let A={getAddress:()=>Promise.resolve(u),signTransaction:O};return{...await G(y.Bitcoin,{signer:A}),address:u}}).with(y.Cosmos,async()=>{if(!(m&&("keplr"in m)))throw new _("wallet_bitkeep_not_found");let{keplr:B}=m;await B.enable(J.Cosmos);let G=B.getOfflineSignerOnlyAmino(J.Cosmos),u=await G.getAccounts();if(!u?.[0])throw new _("wallet_bitkeep_no_accounts",{chain:y.Cosmos});let{getCosmosToolbox:O}=await import("@swapkit/toolboxes/cosmos"),[{address:A}]=u,R={...G,getAddress:()=>Promise.resolve(A),signTransaction:async()=>Promise.resolve({})};return{...await O(y.Cosmos,{signer:R}),address:A}}).with(y.Solana,async()=>{if(!(m&&("solana"in m)))throw new _("wallet_bitkeep_not_found");let{getSolanaToolbox:B}=await import("@swapkit/toolboxes/solana"),G=m?.solana,u=await G.connect(),O=u.publicKey.toString(),A={...G,publicKey:u.publicKey,getAddress:async()=>O};return{...await B({signer:A}),address:O}}).with(y.Tron,async()=>{if(!(m&&("tronLink"in m)&&("tronWeb"in m)))throw new _("wallet_bitkeep_not_found");let{createTronToolbox:B}=await import("@swapkit/toolboxes/tron"),{tronLink:G,tronWeb:u}=m,O=await G.request({method:"tron_requestAccounts"});if(O.code!==200)throw new _("wallet_connection_rejected_by_user",{message:O.message||"User rejected connection"});let A=u.defaultAddress?.base58;if(!A)throw new _("wallet_bitkeep_no_accounts",{chain:y.Tron});return{...await B({signer:{getAddress:()=>Promise.resolve(A),signTransaction:async(F)=>{return await u.trx.sign(F)}}}),address:A}}).otherwise(()=>{throw new _("wallet_chain_not_supported")})}var X=async({chain:f,walletProvider:D})=>{let{getEvmToolbox:M}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:m}=await import("ethers");if(!D)throw new _("wallet_provider_not_found");let B=new m(D,"any"),G=await B.getSigner(),u=await M(f,{provider:B,signer:G});try{if(f!==y.Ethereum&&"getNetworkParams"in u)await V(B,f,u.getNetworkParams())}catch(O){throw new _("wallet_bitkeep_failed_to_switch_network",{chain:f})}return U({chain:f,toolbox:u,provider:B})};var N=j({name:"connectBitget",walletType:Z.BITGET,supportedChains:[...Y,q.Cosmos,q.Bitcoin,q.Solana,q.Tron],connect:({addChain:f,walletType:D,supportedChains:M})=>async function m(B){let G=$({chains:B,supportedChains:M,walletType:D});return await Promise.all(G.map(async(u)=>{let O=await Q(u);f({...O,chain:u,walletType:D})})),!0}}),v=L(N);export{N as bitgetWallet,v as BITGET_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=B596B3BF2A22DA5164756E2164756E21
3
+ //# debugId=B9CB4D4628AD563964756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/bitget/index.ts", "../src/bitget/helpers.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, EVMChains, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
- "import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: wallet,\n });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0])\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n const toolbox = getSolanaToolbox({ signer: provider });\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const account = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!account?.base58) {\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = account.base58;\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
5
+ "import { Chain, EVMChains, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\n\nimport { getWalletMethods } from \"./helpers\";\n\nexport const bitgetWallet = createWallet({\n name: \"connectBitget\",\n walletType: WalletOption.BITGET,\n supportedChains: [...EVMChains, Chain.Cosmos, Chain.Bitcoin, Chain.Solana, Chain.Tron],\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectBitget(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const BITGET_SUPPORTED_CHAINS = getWalletSupportedChains(bitgetWallet);\n",
6
+ "import {\n Chain,\n ChainId,\n type EVMChain,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n const bitget = window.bitkeep;\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(bitget && \"ethereum\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const wallet = bitget.ethereum;\n\n const [address]: [string] = await wallet.send(\"eth_requestAccounts\", []);\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: wallet,\n });\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(bitget && \"unisat\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { unisat: wallet } = bitget;\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const [address] = await wallet.requestAccounts();\n\n async function signTransaction(psbt: Psbt) {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { autoFinalized: false });\n\n return Psbt.fromHex(signedPsbt);\n }\n\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction,\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(bitget && \"keplr\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n const { keplr: wallet } = bitget;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n if (!accounts?.[0])\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n\n const signer = {\n ...offlineSigner,\n getAddress: () => Promise.resolve(address),\n signTransaction: async () => Promise.resolve({} as any),\n };\n\n const toolbox = await getCosmosToolbox(Chain.Cosmos, {\n signer,\n });\n\n return { ...toolbox, address };\n })\n .with(Chain.Solana, async () => {\n if (!(bitget && \"solana\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const provider = bitget?.solana;\n\n // Connect to get the public key\n const providerConnection = await provider.connect();\n const address: string = providerConnection.publicKey.toString();\n\n // Create a proper signer object that wraps the provider\n const signer = {\n ...provider,\n publicKey: providerConnection.publicKey,\n getAddress: async () => address,\n };\n\n const toolbox = await getSolanaToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Tron, async () => {\n if (!(bitget && \"tronLink\" in bitget && \"tronWeb\" in bitget)) {\n throw new SwapKitError(\"wallet_bitkeep_not_found\");\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n const { tronLink, tronWeb } = bitget;\n\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n // Check if the request was successful\n if (response.code !== 200) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: response.message || \"User rejected connection\",\n });\n }\n\n // After successful approval, the address should be available in tronWeb.defaultAddress\n const address = tronWeb.defaultAddress?.base58;\n\n if (!address) {\n throw new SwapKitError(\"wallet_bitkeep_no_accounts\", { chain: Chain.Tron });\n }\n\n // Create signer compatible with TronSigner interface\n const signer = {\n getAddress: () => Promise.resolve(address),\n signTransaction: async (transaction: TronTransaction) => {\n const signedTx = await tronWeb.trx.sign(transaction);\n return signedTx;\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_chain_not_supported\");\n });\n}\n\nexport const getWeb3WalletMethods = async ({\n chain,\n walletProvider,\n}: { walletProvider?: Eip1193Provider; chain: EVMChain }) => {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_provider_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_bitkeep_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ chain, toolbox, provider });\n};\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "B596B3BF2A22DA5164756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "B9CB4D4628AD563964756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var y={};_(y,{okxWallet:()=>u,OKX_SUPPORTED_CHAINS:()=>b});module.exports=f(y);var e=require("@swapkit/helpers"),x=require("@swapkit/wallet-core");var o=require("@swapkit/helpers"),h=require("bitcoinjs-lib"),g=(i)=>async({recipient:s,assetValue:l,memo:r})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:o.Chain.Cosmos});let{createSigningStargateClient:t}=await import("@swapkit/toolboxes/cosmos"),{keplr:a}=window.okxwallet,n=a?.getOfflineSignerOnlyAmino(o.ChainId.Cosmos),w=await t(o.SKConfig.get("rpcUrls").GAIA,n),d=[{denom:l?.symbol==="MUON"?"umuon":"uatom",amount:l.getBaseValue("string")}],{transactionHash:m}=await w.sendTokens(i,s,d,1.6,r);return m};async function k({walletProvider:i,chain:s}){let{getEvmToolbox:l}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:r}=await import("ethers");if(!i)throw new o.SwapKitError("wallet_okx_not_found");let t=new r(i,"any"),a=await t.getSigner(),n=await l(s,{provider:t,signer:a});try{if(s!==o.Chain.Ethereum&&"getNetworkParams"in n)await o.switchEVMWalletNetwork(t,s,n.getNetworkParams())}catch(w){throw new o.SwapKitError("wallet_okx_failed_to_switch_network",{chain:s})}return o.prepareNetworkSwitch({toolbox:n,provider:t,chain:s})}async function p(i){let{match:s,P:l}=await import("ts-pattern");return s(i).with(l.union(o.Chain.Arbitrum,o.Chain.Aurora,o.Chain.Avalanche,o.Chain.Base,o.Chain.Berachain,o.Chain.BinanceSmartChain,o.Chain.Ethereum,o.Chain.Gnosis,o.Chain.Optimism,o.Chain.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:i});let r=await k({chain:i,walletProvider:window.okxwallet}),t=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...r,address:t}}).with(o.Chain.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:o.Chain.Bitcoin});let{getUtxoToolbox:r}=await import("@swapkit/toolboxes/utxo"),{bitcoin:t}=window.okxwallet,a=(await t.connect()).address,n={signTransaction:async(d)=>{let m=await t.signPsbt(d.toHex(),{from:a,type:"list"});return h.Psbt.fromHex(m)},getAddress:async()=>Promise.resolve(a)};return{...await r(o.Chain.Bitcoin,{signer:n}),address:a}}).with(o.Chain.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:o.Chain.Cosmos});let{keplr:r}=window.okxwallet;await r.enable(o.ChainId.Cosmos);let t=await r.getOfflineSignerOnlyAmino(o.ChainId.Cosmos).getAccounts();if(!t?.[0])throw new o.SwapKitError("wallet_okx_no_accounts",{chain:o.Chain.Cosmos});let{getCosmosToolbox:a}=await import("@swapkit/toolboxes/cosmos"),[{address:n}]=t;return{...a(o.Chain.Cosmos),address:n,transfer:g(n)}}).with(o.Chain.Near,async()=>{if(!(window.okxwallet&&("near"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:o.Chain.Near});let{createNearSignerFromProvider:r}=await import("../../chunk-wfattb4a.js"),{getNearToolbox:t}=await import("@swapkit/toolboxes/near"),a=window.okxwallet.near,n=await r(a,"OKX"),w=await n.getAddress();return{...await t({signer:n}),address:w}}).with(o.Chain.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new o.SwapKitError("wallet_okx_not_found",{chain:o.Chain.Tron});let{createTronToolbox:r}=await import("@swapkit/toolboxes/tron"),t=window.okxwallet.tronLink,a=await t.request({method:"tron_requestAccounts"});if(!a||a.length===0)throw new o.SwapKitError("wallet_okx_no_accounts",{chain:o.Chain.Tron});let n=t.tronWeb.defaultAddress.base58;return{...await r({signer:{getAddress:async()=>n,signTransaction:async(m)=>{return await t.tronWeb.trx.sign(m)}}}),address:n}}).otherwise(()=>{throw new o.SwapKitError("wallet_okx_chain_not_supported",{chain:i})})}var u=x.createWallet({name:"connectOkx",walletType:e.WalletOption.OKX,supportedChains:[e.Chain.Arbitrum,e.Chain.Aurora,e.Chain.Avalanche,e.Chain.Base,e.Chain.Berachain,e.Chain.BinanceSmartChain,e.Chain.Bitcoin,e.Chain.Cosmos,e.Chain.Ethereum,e.Chain.Gnosis,e.Chain.Near,e.Chain.Optimism,e.Chain.Polygon,e.Chain.Tron],connect:({addChain:i,supportedChains:s,walletType:l})=>async function r(t){let a=e.filterSupportedChains({chains:t,supportedChains:s,walletType:l});return await Promise.all(a.map(async(n)=>{let w=await p(n),d=await w.getAddress()||"";i({...w,address:d,chain:n,walletType:l})})),!0}}),b=x.getWalletSupportedChains(u);
1
+ var F={};j(F,{okxWallet:()=>U,OKX_SUPPORTED_CHAINS:()=>q});module.exports=$(F);var y=require("@swapkit/helpers"),M=require("@swapkit/wallet-core");var O=require("@swapkit/helpers"),Q=require("bitcoinjs-lib"),Y=(m)=>async({recipient:D,assetValue:W,memo:_})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:O.Chain.Cosmos});let{createSigningStargateClient:A}=await import("@swapkit/toolboxes/cosmos"),{keplr:B}=window.okxwallet,X=B?.getOfflineSignerOnlyAmino(O.ChainId.Cosmos),G=await A(O.SKConfig.get("rpcUrls").GAIA,X),z=[{denom:W?.symbol==="MUON"?"umuon":"uatom",amount:W.getBaseValue("string")}],{transactionHash:H}=await G.sendTokens(m,D,z,1.6,_);return H};async function Z({walletProvider:m,chain:D}){let{getEvmToolbox:W}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers");if(!m)throw new O.SwapKitError("wallet_okx_not_found");let A=new _(m,"any"),B=await A.getSigner(),X=await W(D,{provider:A,signer:B});try{if(D!==O.Chain.Ethereum&&"getNetworkParams"in X)await O.switchEVMWalletNetwork(A,D,X.getNetworkParams())}catch(G){throw new O.SwapKitError("wallet_okx_failed_to_switch_network",{chain:D})}return O.prepareNetworkSwitch({toolbox:X,provider:A,chain:D})}async function R(m){let{match:D,P:W}=await import("ts-pattern");return D(m).with(W.union(O.Chain.Arbitrum,O.Chain.Aurora,O.Chain.Avalanche,O.Chain.Base,O.Chain.Berachain,O.Chain.BinanceSmartChain,O.Chain.Ethereum,O.Chain.Gnosis,O.Chain.Optimism,O.Chain.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:m});let _=await Z({chain:m,walletProvider:window.okxwallet}),A=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{..._,address:A}}).with(O.Chain.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:O.Chain.Bitcoin});let{getUtxoToolbox:_}=await import("@swapkit/toolboxes/utxo"),{bitcoin:A}=window.okxwallet,B=(await A.connect()).address,X={signTransaction:async(z)=>{let H=await A.signPsbt(z.toHex(),{from:B,type:"list"});return Q.Psbt.fromHex(H)},getAddress:async()=>Promise.resolve(B)};return{...await _(O.Chain.Bitcoin,{signer:X}),address:B}}).with(O.Chain.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:O.Chain.Cosmos});let{keplr:_}=window.okxwallet;await _.enable(O.ChainId.Cosmos);let B=await _.getOfflineSignerOnlyAmino(O.ChainId.Cosmos).getAccounts();if(!(B&&Array.isArray(B))||B.length===0)throw new O.SwapKitError("wallet_okx_no_accounts",{chain:O.Chain.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:X}=await import("@swapkit/toolboxes/cosmos"),[{address:G}]=B;return{...await X(O.Chain.Cosmos),address:G,transfer:Y(G)}}).with(O.Chain.Near,async()=>{if(!(window.okxwallet&&("near"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:O.Chain.Near});let{createNearSignerFromProvider:_}=await import("../../chunk-wfattb4a.js"),{getNearToolbox:A}=await import("@swapkit/toolboxes/near"),B=window.okxwallet.near,X=await _(B,"OKX"),G=await X.getAddress();return{...await A({signer:X}),address:G}}).with(O.Chain.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new O.SwapKitError("wallet_okx_not_found",{chain:O.Chain.Tron});let{createTronToolbox:_}=await import("@swapkit/toolboxes/tron"),A=window.okxwallet.tronLink,B=await A.request({method:"tron_requestAccounts"});if(!B||B.length===0)throw new O.SwapKitError("wallet_okx_no_accounts",{chain:O.Chain.Tron});let X=A.tronWeb.defaultAddress.base58;return{...await _({signer:{getAddress:async()=>X,signTransaction:async(H)=>{return await A.tronWeb.trx.sign(H)}}}),address:X}}).otherwise(()=>{throw new O.SwapKitError("wallet_okx_chain_not_supported",{chain:m})})}var U=M.createWallet({name:"connectOkx",walletType:y.WalletOption.OKX,supportedChains:[y.Chain.Arbitrum,y.Chain.Aurora,y.Chain.Avalanche,y.Chain.Base,y.Chain.Berachain,y.Chain.BinanceSmartChain,y.Chain.Bitcoin,y.Chain.Cosmos,y.Chain.Ethereum,y.Chain.Gnosis,y.Chain.Near,y.Chain.Optimism,y.Chain.Polygon,y.Chain.Tron],connect:({addChain:m,supportedChains:D,walletType:W})=>async function _(A){let B=y.filterSupportedChains({chains:A,supportedChains:D,walletType:W});return await Promise.all(B.map(async(X)=>{let G=await R(X);m({...G,chain:X,walletType:W})})),!0}}),q=M.getWalletSupportedChains(U);
2
2
 
3
- //# debugId=8F2AED3B873B612164756E2164756E21
3
+ //# debugId=7EC38733C0022E4064756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n name: \"connectOkx\",\n walletType: WalletOption.OKX,\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
6
- "import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\",\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: { walletProvider: Eip1193Provider | undefined; chain: EVMChain }) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: window.okxwallet,\n });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), {\n from: address,\n type: \"list\",\n });\n\n return Psbt.fromHex(signedPsbt);\n },\n getAddress: async () => Promise.resolve(address),\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(ChainId.Cosmos);\n const accounts = await wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos).getAccounts();\n if (!accounts?.[0]) throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n .with(Chain.Near, async () => {\n if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_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.okxwallet.near;\n const signer = await createNearSignerFromProvider(provider, \"OKX\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n });\n}\n"
5
+ "import { Chain, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n name: \"connectOkx\",\n walletType: WalletOption.OKX,\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
6
+ "import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\",\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: { walletProvider: Eip1193Provider | undefined; chain: EVMChain }) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: window.okxwallet,\n });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), {\n from: address,\n type: \"list\",\n });\n\n return Psbt.fromHex(signedPsbt);\n },\n getAddress: async () => Promise.resolve(address),\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n\n // Add defensive check for accounts array\n if (!(accounts && Array.isArray(accounts)) || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", {\n chain: Chain.Cosmos,\n message: \"No Cosmos accounts returned from OKX Wallet\",\n });\n }\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n .with(Chain.Near, async () => {\n if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_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.okxwallet.near;\n const signer = await createNearSignerFromProvider(provider, \"OKX\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n });\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "8F2AED3B873B612164756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "7EC38733C0022E4064756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- import{F as d,G as m}from"../../chunk-yqaz2d25.js";import{Chain as r,WalletOption as C,filterSupportedChains as T}from"@swapkit/helpers";import{createWallet as P,getWalletSupportedChains as A}from"@swapkit/wallet-core";import{Chain as o,ChainId as p,SKConfig as g,SwapKitError as w,prepareNetworkSwitch as k,switchEVMWalletNetwork as f}from"@swapkit/helpers";import{Psbt as _}from"bitcoinjs-lib";var b=(i)=>async({recipient:s,assetValue:c,memo:a})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:o.Cosmos});let{createSigningStargateClient:t}=await import("@swapkit/toolboxes/cosmos"),{keplr:e}=window.okxwallet,n=e?.getOfflineSignerOnlyAmino(p.Cosmos),l=await t(g.get("rpcUrls").GAIA,n),x=[{denom:c?.symbol==="MUON"?"umuon":"uatom",amount:c.getBaseValue("string")}],{transactionHash:h}=await l.sendTokens(i,s,x,1.6,a);return h};async function y({walletProvider:i,chain:s}){let{getEvmToolbox:c}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:a}=await import("ethers");if(!i)throw new w("wallet_okx_not_found");let t=new a(i,"any"),e=await t.getSigner(),n=await c(s,{provider:t,signer:e});try{if(s!==o.Ethereum&&"getNetworkParams"in n)await f(t,s,n.getNetworkParams())}catch(l){throw new w("wallet_okx_failed_to_switch_network",{chain:s})}return k({toolbox:n,provider:t,chain:s})}async function u(i){let{match:s,P:c}=await import("ts-pattern");return s(i).with(c.union(o.Arbitrum,o.Aurora,o.Avalanche,o.Base,o.Berachain,o.BinanceSmartChain,o.Ethereum,o.Gnosis,o.Optimism,o.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:i});let a=await y({chain:i,walletProvider:window.okxwallet}),t=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...a,address:t}}).with(o.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:o.Bitcoin});let{getUtxoToolbox:a}=await import("@swapkit/toolboxes/utxo"),{bitcoin:t}=window.okxwallet,e=(await t.connect()).address,n={signTransaction:async(x)=>{let h=await t.signPsbt(x.toHex(),{from:e,type:"list"});return _.fromHex(h)},getAddress:async()=>Promise.resolve(e)};return{...await a(o.Bitcoin,{signer:n}),address:e}}).with(o.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:o.Cosmos});let{keplr:a}=window.okxwallet;await a.enable(p.Cosmos);let t=await a.getOfflineSignerOnlyAmino(p.Cosmos).getAccounts();if(!t?.[0])throw new w("wallet_okx_no_accounts",{chain:o.Cosmos});let{getCosmosToolbox:e}=await import("@swapkit/toolboxes/cosmos"),[{address:n}]=t;return{...e(o.Cosmos),address:n,transfer:b(n)}}).with(o.Near,async()=>{if(!(window.okxwallet&&("near"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:o.Near});let{createNearSignerFromProvider:a}=await import("../../chunk-mcrgqfr9.js"),{getNearToolbox:t}=await import("@swapkit/toolboxes/near"),e=window.okxwallet.near,n=await a(e,"OKX"),l=await n.getAddress();return{...await t({signer:n}),address:l}}).with(o.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new w("wallet_okx_not_found",{chain:o.Tron});let{createTronToolbox:a}=await import("@swapkit/toolboxes/tron"),t=window.okxwallet.tronLink,e=await t.request({method:"tron_requestAccounts"});if(!e||e.length===0)throw new w("wallet_okx_no_accounts",{chain:o.Tron});let n=t.tronWeb.defaultAddress.base58;return{...await a({signer:{getAddress:async()=>n,signTransaction:async(h)=>{return await t.tronWeb.trx.sign(h)}}}),address:n}}).otherwise(()=>{throw new w("wallet_okx_chain_not_supported",{chain:i})})}var S=P({name:"connectOkx",walletType:C.OKX,supportedChains:[r.Arbitrum,r.Aurora,r.Avalanche,r.Base,r.Berachain,r.BinanceSmartChain,r.Bitcoin,r.Cosmos,r.Ethereum,r.Gnosis,r.Near,r.Optimism,r.Polygon,r.Tron],connect:({addChain:i,supportedChains:s,walletType:c})=>async function a(t){let e=T({chains:t,supportedChains:s,walletType:c});return await Promise.all(e.map(async(n)=>{let l=await u(n),x=await l.getAddress()||"";i({...l,address:x,chain:n,walletType:c})})),!0}}),M=A(S);export{S as okxWallet,M as OKX_SUPPORTED_CHAINS};
1
+ import{F as z,G as H}from"../../chunk-yqaz2d25.js";import{Chain as _,WalletOption as J,filterSupportedChains as N}from"@swapkit/helpers";import{createWallet as I,getWalletSupportedChains as L}from"@swapkit/wallet-core";import{Chain as O,ChainId as R,SKConfig as Y,SwapKitError as W,prepareNetworkSwitch as Z,switchEVMWalletNetwork as $}from"@swapkit/helpers";import{Psbt as j}from"bitcoinjs-lib";var q=(m)=>async({recipient:D,assetValue:f,memo:X})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:O.Cosmos});let{createSigningStargateClient:A}=await import("@swapkit/toolboxes/cosmos"),{keplr:B}=window.okxwallet,y=B?.getOfflineSignerOnlyAmino(R.Cosmos),G=await A(Y.get("rpcUrls").GAIA,y),M=[{denom:f?.symbol==="MUON"?"umuon":"uatom",amount:f.getBaseValue("string")}],{transactionHash:Q}=await G.sendTokens(m,D,M,1.6,X);return Q};async function F({walletProvider:m,chain:D}){let{getEvmToolbox:f}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:X}=await import("ethers");if(!m)throw new W("wallet_okx_not_found");let A=new X(m,"any"),B=await A.getSigner(),y=await f(D,{provider:A,signer:B});try{if(D!==O.Ethereum&&"getNetworkParams"in y)await $(A,D,y.getNetworkParams())}catch(G){throw new W("wallet_okx_failed_to_switch_network",{chain:D})}return Z({toolbox:y,provider:A,chain:D})}async function U(m){let{match:D,P:f}=await import("ts-pattern");return D(m).with(f.union(O.Arbitrum,O.Aurora,O.Avalanche,O.Base,O.Berachain,O.BinanceSmartChain,O.Ethereum,O.Gnosis,O.Optimism,O.Polygon),async()=>{if(!(window.okxwallet&&("send"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:m});let X=await F({chain:m,walletProvider:window.okxwallet}),A=(await window.okxwallet.send("eth_requestAccounts",[])).result[0];return{...X,address:A}}).with(O.Bitcoin,async()=>{if(!(window.okxwallet&&("bitcoin"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:O.Bitcoin});let{getUtxoToolbox:X}=await import("@swapkit/toolboxes/utxo"),{bitcoin:A}=window.okxwallet,B=(await A.connect()).address,y={signTransaction:async(M)=>{let Q=await A.signPsbt(M.toHex(),{from:B,type:"list"});return j.fromHex(Q)},getAddress:async()=>Promise.resolve(B)};return{...await X(O.Bitcoin,{signer:y}),address:B}}).with(O.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:O.Cosmos});let{keplr:X}=window.okxwallet;await X.enable(R.Cosmos);let B=await X.getOfflineSignerOnlyAmino(R.Cosmos).getAccounts();if(!(B&&Array.isArray(B))||B.length===0)throw new W("wallet_okx_no_accounts",{chain:O.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:y}=await import("@swapkit/toolboxes/cosmos"),[{address:G}]=B;return{...await y(O.Cosmos),address:G,transfer:q(G)}}).with(O.Near,async()=>{if(!(window.okxwallet&&("near"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:O.Near});let{createNearSignerFromProvider:X}=await import("../../chunk-mcrgqfr9.js"),{getNearToolbox:A}=await import("@swapkit/toolboxes/near"),B=window.okxwallet.near,y=await X(B,"OKX"),G=await y.getAddress();return{...await A({signer:y}),address:G}}).with(O.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new W("wallet_okx_not_found",{chain:O.Tron});let{createTronToolbox:X}=await import("@swapkit/toolboxes/tron"),A=window.okxwallet.tronLink,B=await A.request({method:"tron_requestAccounts"});if(!B||B.length===0)throw new W("wallet_okx_no_accounts",{chain:O.Tron});let y=A.tronWeb.defaultAddress.base58;return{...await X({signer:{getAddress:async()=>y,signTransaction:async(Q)=>{return await A.tronWeb.trx.sign(Q)}}}),address:y}}).otherwise(()=>{throw new W("wallet_okx_chain_not_supported",{chain:m})})}var P=I({name:"connectOkx",walletType:J.OKX,supportedChains:[_.Arbitrum,_.Aurora,_.Avalanche,_.Base,_.Berachain,_.BinanceSmartChain,_.Bitcoin,_.Cosmos,_.Ethereum,_.Gnosis,_.Near,_.Optimism,_.Polygon,_.Tron],connect:({addChain:m,supportedChains:D,walletType:f})=>async function X(A){let B=N({chains:A,supportedChains:D,walletType:f});return await Promise.all(B.map(async(y)=>{let G=await U(y);m({...G,chain:y,walletType:f})})),!0}}),E=L(P);export{P as okxWallet,E as OKX_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=1532095472533CEE64756E2164756E21
3
+ //# debugId=CCE8C70EB58C907C64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map
@@ -2,10 +2,10 @@
2
2
  "version": 3,
3
3
  "sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
4
4
  "sourcesContent": [
5
- "import { Chain, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n name: \"connectOkx\",\n walletType: WalletOption.OKX,\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n const address = (await walletMethods.getAddress()) || \"\";\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
6
- "import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\",\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: { walletProvider: Eip1193Provider | undefined; chain: EVMChain }) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: window.okxwallet,\n });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), {\n from: address,\n type: \"list\",\n });\n\n return Psbt.fromHex(signedPsbt);\n },\n getAddress: async () => Promise.resolve(address),\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(ChainId.Cosmos);\n const accounts = await wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos).getAccounts();\n if (!accounts?.[0]) throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Cosmos });\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n .with(Chain.Near, async () => {\n if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_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.okxwallet.near;\n const signer = await createNearSignerFromProvider(provider, \"OKX\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n });\n}\n"
5
+ "import { Chain, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\n name: \"connectOkx\",\n walletType: WalletOption.OKX,\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.Cosmos,\n Chain.Ethereum,\n Chain.Gnosis,\n Chain.Near,\n Chain.Optimism,\n Chain.Polygon,\n Chain.Tron,\n ],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectOkx(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
6
+ "import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n SKConfig,\n SwapKitError,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n} from \"@swapkit/helpers\";\nimport type { NearToolbox } from \"@swapkit/toolboxes/near\";\nimport type { TronSigner, TronTransaction } from \"@swapkit/toolboxes/tron\";\nimport { Psbt } from \"bitcoinjs-lib\";\nimport type { Eip1193Provider } from \"ethers\";\n\nconst cosmosTransfer =\n (sender: string) =>\n async ({ recipient, assetValue, memo }: GenericTransferParams) => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { createSigningStargateClient } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const { keplr: wallet } = window.okxwallet;\n const offlineSigner = wallet?.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n\n const cosmJS = await createSigningStargateClient(SKConfig.get(\"rpcUrls\").GAIA, offlineSigner);\n\n const coins = [\n {\n denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\",\n amount: assetValue.getBaseValue(\"string\"),\n },\n ];\n\n const { transactionHash } = await cosmJS.sendTokens(sender, recipient, coins, 1.6, memo);\n return transactionHash;\n };\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: { walletProvider: Eip1193Provider | undefined; chain: EVMChain }) {\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n if (!walletProvider) throw new SwapKitError(\"wallet_okx_not_found\");\n\n const provider = new BrowserProvider(walletProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain, { provider, signer });\n\n try {\n if (chain !== Chain.Ethereum && \"getNetworkParams\" in toolbox) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch (_error) {\n throw new SwapKitError(\"wallet_okx_failed_to_switch_network\", { chain });\n }\n\n return prepareNetworkSwitch({ toolbox, provider, chain });\n}\n\nexport async function getWalletMethods(chain: Chain) {\n const { match, P } = await import(\"ts-pattern\");\n\n return match(chain)\n .with(\n P.union(\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 ),\n async () => {\n if (!(window.okxwallet && \"send\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain });\n }\n\n const evmWallet = await getWeb3WalletMethods({\n chain: chain as EVMChain,\n walletProvider: window.okxwallet,\n });\n const address: string = (await window.okxwallet.send(\"eth_requestAccounts\", [])).result[0];\n\n return { ...evmWallet, address };\n },\n )\n .with(Chain.Bitcoin, async () => {\n if (!(window.okxwallet && \"bitcoin\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Bitcoin });\n }\n\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n\n const { bitcoin: wallet } = window.okxwallet;\n const address = (await wallet.connect()).address;\n\n const signer = {\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), {\n from: address,\n type: \"list\",\n });\n\n return Psbt.fromHex(signedPsbt);\n },\n getAddress: async () => Promise.resolve(address),\n };\n\n const toolbox = await getUtxoToolbox(Chain.Bitcoin, { signer });\n\n return { ...toolbox, address };\n })\n .with(Chain.Cosmos, async () => {\n if (!(window.okxwallet && \"keplr\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Cosmos });\n }\n const { keplr: wallet } = window.okxwallet;\n\n await wallet.enable(ChainId.Cosmos);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.Cosmos);\n const accounts = await offlineSigner.getAccounts();\n\n // Add defensive check for accounts array\n if (!(accounts && Array.isArray(accounts)) || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", {\n chain: Chain.Cosmos,\n message: \"No Cosmos accounts returned from OKX Wallet\",\n });\n }\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(Chain.Cosmos);\n\n return { ...toolbox, address, transfer: cosmosTransfer(address) };\n })\n .with(Chain.Near, async () => {\n if (!(window.okxwallet && \"near\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_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.okxwallet.near;\n const signer = await createNearSignerFromProvider(provider, \"OKX\");\n const accountId = await signer.getAddress();\n const toolbox = await getNearToolbox({ signer });\n\n return { ...toolbox, address: accountId } as NearToolbox & { address: string };\n })\n .with(Chain.Tron, async () => {\n if (!(window.okxwallet && \"tronLink\" in window.okxwallet)) {\n throw new SwapKitError(\"wallet_okx_not_found\", { chain: Chain.Tron });\n }\n\n const { createTronToolbox } = await import(\"@swapkit/toolboxes/tron\");\n\n const tronLink = window.okxwallet.tronLink;\n\n // Request account access\n const accounts = await tronLink.request({ method: \"tron_requestAccounts\" });\n if (!accounts || accounts.length === 0) {\n throw new SwapKitError(\"wallet_okx_no_accounts\", { chain: Chain.Tron });\n }\n\n const address = tronLink.tronWeb.defaultAddress.base58;\n\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n const toolbox = await createTronToolbox({ signer });\n\n return { ...toolbox, address };\n })\n .otherwise(() => {\n throw new SwapKitError(\"wallet_okx_chain_not_supported\", { chain });\n });\n}\n"
7
7
  ],
8
- "mappings": "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",
9
- "debugId": "1532095472533CEE64756E2164756E21",
8
+ "mappings": "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",
9
+ "debugId": "CCE8C70EB58C907C64756E2164756E21",
10
10
  "names": []
11
11
  }
@@ -1,4 +1,4 @@
1
- var F={};S(F,{waitForTronLink:()=>G,verifyNetwork:()=>Q,tronlinkWallet:()=>V,setupEventListeners:()=>T,getWalletForChain:()=>J,getExpectedTronNetwork:()=>Z,TronLinkResponseCode:()=>H,TRONLINK_SUPPORTED_CHAINS:()=>A});module.exports=M(F);var P=require("@swapkit/helpers"),_=require("@swapkit/wallet-core");var D=require("@swapkit/helpers"),z=require("@swapkit/toolboxes/tron");var H;((m)=>{m[m.SUCCESS=200]="SUCCESS";m[m.CANCELED=4000]="CANCELED";m[m.REJECTED=4001]="REJECTED";m[m.UNAUTHORIZED=4100]="UNAUTHORIZED";m[m.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";m[m.DISCONNECTED=4900]="DISCONNECTED";m[m.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(H||={});async function G(b=3000){return new Promise((U,g)=>{let f=!1,E=()=>{if(f)return;if(f=!0,window.removeEventListener("tronlink#initialized",E),clearTimeout(q),window.tronLink)U(window.tronLink);else g(new D.SwapKitError("wallet_provider_not_found",{wallet:D.WalletOption.TRONLINK}))};if(window.tronLink){E();return}window.addEventListener("tronlink#initialized",E,{once:!0});let q=setTimeout(E,b)})}async function J(b,U){if(b!==D.Chain.Tron)throw new D.SwapKitError("wallet_chain_not_supported",{wallet:D.WalletOption.TRONLINK,chain:b});let g=await G();try{let I=await g.request({method:"tron_requestAccounts"});if(I.code!==200)throw new Error(`TronLink error: ${I.message}`)}catch(I){let m=I;if(m.code===4001)throw new D.SwapKitError("wallet_connection_rejected_by_user");if(m.code===4100)throw new D.SwapKitError("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new D.SwapKitError("wallet_provider_not_found",{wallet:D.WalletOption.TRONLINK,message:m.message||"Failed to connect to TronLink"})}let f=g.tronWeb.defaultAddress?.base58;if(!f)throw new D.SwapKitError("wallet_provider_not_found",{wallet:D.WalletOption.TRONLINK,message:"No account found in TronLink"});if(U)Q(U);return{...await z.createTronToolbox({signer:{getAddress:async()=>f,signTransaction:async(I)=>{return await g.tronWeb.trx.sign(I)}}}),address:f}}function T(b,U){let g=(f)=>{if(f.data?.message?.action==="setAccount"){let E=f.data.message.data.address;if(b)b(E);else window.location.reload()}if(f.data?.message?.action==="setNode"){let E=f.data.message.data.node;if(U)U(E.fullNode);else window.location.reload()}};return window.addEventListener("message",g),()=>window.removeEventListener("message",g)}function Q(b){let U=window.tronLink;if(!U)throw new D.SwapKitError("wallet_provider_not_found",{wallet:D.WalletOption.TRONLINK});let g=U.tronWeb.fullNode?.host;if(g&&!g.includes(b))throw new D.SwapKitError("wallet_failed_to_add_or_switch_network",{wallet:D.WalletOption.TRONLINK,message:`Wrong network. Please switch to ${b} in TronLink.`,currentNetwork:g,expectedNetwork:b})}function Z(b=!1){return b?"shasta":"api.trongrid.io"}var V=_.createWallet({name:"connectTronLink",walletType:P.WalletOption.TRONLINK,supportedChains:[P.Chain.Tron],connect:({addChain:b,supportedChains:U,walletType:g})=>async function f(E){if(P.filterSupportedChains({chains:E,supportedChains:U,walletType:g}).length===0)throw new Error("TronLink wallet only supports Tron chain");let I=Z(!1),m=await J(P.Chain.Tron,I),X=m.address,Y=T((B)=>{if(B!==X)window.location.reload()},(B)=>{if(!B.includes(I))window.location.reload()}),$=()=>{Y()};return b({...m,chain:P.Chain.Tron,balance:[],disconnect:$,walletType:g}),!0}}),A=_.getWalletSupportedChains(V);
1
+ var S={};F(S,{waitForTronLink:()=>G,verifyNetwork:()=>Q,tronlinkWallet:()=>V,setupEventListeners:()=>T,getWalletForChain:()=>J,getExpectedTronNetwork:()=>Z,TronLinkResponseCode:()=>H,TRONLINK_SUPPORTED_CHAINS:()=>O});module.exports=M(S);var _=require("@swapkit/helpers"),B=require("@swapkit/wallet-core");var b=require("@swapkit/helpers"),z=require("@swapkit/toolboxes/tron");var H;((D)=>{D[D.SUCCESS=200]="SUCCESS";D[D.LOCKED=4000]="LOCKED";D[D.REJECTED=4001]="REJECTED";D[D.UNAUTHORIZED=4100]="UNAUTHORIZED";D[D.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";D[D.DISCONNECTED=4900]="DISCONNECTED";D[D.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(H||={});async function G(g=3000){return new Promise((U,m)=>{let f=!1,P=()=>{if(f)return;if(f=!0,window.removeEventListener("tronlink#initialized",P),q)clearTimeout(q);if(window.tronLink)U(window.tronLink);else m(new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK}))};if(window.tronLink){U(window.tronLink);return}window.addEventListener("tronlink#initialized",P,{once:!0});let q=setTimeout(P,g)})}async function J(g,U){if(g!==b.Chain.Tron)throw new b.SwapKitError("wallet_chain_not_supported",{wallet:b.WalletOption.TRONLINK,chain:g});let m=await G();if(!m.ready)throw new b.SwapKitError("wallet_locked",{wallet:b.WalletOption.TRONLINK,message:"TronLink is locked. Please unlock it to continue."});try{let I=await m.request({method:"tron_requestAccounts"});if(I.code!==200)throw new Error(`TronLink error: ${I.message}`)}catch(I){let D=I;if(D.code===4001)throw new b.SwapKitError("wallet_connection_rejected_by_user");if(D.code===4100)throw new b.SwapKitError("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK,message:D.message||"Failed to connect to TronLink"})}let f=m.tronWeb.defaultAddress?.base58;if(!f)throw new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK,message:"No account found in TronLink"});if(U)Q(U);return{...await z.createTronToolbox({signer:{getAddress:async()=>f,signTransaction:async(I)=>{return await m.tronWeb.trx.sign(I)}}}),address:f}}function T(g,U){let m=(f)=>{if(f.data?.message?.action==="setAccount"){let P=f.data.message.data.address;if(g)g(P);else window.location.reload()}if(f.data?.message?.action==="setNode"){let P=f.data.message.data.node;if(U)U(P.fullNode);else window.location.reload()}};return window.addEventListener("message",m),()=>window.removeEventListener("message",m)}function Q(g){let U=window.tronLink;if(!U)throw new b.SwapKitError("wallet_provider_not_found",{wallet:b.WalletOption.TRONLINK});let m=U.tronWeb.fullNode?.host;if(m&&!m.includes(g))throw new b.SwapKitError("wallet_failed_to_add_or_switch_network",{wallet:b.WalletOption.TRONLINK,message:`Wrong network. Please switch to ${g} in TronLink.`,currentNetwork:m,expectedNetwork:g})}function Z(g=!1){return g?"shasta":"api.trongrid.io"}var V=B.createWallet({name:"connectTronLink",walletType:_.WalletOption.TRONLINK,supportedChains:[_.Chain.Tron],connect:({addChain:g,supportedChains:U,walletType:m})=>async function f(P){if(_.filterSupportedChains({chains:P,supportedChains:U,walletType:m}).length===0)throw new Error("TronLink wallet only supports Tron chain");let I=Z(!1),D=await J(_.Chain.Tron,I),X=D.address,Y=T((E)=>{if(E!==X)window.location.reload()},(E)=>{if(!E.includes(I))window.location.reload()}),$=()=>{Y()};return g({...D,chain:_.Chain.Tron,balance:[],disconnect:$,walletType:m}),!0}}),O=B.getWalletSupportedChains(V);
2
2
 
3
- //# debugId=D535388787A40ECE64756E2164756E21
3
+ //# debugId=0A544539AB0FF75664756E2164756E21
4
4
  //# sourceMappingURL=index.cjs.map
@@ -3,10 +3,10 @@
3
3
  "sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
4
4
  "sourcesContent": [
5
5
  "import { Chain, WalletOption, filterSupportedChains } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n name: \"connectTronLink\",\n walletType: WalletOption.TRONLINK,\n supportedChains: [Chain.Tron],\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n // Store original address for comparison in event listeners\n const currentAddress = walletMethods.address;\n\n // Setup event listeners for account/network changes\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n // Handle account change - reload to refresh connection\n window.location.reload();\n }\n },\n (newNetwork) => {\n // Handle network change - reload to refresh connection\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n // Create disconnect function that cleans up event listeners\n const disconnect = () => {\n cleanup();\n };\n\n addChain({\n ...walletMethods,\n chain: Chain.Tron,\n balance: [],\n disconnect,\n walletType,\n });\n\n return true;\n },\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./types.js\";\nexport * from \"./helpers.js\";\n",
6
- "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { type TronSigner, type TronTransaction, createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkError, TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport async function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(\n new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n }),\n );\n }\n };\n\n // Check if already available\n if (window.tronLink) {\n handleProvider();\n return;\n }\n\n // Listen for the initialization event\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n // Fallback timeout\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", {\n wallet: WalletOption.TRONLINK,\n chain,\n });\n }\n\n const tronLink = await waitForTronLink();\n\n try {\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new Error(`TronLink error: ${response.message}`);\n }\n } catch (error: unknown) {\n const tronError = error as TronLinkError;\n\n // Handle specific error codes\n if (tronError.code === TronLinkResponseCode.REJECTED) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n if (tronError.code === TronLinkResponseCode.UNAUTHORIZED) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: \"Unauthorized: Please authorize the connection in TronLink\",\n });\n }\n\n // Generic connection error\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n message: tronError.message || \"Failed to connect to TronLink\",\n });\n }\n\n // Verify connection\n const address = tronLink.tronWeb.defaultAddress?.base58;\n if (!address) {\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n message: \"No account found in TronLink\",\n });\n }\n\n // Verify network if required\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n // Create signer object\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n // Create toolbox with signer\n const toolbox = await createTronToolbox({\n signer,\n });\n\n // Return wallet methods\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n): () => void {\n const messageHandler = (event: MessageEvent) => {\n if (event.data?.message?.action === \"setAccount\") {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n } else {\n // Default behavior: reload the page\n window.location.reload();\n }\n }\n\n if (event.data?.message?.action === \"setNode\") {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n } else {\n // Default behavior: reload the page on network change\n window.location.reload();\n }\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Return cleanup function\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n wallet: WalletOption.TRONLINK,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n currentNetwork: currentNode,\n expectedNetwork,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
- "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse>;\n tronWeb: {\n defaultAddress: {\n base58: string;\n hex: string;\n };\n fullNode?: {\n host: string;\n };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n CANCELED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: {\n address: string;\n };\n setNode: {\n node: {\n chain: string;\n fullNode: string;\n };\n };\n}\n\nexport interface TronLinkError extends Error {\n code: number;\n data?: unknown;\n}\n"
6
+ "import { Chain, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { type TronSigner, type TronTransaction, createTronToolbox } from \"@swapkit/toolboxes/tron\";\nimport type { TronLinkError, TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport async function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(\n new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n }),\n );\n }\n };\n\n // Check if already available\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n // Listen for the initialization event\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n // Fallback timeout\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new SwapKitError(\"wallet_chain_not_supported\", {\n wallet: WalletOption.TRONLINK,\n chain,\n });\n }\n\n const tronLink = await waitForTronLink();\n\n if (!tronLink.ready) {\n throw new SwapKitError(\"wallet_locked\", {\n wallet: WalletOption.TRONLINK,\n message: \"TronLink is locked. Please unlock it to continue.\",\n });\n }\n\n try {\n // Request account access\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new Error(`TronLink error: ${response.message}`);\n }\n } catch (error: unknown) {\n const tronError = error as TronLinkError;\n\n // Handle specific error codes\n if (tronError.code === TronLinkResponseCode.REJECTED) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\");\n }\n\n if (tronError.code === TronLinkResponseCode.UNAUTHORIZED) {\n throw new SwapKitError(\"wallet_connection_rejected_by_user\", {\n message: \"Unauthorized: Please authorize the connection in TronLink\",\n });\n }\n\n // Generic connection error\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n message: tronError.message || \"Failed to connect to TronLink\",\n });\n }\n\n // Verify connection\n const address = tronLink.tronWeb.defaultAddress?.base58;\n if (!address) {\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n message: \"No account found in TronLink\",\n });\n }\n\n // Verify network if required\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n // Create signer object\n const signer: TronSigner = {\n getAddress: async () => address,\n signTransaction: async (transaction: TronTransaction) => {\n return await tronLink.tronWeb.trx.sign(transaction);\n },\n };\n\n // Create toolbox with signer\n const toolbox = await createTronToolbox({\n signer,\n });\n\n // Return wallet methods\n return { ...toolbox, address };\n}\n\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n): () => void {\n const messageHandler = (event: MessageEvent) => {\n if (event.data?.message?.action === \"setAccount\") {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n } else {\n // Default behavior: reload the page\n window.location.reload();\n }\n }\n\n if (event.data?.message?.action === \"setNode\") {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n } else {\n // Default behavior: reload the page on network change\n window.location.reload();\n }\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n // Return cleanup function\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new SwapKitError(\"wallet_provider_not_found\", {\n wallet: WalletOption.TRONLINK,\n });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new SwapKitError(\"wallet_failed_to_add_or_switch_network\", {\n wallet: WalletOption.TRONLINK,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n currentNetwork: currentNode,\n expectedNetwork,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
7
+ "import type { TronSignedTransaction, TronTransaction } from \"@swapkit/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse>;\n tronWeb: {\n defaultAddress: {\n base58: string;\n hex: string;\n };\n fullNode?: {\n host: string;\n };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: {\n address: string;\n };\n setNode: {\n node: {\n chain: string;\n fullNode: string;\n };\n };\n}\n\nexport interface TronLinkError extends Error {\n code: number;\n data?: unknown;\n}\n"
8
8
  ],
9
- "mappings": "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",
10
- "debugId": "D535388787A40ECE64756E2164756E21",
9
+ "mappings": "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",
10
+ "debugId": "0A544539AB0FF75664756E2164756E21",
11
11
  "names": []
12
12
  }
@@ -1,4 +1,4 @@
1
- import"../../chunk-yqaz2d25.js";import{Chain as B,WalletOption as M,filterSupportedChains as S}from"@swapkit/helpers";import{createWallet as A,getWalletSupportedChains as F}from"@swapkit/wallet-core";import{Chain as V,SwapKitError as I,WalletOption as P}from"@swapkit/helpers";import{createTronToolbox as X}from"@swapkit/toolboxes/tron";var H;((m)=>{m[m.SUCCESS=200]="SUCCESS";m[m.CANCELED=4000]="CANCELED";m[m.REJECTED=4001]="REJECTED";m[m.UNAUTHORIZED=4100]="UNAUTHORIZED";m[m.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";m[m.DISCONNECTED=4900]="DISCONNECTED";m[m.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(H||={});async function Y(D=3000){return new Promise((g,b)=>{let U=!1,f=()=>{if(U)return;if(U=!0,window.removeEventListener("tronlink#initialized",f),clearTimeout(_),window.tronLink)g(window.tronLink);else b(new I("wallet_provider_not_found",{wallet:P.TRONLINK}))};if(window.tronLink){f();return}window.addEventListener("tronlink#initialized",f,{once:!0});let _=setTimeout(f,D)})}async function J(D,g){if(D!==V.Tron)throw new I("wallet_chain_not_supported",{wallet:P.TRONLINK,chain:D});let b=await Y();try{let E=await b.request({method:"tron_requestAccounts"});if(E.code!==200)throw new Error(`TronLink error: ${E.message}`)}catch(E){let m=E;if(m.code===4001)throw new I("wallet_connection_rejected_by_user");if(m.code===4100)throw new I("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new I("wallet_provider_not_found",{wallet:P.TRONLINK,message:m.message||"Failed to connect to TronLink"})}let U=b.tronWeb.defaultAddress?.base58;if(!U)throw new I("wallet_provider_not_found",{wallet:P.TRONLINK,message:"No account found in TronLink"});if(g)$(g);return{...await X({signer:{getAddress:async()=>U,signTransaction:async(E)=>{return await b.tronWeb.trx.sign(E)}}}),address:U}}function T(D,g){let b=(U)=>{if(U.data?.message?.action==="setAccount"){let f=U.data.message.data.address;if(D)D(f);else window.location.reload()}if(U.data?.message?.action==="setNode"){let f=U.data.message.data.node;if(g)g(f.fullNode);else window.location.reload()}};return window.addEventListener("message",b),()=>window.removeEventListener("message",b)}function $(D){let g=window.tronLink;if(!g)throw new I("wallet_provider_not_found",{wallet:P.TRONLINK});let b=g.tronWeb.fullNode?.host;if(b&&!b.includes(D))throw new I("wallet_failed_to_add_or_switch_network",{wallet:P.TRONLINK,message:`Wrong network. Please switch to ${D} in TronLink.`,currentNetwork:b,expectedNetwork:D})}function Z(D=!1){return D?"shasta":"api.trongrid.io"}var O=A({name:"connectTronLink",walletType:M.TRONLINK,supportedChains:[B.Tron],connect:({addChain:D,supportedChains:g,walletType:b})=>async function U(f){if(S({chains:f,supportedChains:g,walletType:b}).length===0)throw new Error("TronLink wallet only supports Tron chain");let E=Z(!1),m=await J(B.Tron,E),z=m.address,G=T((q)=>{if(q!==z)window.location.reload()},(q)=>{if(!q.includes(E))window.location.reload()}),Q=()=>{G()};return D({...m,chain:B.Tron,balance:[],disconnect:Q,walletType:b}),!0}}),L=F(O);export{Y as waitForTronLink,$ as verifyNetwork,O as tronlinkWallet,T as setupEventListeners,J as getWalletForChain,Z as getExpectedTronNetwork,H as TronLinkResponseCode,L as TRONLINK_SUPPORTED_CHAINS};
1
+ import"../../chunk-yqaz2d25.js";import{Chain as E,WalletOption as M,filterSupportedChains as F}from"@swapkit/helpers";import{createWallet as O,getWalletSupportedChains as S}from"@swapkit/wallet-core";import{Chain as V,SwapKitError as I,WalletOption as _}from"@swapkit/helpers";import{createTronToolbox as X}from"@swapkit/toolboxes/tron";var H;((D)=>{D[D.SUCCESS=200]="SUCCESS";D[D.LOCKED=4000]="LOCKED";D[D.REJECTED=4001]="REJECTED";D[D.UNAUTHORIZED=4100]="UNAUTHORIZED";D[D.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";D[D.DISCONNECTED=4900]="DISCONNECTED";D[D.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(H||={});async function Y(m=3000){return new Promise((g,b)=>{let U=!1,f=()=>{if(U)return;if(U=!0,window.removeEventListener("tronlink#initialized",f),q)clearTimeout(q);if(window.tronLink)g(window.tronLink);else b(new I("wallet_provider_not_found",{wallet:_.TRONLINK}))};if(window.tronLink){g(window.tronLink);return}window.addEventListener("tronlink#initialized",f,{once:!0});let q=setTimeout(f,m)})}async function J(m,g){if(m!==V.Tron)throw new I("wallet_chain_not_supported",{wallet:_.TRONLINK,chain:m});let b=await Y();if(!b.ready)throw new I("wallet_locked",{wallet:_.TRONLINK,message:"TronLink is locked. Please unlock it to continue."});try{let P=await b.request({method:"tron_requestAccounts"});if(P.code!==200)throw new Error(`TronLink error: ${P.message}`)}catch(P){let D=P;if(D.code===4001)throw new I("wallet_connection_rejected_by_user");if(D.code===4100)throw new I("wallet_connection_rejected_by_user",{message:"Unauthorized: Please authorize the connection in TronLink"});throw new I("wallet_provider_not_found",{wallet:_.TRONLINK,message:D.message||"Failed to connect to TronLink"})}let U=b.tronWeb.defaultAddress?.base58;if(!U)throw new I("wallet_provider_not_found",{wallet:_.TRONLINK,message:"No account found in TronLink"});if(g)$(g);return{...await X({signer:{getAddress:async()=>U,signTransaction:async(P)=>{return await b.tronWeb.trx.sign(P)}}}),address:U}}function T(m,g){let b=(U)=>{if(U.data?.message?.action==="setAccount"){let f=U.data.message.data.address;if(m)m(f);else window.location.reload()}if(U.data?.message?.action==="setNode"){let f=U.data.message.data.node;if(g)g(f.fullNode);else window.location.reload()}};return window.addEventListener("message",b),()=>window.removeEventListener("message",b)}function $(m){let g=window.tronLink;if(!g)throw new I("wallet_provider_not_found",{wallet:_.TRONLINK});let b=g.tronWeb.fullNode?.host;if(b&&!b.includes(m))throw new I("wallet_failed_to_add_or_switch_network",{wallet:_.TRONLINK,message:`Wrong network. Please switch to ${m} in TronLink.`,currentNetwork:b,expectedNetwork:m})}function Z(m=!1){return m?"shasta":"api.trongrid.io"}var A=O({name:"connectTronLink",walletType:M.TRONLINK,supportedChains:[E.Tron],connect:({addChain:m,supportedChains:g,walletType:b})=>async function U(f){if(F({chains:f,supportedChains:g,walletType:b}).length===0)throw new Error("TronLink wallet only supports Tron chain");let P=Z(!1),D=await J(E.Tron,P),z=D.address,G=T((B)=>{if(B!==z)window.location.reload()},(B)=>{if(!B.includes(P))window.location.reload()}),Q=()=>{G()};return m({...D,chain:E.Tron,balance:[],disconnect:Q,walletType:b}),!0}}),L=S(A);export{Y as waitForTronLink,$ as verifyNetwork,A as tronlinkWallet,T as setupEventListeners,J as getWalletForChain,Z as getExpectedTronNetwork,H as TronLinkResponseCode,L as TRONLINK_SUPPORTED_CHAINS};
2
2
 
3
- //# debugId=FEA7366F0071C68664756E2164756E21
3
+ //# debugId=2C5C49ED8892E7FB64756E2164756E21
4
4
  //# sourceMappingURL=index.js.map