@swapkit/wallets 4.1.18 → 4.1.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/bitget/index.cjs +2 -2
- package/dist/src/bitget/index.cjs.map +3 -3
- package/dist/src/bitget/index.js +2 -2
- package/dist/src/bitget/index.js.map +3 -3
- package/dist/src/coinbase/index.cjs +2 -2
- package/dist/src/coinbase/index.cjs.map +3 -3
- package/dist/src/coinbase/index.js +2 -2
- package/dist/src/coinbase/index.js.map +3 -3
- package/dist/src/cosmostation/index.cjs +2 -2
- package/dist/src/cosmostation/index.cjs.map +3 -3
- package/dist/src/cosmostation/index.js +2 -2
- package/dist/src/cosmostation/index.js.map +3 -3
- package/dist/src/ctrl/index.cjs +2 -2
- package/dist/src/ctrl/index.cjs.map +4 -4
- package/dist/src/ctrl/index.js +2 -2
- package/dist/src/ctrl/index.js.map +4 -4
- package/dist/src/evm-extensions/index.cjs +2 -2
- package/dist/src/evm-extensions/index.cjs.map +3 -3
- package/dist/src/evm-extensions/index.js +2 -2
- package/dist/src/evm-extensions/index.js.map +3 -3
- package/dist/src/keepkey-bex/index.cjs +2 -2
- package/dist/src/keepkey-bex/index.cjs.map +3 -3
- package/dist/src/keepkey-bex/index.js +2 -2
- package/dist/src/keepkey-bex/index.js.map +3 -3
- package/dist/src/keplr/index.cjs +2 -2
- package/dist/src/keplr/index.cjs.map +4 -4
- package/dist/src/keplr/index.js +2 -2
- package/dist/src/keplr/index.js.map +4 -4
- package/dist/src/okx/index.cjs +2 -2
- package/dist/src/okx/index.cjs.map +3 -3
- package/dist/src/okx/index.js +2 -2
- package/dist/src/okx/index.js.map +3 -3
- package/dist/src/vultisig/index.cjs +2 -2
- package/dist/src/vultisig/index.cjs.map +4 -4
- package/dist/src/vultisig/index.js +2 -2
- package/dist/src/vultisig/index.js.map +4 -4
- package/dist/src/walletconnect/index.cjs.map +2 -2
- package/dist/src/walletconnect/index.js.map +2 -2
- package/dist/types/bitget/helpers.d.ts +10 -10
- package/dist/types/bitget/helpers.d.ts.map +1 -1
- package/dist/types/coinbase/index.d.ts.map +1 -1
- package/dist/types/coinbase/signer.d.ts +8 -8
- package/dist/types/coinbase/signer.d.ts.map +1 -1
- package/dist/types/cosmostation/index.d.ts.map +1 -1
- package/dist/types/ctrl/walletHelpers.d.ts +2 -2
- package/dist/types/ctrl/walletHelpers.d.ts.map +1 -1
- package/dist/types/evm-extensions/index.d.ts +7 -7
- package/dist/types/evm-extensions/index.d.ts.map +1 -1
- package/dist/types/keepkey-bex/index.d.ts.map +1 -1
- package/dist/types/keplr/index.d.ts.map +1 -1
- package/dist/types/okx/helpers.d.ts +5 -5
- package/dist/types/okx/helpers.d.ts.map +1 -1
- package/dist/types/vultisig/index.d.ts.map +1 -1
- package/dist/types/vultisig/walletHelpers.d.ts +4 -4
- package/dist/types/vultisig/walletHelpers.d.ts.map +1 -1
- package/dist/types/walletconnect/helpers.d.ts +2 -2
- package/dist/types/walletconnect/helpers.d.ts.map +1 -1
- package/package.json +8 -8
package/dist/src/keplr/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as
|
|
1
|
+
import{F as E,G as f}from"../../chunk-fxqrst6z.js";import{Chain as o,ChainId as i,filterSupportedChains as I,SwapKitError as t,WalletOption as h}from"@swapkit/helpers";import{createWallet as y,getWalletSupportedChains as x}from"@swapkit/wallet-core";import{ChainId as s}from"@swapkit/helpers";var p=new Map([[s.KUJI,{bech32Config:{bech32PrefixAccAddr:"kujira",bech32PrefixAccPub:"kujirapub",bech32PrefixConsAddr:"kujiravalcons",bech32PrefixConsPub:"kujiravalconspub",bech32PrefixValAddr:"kujiravaloper",bech32PrefixValPub:"kujiravaloperpub"},bip44:{coinType:118},chainId:"kaiyo-1",chainName:"Kujira",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png",currencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"bKUJI",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png",coinMinimalDenom:"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji"},{coinDecimals:6,coinDenom:"AQLA",coinGeckoId:"aqualibre",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png",coinMinimalDenom:"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"},{coinDecimals:6,coinDenom:"USK",coinGeckoId:"usk",coinMinimalDenom:"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk"},{coinDecimals:6,coinDenom:"axlUSDC",coinGeckoId:"usd-coin",coinMinimalDenom:"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F"},{coinDecimals:6,coinDenom:"ATOM",coinGeckoId:"cosmos",coinMinimalDenom:"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2"},{coinDecimals:6,coinDenom:"OSMO",coinGeckoId:"osmosis",coinMinimalDenom:"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23"},{coinDecimals:6,coinDenom:"CMDX",coinGeckoId:"comdex",coinMinimalDenom:"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07"},{coinDecimals:6,coinDenom:"EVMOS",coinGeckoId:"evmos",coinMinimalDenom:"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10"},{coinDecimals:6,coinDenom:"JUNO",coinGeckoId:"juno-network",coinMinimalDenom:"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5"},{coinDecimals:6,coinDenom:"MNTA",coinGeckoId:"mantadao",coinMinimalDenom:"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta"},{coinDecimals:6,coinDenom:"SCRT",coinGeckoId:"secret",coinMinimalDenom:"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5"},{coinDecimals:6,coinDenom:"STARS",coinGeckoId:"stargaze",coinMinimalDenom:"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602"},{coinDecimals:18,coinDenom:"wAVAX",coinGeckoId:"avalanche-2",coinMinimalDenom:"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2"},{coinDecimals:18,coinDenom:"wETH",coinGeckoId:"ethereum",coinMinimalDenom:"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7"}],nodeProvider:{email:"pfc-validator@protonmail.com",name:"PFC",website:"https://pfc.zone/"},rest:"https://rest.cosmos.directory/kujira/",rpc:"https://kujira-rpc.nodes.defiantlabs.net",stakeCurrency:{coinDecimals:6,coinDenom:"KUJI",coinGeckoId:"kujira",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png",coinMinimalDenom:"ukuji"}}],[s.NOBLE,{bech32Config:{bech32PrefixAccAddr:"noble",bech32PrefixAccPub:"noblepub",bech32PrefixConsAddr:"noblevalcons",bech32PrefixConsPub:"noblevalconspub",bech32PrefixValAddr:"noblevaloper",bech32PrefixValPub:"noblevaloperpub"},bip44:{coinType:118},chainId:"noble-1",chainName:"Noble",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png",currencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"uusdn"}],features:["cosmwasm"],feeCurrencies:[{coinDecimals:6,coinDenom:"USDC",coinGeckoId:"usd-coin",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png",coinMinimalDenom:"uusdc"},{coinDecimals:6,coinDenom:"USDN",coinGeckoId:"usd-coin",coinMinimalDenom:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png"}],rest:"https://lcd-noble.keplr.app",rpc:"https://rpc-noble.keplr.app"}],[s.THOR,{bech32Config:{bech32PrefixAccAddr:"thor",bech32PrefixAccPub:"thorpub",bech32PrefixConsAddr:"thorvalcons",bech32PrefixConsPub:"thorvalconspub",bech32PrefixValAddr:"thorvaloper",bech32PrefixValPub:"thorvaloperpub"},bip44:{coinType:931},chainId:"thorchain-1",chainName:"THORChain",chainSymbolImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png",currencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune"}],features:[],feeCurrencies:[{coinDecimals:8,coinDenom:"RUNE",coinGeckoId:"thorchain",coinImageUrl:"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png",coinMinimalDenom:"rune",gasPriceStep:{average:0.02,high:0.03,low:0.02}}],rest:"https://lcd-thorchain.keplr.app",rpc:"https://rpc-thorchain.keplr.app"}]]);var F=[i.GAIA,i.KUJI,i.NOBLE,i.THOR],w=y({connect:({addChain:u,supportedChains:D})=>async function(d,c=h.KEPLR){let k=c===h.LEAP?"leap":"keplr",g=I({chains:d,supportedChains:D,walletType:c}),a=window[k];return await Promise.all(g.map(async(n)=>{let e=i[n];if(!F.includes(e)){let l=p.get(e);if(!l)throw new t("wallet_keplr_chain_not_supported",{chain:n});await a.experimentalSuggestChain(l)}a?.enable(e);let r=a?.getOfflineSignerOnlyAmino(e);if(!r)throw new t("wallet_keplr_signer_not_found");let{getCosmosToolbox:b}=await import("@swapkit/toolboxes/cosmos"),m=await r.getAccounts();if(!m?.[0]?.address)throw new t("wallet_keplr_no_accounts");let[{address:C}]=m,A=await b(n,{signer:r});u({...A,address:C,chain:n,walletType:c})})),!0},name:"connectKeplr",supportedChains:[o.Cosmos,o.Kujira,o.Noble,o.THORChain]}),G=x(w);export{w as keplrWallet,G as KEPLR_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=5DAF1B60B583606764756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/keplr/index.ts", "../src/keplr/chainRegistry.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import { Chain, ChainId,
|
|
6
|
-
"import type { ChainInfo } from \"@keplr-wallet/types\";\nimport { ChainId } from \"@swapkit/helpers\";\n\nexport const chainRegistry = new Map<ChainId, ChainInfo>([\n [\n ChainId.
|
|
5
|
+
"import { Chain, ChainId, filterSupportedChains, SwapKitError, WalletOption } from \"@swapkit/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { chainRegistry } from \"./chainRegistry\";\n\nconst keplrSupportedChainIds = [ChainId.GAIA, ChainId.KUJI, ChainId.NOBLE, ChainId.THOR] as const;\n\nexport const keplrWallet = createWallet({\n connect: ({ addChain, supportedChains }) =>\n async function connectKeplr(\n chains: Chain[],\n walletType: WalletOption.KEPLR | WalletOption.LEAP = WalletOption.KEPLR,\n ) {\n const extensionKey = walletType === WalletOption.LEAP ? \"leap\" : \"keplr\";\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n const keplrClient = window[extensionKey];\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const chainId = ChainId[chain] as (typeof keplrSupportedChainIds)[number];\n\n if (!keplrSupportedChainIds.includes(chainId)) {\n const chainConfig = chainRegistry.get(chainId);\n if (!chainConfig) throw new SwapKitError(\"wallet_keplr_chain_not_supported\", { chain });\n\n await keplrClient.experimentalSuggestChain(chainConfig);\n }\n\n keplrClient?.enable(chainId);\n const signer = keplrClient?.getOfflineSignerOnlyAmino(chainId);\n if (!signer) throw new SwapKitError(\"wallet_keplr_signer_not_found\");\n\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n\n const accounts = await signer.getAccounts();\n if (!accounts?.[0]?.address) throw new SwapKitError(\"wallet_keplr_no_accounts\");\n\n const [{ address }] = accounts;\n const toolbox = await getCosmosToolbox(chain, { signer });\n\n addChain({ ...toolbox, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectKeplr\",\n supportedChains: [Chain.Cosmos, Chain.Kujira, Chain.Noble, Chain.THORChain],\n});\n\nexport const KEPLR_SUPPORTED_CHAINS = getWalletSupportedChains(keplrWallet);\n",
|
|
6
|
+
"import type { ChainInfo } from \"@keplr-wallet/types\";\nimport { ChainId } from \"@swapkit/helpers\";\n\nexport const chainRegistry = new Map<ChainId, ChainInfo>([\n [\n ChainId.KUJI,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"kujira\",\n bech32PrefixAccPub: \"kujirapub\",\n bech32PrefixConsAddr: \"kujiravalcons\",\n bech32PrefixConsPub: \"kujiravalconspub\",\n bech32PrefixValAddr: \"kujiravaloper\",\n bech32PrefixValPub: \"kujiravaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"kaiyo-1\",\n chainName: \"Kujira\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"bKUJI\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/bKUJI.png\",\n coinMinimalDenom: \"factory/kujira15e8q5wzlk5k38gjxlhse3vu6vqnafysncx2ltexd6y9gx50vuj2qpt7dgv/boneKuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"AQLA\",\n coinGeckoId: \"aqualibre\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/AQLA.png\",\n coinMinimalDenom: \"factory/kujira1xe0awk5planmtsmjel5xtx2hzhqdw5p8z66yqd/uaqla\",\n },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USK\",\n coinGeckoId: \"usk\",\n coinMinimalDenom: \"factory/kujira1qk00h5atutpsv900x202pxx42npjr9thg58dnqpa72f2p7m2luase444a7/uusk\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"axlUSDC\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom: \"ibc/295548A78785A1007F232DE286149A6FF512F180AF5657780FC89C009E2C348F\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"ATOM\",\n coinGeckoId: \"cosmos\",\n coinMinimalDenom: \"ibc/27394FB092D2ECCD56123C74F36E4C1F926001CEADA9CA97EA622B25F41E5EB2\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"OSMO\",\n coinGeckoId: \"osmosis\",\n coinMinimalDenom: \"ibc/47BD209179859CDE4A2806763D7189B6E6FE13A17880FE2B42DE1E6C1E329E23\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"CMDX\",\n coinGeckoId: \"comdex\",\n coinMinimalDenom: \"ibc/3607EB5B5E64DD1C0E12E07F077FF470D5BC4706AFCBC98FE1BA960E5AE4CE07\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"EVMOS\",\n coinGeckoId: \"evmos\",\n coinMinimalDenom: \"ibc/F3AA7EF362EC5E791FE78A0F4CCC69FEE1F9A7485EB1A8CAB3F6601C00522F10\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"JUNO\",\n coinGeckoId: \"juno-network\",\n coinMinimalDenom: \"ibc/EFF323CC632EC4F747C61BCE238A758EFDB7699C3226565F7C20DA06509D59A5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"MNTA\",\n coinGeckoId: \"mantadao\",\n coinMinimalDenom: \"factory/kujira1643jxg8wasy5cfcn7xm8rd742yeazcksqlg4d7/umnta\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"SCRT\",\n coinGeckoId: \"secret\",\n coinMinimalDenom: \"ibc/A358D7F19237777AF6D8AD0E0F53268F8B18AE8A53ED318095C14D6D7F3B2DB5\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"STARS\",\n coinGeckoId: \"stargaze\",\n coinMinimalDenom: \"ibc/4F393C3FCA4190C0A6756CE7F6D897D5D1BE57D6CCB80D0BC87393566A7B6602\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wAVAX\",\n coinGeckoId: \"avalanche-2\",\n coinMinimalDenom: \"ibc/004EBF085BBED1029326D56BE8A2E67C08CECE670A94AC1947DF413EF5130EB2\",\n },\n {\n coinDecimals: 18,\n coinDenom: \"wETH\",\n coinGeckoId: \"ethereum\",\n coinMinimalDenom: \"ibc/1B38805B1C75352B28169284F96DF56BDEBD9E8FAC005BDCC8CF0378C82AA8E7\",\n },\n ],\n nodeProvider: { email: \"pfc-validator@protonmail.com\", name: \"PFC\", website: \"https://pfc.zone/\" },\n rest: \"https://rest.cosmos.directory/kujira/\",\n rpc: \"https://kujira-rpc.nodes.defiantlabs.net\",\n stakeCurrency: {\n coinDecimals: 6,\n coinDenom: \"KUJI\",\n coinGeckoId: \"kujira\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/kaiyo/ukuji.png\",\n coinMinimalDenom: \"ukuji\",\n },\n },\n ],\n [\n ChainId.NOBLE,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"noble\",\n bech32PrefixAccPub: \"noblepub\",\n bech32PrefixConsAddr: \"noblevalcons\",\n bech32PrefixConsPub: \"noblevalconspub\",\n bech32PrefixValAddr: \"noblevaloper\",\n bech32PrefixValPub: \"noblevaloperpub\",\n },\n bip44: { coinType: 118 },\n chainId: \"noble-1\",\n chainName: \"Noble\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/chain.png\",\n currencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n { coinDecimals: 6, coinDenom: \"USDN\", coinGeckoId: \"usd-coin\", coinMinimalDenom: \"uusdn\" },\n ],\n features: [\"cosmwasm\"],\n feeCurrencies: [\n {\n coinDecimals: 6,\n coinDenom: \"USDC\",\n coinGeckoId: \"usd-coin\",\n coinImageUrl: \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdc.png\",\n coinMinimalDenom: \"uusdc\",\n },\n {\n coinDecimals: 6,\n coinDenom: \"USDN\",\n coinGeckoId: \"usd-coin\",\n coinMinimalDenom:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/noble/uusdn.png\",\n },\n ],\n rest: \"https://lcd-noble.keplr.app\",\n rpc: \"https://rpc-noble.keplr.app\",\n },\n ],\n [\n ChainId.THOR,\n {\n bech32Config: {\n bech32PrefixAccAddr: \"thor\",\n bech32PrefixAccPub: \"thorpub\",\n bech32PrefixConsAddr: \"thorvalcons\",\n bech32PrefixConsPub: \"thorvalconspub\",\n bech32PrefixValAddr: \"thorvaloper\",\n bech32PrefixValPub: \"thorvaloperpub\",\n },\n bip44: { coinType: 931 },\n chainId: \"thorchain-1\",\n chainName: \"THORChain\",\n chainSymbolImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/chain.png\",\n currencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n },\n ],\n features: [],\n feeCurrencies: [\n {\n coinDecimals: 8,\n coinDenom: \"RUNE\",\n coinGeckoId: \"thorchain\",\n coinImageUrl:\n \"https://raw.githubusercontent.com/chainapsis/keplr-chain-registry/main/images/thorchain/rune.png\",\n coinMinimalDenom: \"rune\",\n gasPriceStep: { average: 0.02, high: 0.03, low: 0.02 },\n },\n ],\n rest: \"https://lcd-thorchain.keplr.app\",\n rpc: \"https://rpc-thorchain.keplr.app\",\n },\n ],\n]);\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "mDAAA,gBAAS,aAAO,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "mDAAA,gBAAS,aAAO,2BAAS,kBAAuB,kBAAc,yBAC9D,uBAAS,8BAAc,6BCAvB,kBAAS,yBAEF,IAAM,EAAgB,IAAI,IAAwB,CACvD,CACE,EAAQ,KACR,CACE,aAAc,CACZ,oBAAqB,SACrB,mBAAoB,YACpB,qBAAsB,gBACtB,oBAAqB,mBACrB,oBAAqB,gBACrB,mBAAoB,kBACtB,EACA,MAAO,CAAE,SAAU,GAAI,EACvB,QAAS,UACT,UAAW,SACX,oBACE,gGACF,WAAY,CACV,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,aACE,0KACF,iBAAkB,oFACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,YACb,aACE,qJACF,iBAAkB,6DACpB,CACF,EACA,SAAU,CAAC,UAAU,EACrB,cAAe,CACb,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,aAAc,gGACd,iBAAkB,OACpB,EACA,CACE,aAAc,EACd,UAAW,MACX,YAAa,MACb,iBAAkB,gFACpB,EACA,CACE,aAAc,EACd,UAAW,UACX,YAAa,WACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,UACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAAa,QACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,eACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,WACb,iBAAkB,6DACpB,EACA,CACE,aAAc,EACd,UAAW,OACX,YAAa,SACb,iBAAkB,sEACpB,EACA,CACE,aAAc,EACd,UAAW,QACX,YAAa,WACb,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",
|
|
9
|
+
"debugId": "5DAF1B60B583606764756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
package/dist/src/okx/index.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var N={};J(N,{okxWallet:()=>Z,OKX_SUPPORTED_CHAINS:()=>R});module.exports=F(N);var y=require("@swapkit/helpers"),M=require("@swapkit/wallet-core");var O=require("@swapkit/helpers"),Q=require("bitcoinjs-lib"),j=(f)=>async({recipient:m,assetValue:G,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.
|
|
1
|
+
var N={};J(N,{okxWallet:()=>Z,OKX_SUPPORTED_CHAINS:()=>R});module.exports=F(N);var y=require("@swapkit/helpers"),M=require("@swapkit/wallet-core");var O=require("@swapkit/helpers"),Q=require("bitcoinjs-lib"),j=(f)=>async({recipient:m,assetValue:G,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.GAIA),D=await O.getRPCUrl(O.Chain.Cosmos),z=await A(D,X),H=[{amount:G.getBaseValue("string"),denom:G?.symbol==="MUON"?"umuon":"uatom"}],{transactionHash:$}=await z.sendTokens(f,m,H,1.6,_);return $};async function q({walletProvider:f,chain:m}){let{getEvmToolbox:G}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:_}=await import("ethers");if(!f)throw new O.SwapKitError("wallet_okx_not_found");let A=new _(f,"any"),B=await A.getSigner(),X=await G(m,{provider:A,signer:B});try{if(m!==O.Chain.Ethereum&&"getNetworkParams"in X)await O.switchEVMWalletNetwork(A,m,X.getNetworkParams())}catch(D){throw new O.SwapKitError("wallet_okx_failed_to_switch_network",{chain:m})}return O.prepareNetworkSwitch({chain:m,provider:A,toolbox:X})}async function Y(f){let{match:m,P:G}=await import("ts-pattern");return m(f).with(G.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:f});let _=await q({chain:f,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={getAddress:async()=>Promise.resolve(B),signTransaction:async(z)=>{let H=await A.signPsbt(z.toHex(),{from:B,type:"list"});return Q.Psbt.fromHex(H)}};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.GAIA);let B=await _.getOfflineSignerOnlyAmino(O.ChainId.GAIA).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:D}]=B;return{...await X(O.Chain.Cosmos),address:D,transfer:j(D)}}).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-t3m5498m.js"),{getNearToolbox:A}=await import("@swapkit/toolboxes/near"),B=window.okxwallet.near,X=await _(B,"OKX"),D=await X.getAddress();return{...await A({signer:X}),address:D}}).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:f})})}var Z=M.createWallet({connect:({addChain:f,supportedChains:m,walletType:G})=>async function(A){let B=y.filterSupportedChains({chains:A,supportedChains:m,walletType:G});return await Promise.all(B.map(async(X)=>{let D=await Y(X);f({...D,chain:X,walletType:G})})),!0},name:"connectOkx",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],walletType:y.WalletOption.OKX}),R=M.getWalletSupportedChains(Z);
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=5A3D2306E7FA6B2164756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\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 name: \"connectOkx\",\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 walletType: WalletOption.OKX,\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
|
|
6
|
-
"import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\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.
|
|
6
|
+
"import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\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.GAIA);\n\n const rpcUrl = await getRPCUrl(Chain.Cosmos);\n const cosmJS = await createSigningStargateClient(rpcUrl, offlineSigner);\n\n const coins = [\n { amount: assetValue.getBaseValue(\"string\"), denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\" },\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}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\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({ chain, provider, toolbox });\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({ chain: chain as EVMChain, walletProvider: window.okxwallet });\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 getAddress: async () => Promise.resolve(address),\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { from: address, type: \"list\" });\n\n return Psbt.fromHex(signedPsbt);\n },\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.GAIA);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.GAIA);\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": "+EAA2D,IAA3D,8BAEA,kCCOO,IATP,8BAYA,2BAGM,EACJ,CAAC,IACD,OAAS,YAAW,aAAY,UAAkC,CAChE,GAAI,EAAE,OAAO,YAAa,UAAW,OAAO,YAC1C,MAAM,IAAI,eAAa,uBAAwB,CAAE,MAAO,QAAM,MAAO,CAAC,EAExE,IAAQ,+BAAgC,KAAa,sCAE7C,MAAO,GAAW,OAAO,UAC3B,EAAgB,GAAQ,0BAA0B,UAAQ,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "5A3D2306E7FA6B2164756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
package/dist/src/okx/index.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as z,G as H}from"../../chunk-fxqrst6z.js";import{Chain as _,filterSupportedChains as U,WalletOption as I}from"@swapkit/helpers";import{createWallet as L,getWalletSupportedChains as T}from"@swapkit/wallet-core";import{Chain as O,ChainId as Y,getRPCUrl as j,prepareNetworkSwitch as q,SwapKitError as G,switchEVMWalletNetwork as F}from"@swapkit/helpers";import{Psbt as J}from"bitcoinjs-lib";var R=(f)=>async({recipient:m,assetValue:W,memo:X})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new G("wallet_okx_not_found",{chain:O.Cosmos});let{createSigningStargateClient:A}=await import("@swapkit/toolboxes/cosmos"),{keplr:B}=window.okxwallet,y=B?.getOfflineSignerOnlyAmino(Y.
|
|
1
|
+
import{F as z,G as H}from"../../chunk-fxqrst6z.js";import{Chain as _,filterSupportedChains as U,WalletOption as I}from"@swapkit/helpers";import{createWallet as L,getWalletSupportedChains as T}from"@swapkit/wallet-core";import{Chain as O,ChainId as Y,getRPCUrl as j,prepareNetworkSwitch as q,SwapKitError as G,switchEVMWalletNetwork as F}from"@swapkit/helpers";import{Psbt as J}from"bitcoinjs-lib";var R=(f)=>async({recipient:m,assetValue:W,memo:X})=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new G("wallet_okx_not_found",{chain:O.Cosmos});let{createSigningStargateClient:A}=await import("@swapkit/toolboxes/cosmos"),{keplr:B}=window.okxwallet,y=B?.getOfflineSignerOnlyAmino(Y.GAIA),D=await j(O.Cosmos),M=await A(D,y),Q=[{amount:W.getBaseValue("string"),denom:W?.symbol==="MUON"?"umuon":"uatom"}],{transactionHash:$}=await M.sendTokens(f,m,Q,1.6,X);return $};async function N({walletProvider:f,chain:m}){let{getEvmToolbox:W}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:X}=await import("ethers");if(!f)throw new G("wallet_okx_not_found");let A=new X(f,"any"),B=await A.getSigner(),y=await W(m,{provider:A,signer:B});try{if(m!==O.Ethereum&&"getNetworkParams"in y)await F(A,m,y.getNetworkParams())}catch(D){throw new G("wallet_okx_failed_to_switch_network",{chain:m})}return q({chain:m,provider:A,toolbox:y})}async function Z(f){let{match:m,P:W}=await import("ts-pattern");return m(f).with(W.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 G("wallet_okx_not_found",{chain:f});let X=await N({chain:f,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 G("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={getAddress:async()=>Promise.resolve(B),signTransaction:async(M)=>{let Q=await A.signPsbt(M.toHex(),{from:B,type:"list"});return J.fromHex(Q)}};return{...await X(O.Bitcoin,{signer:y}),address:B}}).with(O.Cosmos,async()=>{if(!(window.okxwallet&&("keplr"in window.okxwallet)))throw new G("wallet_okx_not_found",{chain:O.Cosmos});let{keplr:X}=window.okxwallet;await X.enable(Y.GAIA);let B=await X.getOfflineSignerOnlyAmino(Y.GAIA).getAccounts();if(!(B&&Array.isArray(B))||B.length===0)throw new G("wallet_okx_no_accounts",{chain:O.Cosmos,message:"No Cosmos accounts returned from OKX Wallet"});let{getCosmosToolbox:y}=await import("@swapkit/toolboxes/cosmos"),[{address:D}]=B;return{...await y(O.Cosmos),address:D,transfer:R(D)}}).with(O.Near,async()=>{if(!(window.okxwallet&&("near"in window.okxwallet)))throw new G("wallet_okx_not_found",{chain:O.Near});let{createNearSignerFromProvider:X}=await import("../../chunk-dtr1yvx8.js"),{getNearToolbox:A}=await import("@swapkit/toolboxes/near"),B=window.okxwallet.near,y=await X(B,"OKX"),D=await y.getAddress();return{...await A({signer:y}),address:D}}).with(O.Tron,async()=>{if(!(window.okxwallet&&("tronLink"in window.okxwallet)))throw new G("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 G("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 G("wallet_okx_chain_not_supported",{chain:f})})}var V=L({connect:({addChain:f,supportedChains:m,walletType:W})=>async function(A){let B=U({chains:A,supportedChains:m,walletType:W});return await Promise.all(B.map(async(y)=>{let D=await Z(y);f({...D,chain:y,walletType:W})})),!0},name:"connectOkx",supportedChains:[_.Arbitrum,_.Aurora,_.Avalanche,_.Base,_.Berachain,_.BinanceSmartChain,_.Bitcoin,_.Cosmos,_.Ethereum,_.Gnosis,_.Near,_.Optimism,_.Polygon,_.Tron],walletType:I.OKX}),S=T(V);export{V as okxWallet,S as OKX_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=AD755FADCDF9A47B64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
"sources": ["../src/okx/index.ts", "../src/okx/helpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import { Chain, filterSupportedChains, WalletOption } from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport { getWalletMethods } from \"./helpers\";\n\nexport const okxWallet = createWallet({\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 name: \"connectOkx\",\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 walletType: WalletOption.OKX,\n});\n\nexport const OKX_SUPPORTED_CHAINS = getWalletSupportedChains(okxWallet);\n",
|
|
6
|
-
"import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\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.
|
|
6
|
+
"import {\n Chain,\n ChainId,\n type EVMChain,\n type GenericTransferParams,\n getRPCUrl,\n prepareNetworkSwitch,\n SwapKitError,\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.GAIA);\n\n const rpcUrl = await getRPCUrl(Chain.Cosmos);\n const cosmJS = await createSigningStargateClient(rpcUrl, offlineSigner);\n\n const coins = [\n { amount: assetValue.getBaseValue(\"string\"), denom: assetValue?.symbol === \"MUON\" ? \"umuon\" : \"uatom\" },\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}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\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({ chain, provider, toolbox });\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({ chain: chain as EVMChain, walletProvider: window.okxwallet });\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 getAddress: async () => Promise.resolve(address),\n signTransaction: async (psbt: InstanceType<typeof Psbt>) => {\n const signedPsbt = await wallet.signPsbt(psbt.toHex(), { from: address, type: \"list\" });\n\n return Psbt.fromHex(signedPsbt);\n },\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.GAIA);\n const offlineSigner = wallet.getOfflineSignerOnlyAmino(ChainId.GAIA);\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": "mDAAA,gBAAS,2BAAO,kBAAuB,yBAEvC,uBAAS,8BAAc,6BCFvB,gBACE,aACA,eAGA,0BACA,kBACA,4BACA,yBAIF,eAAS,sBAGT,IAAM,EACJ,CAAC,IACD,OAAS,YAAW,aAAY,UAAkC,CAChE,GAAI,EAAE,OAAO,YAAa,UAAW,OAAO,YAC1C,MAAM,IAAI,EAAa,uBAAwB,CAAE,MAAO,EAAM,MAAO,CAAC,EAExE,IAAQ,+BAAgC,KAAa,sCAE7C,MAAO,GAAW,OAAO,UAC3B,EAAgB,GAAQ,0BAA0B,EAAQ,
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "AD755FADCDF9A47B64756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var v={};x(v,{vultisigWallet:()=>A,VULTISIG_SUPPORTED_CHAINS:()=>g});module.exports=b(v);var z=require("@swapkit/helpers"),O=require("@swapkit/wallet-core");var F=require("@swapkit/helpers"),N=require("@swapkit/helpers/contracts");async function
|
|
1
|
+
var v={};x(v,{vultisigWallet:()=>A,VULTISIG_SUPPORTED_CHAINS:()=>g});module.exports=b(v);var z=require("@swapkit/helpers"),O=require("@swapkit/wallet-core");var F=require("@swapkit/helpers"),N=require("@swapkit/helpers/contracts");async function I(D){if(!window.vultisig)throw new F.SwapKitError("wallet_vultisig_not_found");let{match:$}=await import("ts-pattern");return $(D).with(...F.EVMChains,()=>window.vultisig?.ethereum).with(F.Chain.Cosmos,F.Chain.Kujira,()=>window.vultisig?.cosmos).with(F.Chain.Bitcoin,()=>window.vultisig?.bitcoin).with(F.Chain.BitcoinCash,()=>window.vultisig?.bitcoincash).with(F.Chain.Dash,()=>window.vultisig?.dash).with(F.Chain.Dogecoin,()=>window.vultisig?.dogecoin).with(F.Chain.Litecoin,()=>window.vultisig?.litecoin).with(F.Chain.Solana,()=>window.vultisig?.solana).with(F.Chain.THORChain,()=>window.vultisig?.thorchain).with(F.Chain.Maya,()=>window.vultisig?.mayachain).with(F.Chain.Polkadot,()=>window.vultisig?.polkadot).with(F.Chain.Ripple,()=>window.vultisig?.ripple).with(F.Chain.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function P({method:D,params:$,chain:J}){let Q=await I(J),Z=$;if(J===F.Chain.Cosmos||J===F.Chain.Kujira||J===F.Chain.Ripple)Z=$.map((q)=>({data:q.data,from:q.from,to:q.to,value:q.amount.amount.toString()}));return new Promise((q,G)=>{if(Q&&"request"in Q)Q.request({method:D,params:Z},(Y,H)=>{Y?G(Y):q(H)})})}async function y(D){try{let $=await I(D);if(!$)throw new F.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}});if([F.Chain.Cosmos,F.Chain.Kujira].includes(D)){let Q=F.ChainId[D];await $.request({method:"wallet_switch_chain",params:[{chainId:Q}]});let Z=await $.request({method:"get_accounts"});if(!Z)Z=(await $.request({method:"request_accounts"}))[0].address;return Z}if(F.EVMChains.includes(D)){let{BrowserProvider:Q}=await import("ethers"),Z=new Q($,"any"),[q]=await F.providerRequest({method:"eth_requestAccounts",params:[],provider:Z});return q}if(D===F.Chain.Solana)return(await(await I(F.Chain.Solana)).connect()).publicKey.toString();return(await $.request({method:"request_accounts",params:[]}))[0]}catch($){throw new F.SwapKitError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}})}}async function _({assetValue:D,recipient:$,memo:J,gasLimit:Q},Z="send_transaction"){if(!D)throw new F.SwapKitError("wallet_vultisig_asset_not_defined");let q=await y(D.chain),G=[{amount:{amount:D.getBaseValue("number"),decimals:D.decimal},asset:{chain:D.chain,symbol:D.symbol.toUpperCase(),ticker:D.symbol.toUpperCase()},data:J||"",from:q,gasLimit:Q,to:$}];return P({chain:D.chain,method:Z,params:G})}function S(D,$){return{approve:async({assetAddress:J,spenderAddress:Q,amount:Z,from:q})=>{let{MAX_APPROVAL:G,getCreateContractTxObject:Y}=await import("@swapkit/toolboxes/evm"),H=[Q,BigInt(Z||G)],U={abi:N.erc20ABI,contractAddress:J,funcName:"approve",funcParams:H,txOverrides:{from:q}},R=Y({chain:$,provider:D}),{value:L,to:j,data:K}=await R(U);return(await(await D.getSigner()).sendTransaction({data:K||"0x",from:q,to:j,value:BigInt(L||0)})).hash},call:async({contractAddress:J,abi:Q,funcName:Z,funcParams:q=[],txOverrides:G})=>{if(!J)throw new F.SwapKitError("wallet_vultisig_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:H,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:Q,funcName:Z})){let j=H({chain:$,provider:D}),{value:K,from:M,to:E,data:T}=await j({abi:Q,contractAddress:J,funcName:Z,funcParams:q,txOverrides:G});return(await(await D.getSigner()).sendTransaction({data:T||"0x",from:M,to:E,value:BigInt(K||0)})).hash}let L=await Y(J,Q,D)[Z]?.(...q);return typeof L?.hash==="string"?L?.hash:L},sendTransaction:async(J)=>{let{from:Q,to:Z,data:q,value:G}=J;if(!Z)throw new F.SwapKitError("wallet_vultisig_send_transaction_no_address");return(await(await D.getSigner()).sendTransaction({data:q||"0x",from:Q,to:Z,value:BigInt(G||0)})).hash}}}async function V(D,$,J){try{await D.request({method:"wallet_switch_chain",params:[{chainId:F.getChainConfig($).chainId}]})}catch(Q){if(!J)throw new F.SwapKitError("helpers_failed_to_switch_network",{error:Q,reason:"networkParams not provided"})}}function f(D,$,J){return async(...Q)=>{try{await V($,J)}catch(Z){throw new F.SwapKitError({errorKey:"helpers_failed_to_switch_network",info:{error:Z}})}return D(...Q)}}function k({toolbox:D,chain:$,provider:J=window.ethereum,methodNames:Q=[]}){let q=[...Q,"transfer","getAddress","getBalance"].reduce((G,Y)=>{if(!D[Y])return G;let H=D[Y];if(typeof H!=="function")return G;let X=f(H,J,$);return{...G,[Y]:X}},{});return{...D,...q}}var A=O.createWallet({connect:({addChain:D,walletType:$,supportedChains:J})=>async function(Z){let q=z.filterSupportedChains({chains:Z,supportedChains:J,walletType:$}),G=q.filter((X)=>X!==z.Chain.Cosmos&&X!==z.Chain.Kujira).map(async(X)=>{let U=await y(X),R=await W(X);D({...R,address:U,chain:X,walletType:$})}),Y=q.includes(z.Chain.Cosmos),H=q.includes(z.Chain.Kujira);if(Y){let X=await y(z.Chain.Cosmos),U=await W(z.Chain.Cosmos);D({...U,address:X,chain:z.Chain.Cosmos,walletType:$})}if(H){let X=await y(z.Chain.Kujira),U=await W(z.Chain.Kujira);D({...U,address:X,chain:z.Chain.Kujira,walletType:$})}return await Promise.all(G),!0},name:"connectVultisig",supportedChains:[z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Bitcoin,z.Chain.BitcoinCash,z.Chain.Cosmos,z.Chain.Dash,z.Chain.Dogecoin,z.Chain.Ethereum,z.Chain.Kujira,z.Chain.Litecoin,z.Chain.Maya,z.Chain.Optimism,z.Chain.Polkadot,z.Chain.Polygon,z.Chain.Ripple,z.Chain.Solana,z.Chain.THORChain,z.Chain.Zcash],walletType:z.WalletOption.VULTISIG}),g=O.getWalletSupportedChains(A);async function W(D){let{match:$}=await import("ts-pattern");return $(D).with(z.Chain.Solana,async()=>{let{getSolanaToolbox:J}=await import("@swapkit/toolboxes/solana"),Q=window.vultisig?.solana;if(!Q)throw new z.SwapKitError("wallet_vultisig_not_found");return{...await J({signer:Q})}}).with(z.Chain.Maya,z.Chain.THORChain,async()=>{let{getCosmosToolbox:J,THORCHAIN_GAS_VALUE:Q,MAYA_GAS_VALUE:Z}=await import("@swapkit/toolboxes/cosmos"),q=D===z.Chain.Maya?Z:Q;return{...await J(D),deposit:(Y)=>_({...Y,recipient:""},"deposit_transaction"),transfer:(Y)=>_({...Y,gasLimit:q},"send_transaction")}}).with(z.Chain.Cosmos,z.Chain.Kujira,async()=>{let{getCosmosToolbox:J}=await import("@swapkit/toolboxes/cosmos"),Q=await I(D),Z=await J(D);return k({chain:D,provider:Q,toolbox:{...Z,transfer:_}})}).with(...z.UTXOChains,async()=>{let{getUtxoToolbox:J}=await import("@swapkit/toolboxes/utxo");return{...await J(D),transfer:_}}).with(z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Ethereum,z.Chain.Optimism,z.Chain.Polygon,async()=>{let{prepareNetworkSwitch:J,switchEVMWalletNetwork:Q}=await import("@swapkit/helpers"),{getEvmToolbox:Z}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:q}=await import("ethers"),G=await I(D);if(!G)throw new z.SwapKitError("wallet_vultisig_not_found");let Y=new q(G,"any"),H=await Y.getSigner(),X=await Z(D,{provider:Y,signer:H}),U=S(Y,D);try{if(D!==z.Chain.Ethereum){let R=X.getNetworkParams();await Q(Y,D,R)}}catch(R){throw new z.SwapKitError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:D,wallet:z.WalletOption.VULTISIG}})}return J({chain:D,provider:Y,toolbox:{...X,...U}})}).with(z.Chain.Ripple,async()=>{let{getRippleToolbox:J}=await import("@swapkit/toolboxes/ripple");return{...await J(),transfer:_}}).with(z.Chain.Polkadot,async()=>{let{getSubstrateToolbox:J}=await import("@swapkit/toolboxes/substrate");return{...await J(D),transfer:_}}).otherwise(async()=>null)}
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=F314AE2A0E4B604D64756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -2,10 +2,10 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../src/vultisig/index.ts", "../src/vultisig/walletHelpers.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
|
-
"import {\n Chain,\n type EVMChain,\n filterSupportedChains,\n type GenericTransferParams,\n SwapKitError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n} from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n getVultisigAddress,\n getVultisigMethods,\n getVultisigProvider,\n prepareNetworkSwitchCosmos,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const vultisigWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectVultisig(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains\n .filter((chain) => chain !== Chain.Cosmos && chain !== Chain.Kujira)\n .map(async (chain) => {\n const address = await getVultisigAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n const cosmosIncluded = filteredChains.includes(Chain.Cosmos);\n const kujiraIncluded = filteredChains.includes(Chain.Kujira);\n\n // Race condition single cosmos provider exposed.\n if (cosmosIncluded) {\n const addressCosmos = await getVultisigAddress(Chain.Cosmos);\n const walletMethodsCosmos = await getWalletMethods(Chain.Cosmos);\n addChain({ ...walletMethodsCosmos, address: addressCosmos, chain: Chain.Cosmos, walletType });\n }\n if (kujiraIncluded) {\n const addressKujira = await getVultisigAddress(Chain.Kujira);\n const walletMethodsKujira = await getWalletMethods(Chain.Kujira);\n addChain({ ...walletMethodsKujira, address: addressKujira, chain: Chain.Kujira, walletType });\n }\n //--//\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectVultisig\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.Zcash,\n ],\n walletType: WalletOption.VULTISIG,\n});\n\nexport const VULTISIG_SUPPORTED_CHAINS = getWalletSupportedChains(vultisigWallet);\n\nasync function getWalletMethods(chain: (typeof VULTISIG_SUPPORTED_CHAINS)[number]) {\n const { match } = await import(\"ts-pattern\");\n return match(chain)\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n return { ...toolbox };\n })\n\n .with(Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as
|
|
6
|
-
"import {\n type AssetValue,\n Chain,\n ChainToChainId,\n type EVMChain,\n EVMChains,\n type FeeOption,\n type NetworkParams,\n providerRequest,\n SwapKitError,\n type UTXOChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport type { VultisigCosmosProvider } from \"../types\";\n\ntype TransactionMethod = \"send_transaction\" | \"deposit_transaction\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n to: string;\n data?: string;\n from?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype VultisigProviderType<T> = T extends Chain.Solana\n ? SolanaProvider\n : T extends Chain.Cosmos | Chain.Kujira\n ? VultisigCosmosProvider\n : T extends EVMChain\n ? Eip1193Provider\n : T extends Chain.Maya | Chain.THORChain | Chain.Ripple | Chain.Polkadot | UTXOChain\n ? Eip1193Provider\n : undefined;\n\nexport async function getVultisigProvider<T extends Chain>(chain: T): Promise<VultisigProviderType<T>> {\n if (!window.vultisig) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .with(...EVMChains, () => window.vultisig?.ethereum as Eip1193Provider)\n .with(Chain.Cosmos, Chain.Kujira, () => window.vultisig?.cosmos as VultisigCosmosProvider)\n .with(Chain.Bitcoin, () => window.vultisig?.bitcoin as Eip1193Provider)\n .with(Chain.BitcoinCash, () => window.vultisig?.bitcoincash as Eip1193Provider)\n .with(Chain.Dash, () => window.vultisig?.dash as Eip1193Provider)\n .with(Chain.Dogecoin, () => window.vultisig?.dogecoin as Eip1193Provider)\n .with(Chain.Litecoin, () => window.vultisig?.litecoin as Eip1193Provider)\n .with(Chain.Solana, () => window.vultisig?.solana as SolanaProvider)\n .with(Chain.THORChain, () => window.vultisig?.thorchain as Eip1193Provider)\n .with(Chain.Maya, () => window.vultisig?.mayachain as Eip1193Provider)\n .with(Chain.Polkadot, () => window.vultisig?.polkadot as Eip1193Provider)\n .with(Chain.Ripple, () => window.vultisig?.ripple as Eip1193Provider)\n .with(Chain.Zcash, () => window.vultisig?.zcash as Eip1193Provider)\n .otherwise(() => undefined) as VultisigProviderType<T>;\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getVultisigProvider(chain);\n let finalParams: TransactionParams[] | { from: string; to?: string; value: string; data?: string }[] = params;\n\n if (chain === Chain.Cosmos || chain === Chain.Kujira || chain === Chain.Ripple) {\n finalParams = params.map((p) => ({\n data: p.data as string,\n from: p.from as string,\n to: p.to as string,\n value: (p.amount as { amount: number; decimals?: number }).amount.toString(),\n }));\n }\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params: finalParams }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getVultisigAddress(chain: Chain) {\n try {\n const eipProvider = (await getVultisigProvider(chain)) as Eip1193Provider;\n if (!eipProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain)) {\n const provider = await getVultisigProvider(Chain.Cosmos);\n const chainId = ChainToChainId[chain];\n\n await provider.request({ method: \"wallet_switch_chain\", params: [{ chainId }] });\n\n let account = await provider.request({ method: \"get_accounts\" });\n if (!account) {\n const connectedAcount = await provider.request({ method: \"request_accounts\" });\n account = connectedAcount[0].address;\n }\n return account;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n if (\"request\" in eipProvider && typeof eipProvider.request === \"function\") {\n const accounts = await eipProvider.request({ method: \"eth_requestAccounts\" });\n return accounts[0];\n }\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(eipProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const provider = await getVultisigProvider(Chain.Solana);\n\n const accounts = await provider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await eipProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"send_transaction\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_vultisig_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getVultisigAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n data: memo || \"\",\n from,\n gasLimit,\n to: recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n\nexport function getVultisigMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n abi: erc20ABI,\n contractAddress: assetAddress,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n call: async <T>({ contractAddress, abi, funcName, funcParams = [], txOverrides }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, from, to, data } = await createTx({ abi, contractAddress, funcName, funcParams, txOverrides });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_vultisig_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n };\n}\n\nexport async function switchCosmosWalletNetwork(\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n networkParams?: NetworkParams,\n) {\n try {\n await provider.request({ method: \"wallet_switch_chain\", params: [{ chainId: ChainToChainId[chain] }] });\n } catch (error) {\n if (!networkParams) {\n throw new SwapKitError(\"helpers_failed_to_switch_network\", {\n error: error,\n reason: \"networkParams not provided\",\n });\n }\n }\n}\n\nexport function wrapMethodWithNetworkSwitch<T extends (...args: any[]) => any>(\n func: T,\n provider: VultisigCosmosProvider,\n chain: Chain.Cosmos | Chain.Kujira,\n) {\n return (async (...args: any[]) => {\n try {\n await switchCosmosWalletNetwork(provider, chain);\n } catch (error) {\n throw new SwapKitError({ errorKey: \"helpers_failed_to_switch_network\", info: { error } });\n }\n return func(...args);\n }) as unknown as T;\n}\n\nexport function prepareNetworkSwitchCosmos<T extends Awaited<ReturnType<typeof getCosmosToolbox>>, M extends keyof T>({\n toolbox,\n chain,\n provider = window.ethereum,\n methodNames = [],\n}: {\n toolbox: T;\n chain: Chain;\n provider?: VultisigCosmosProvider;\n methodNames?: M[];\n}) {\n const methodsToWrap = [...methodNames, \"transfer\", \"getAddress\", \"getBalance\"] as M[];\n const wrappedMethods = methodsToWrap.reduce((object, methodName) => {\n if (!toolbox[methodName]) return object;\n\n const method = toolbox[methodName];\n\n if (typeof method !== \"function\") return object;\n\n // @ts-expect-error\n const wrappedMethod = wrapMethodWithNetworkSwitch(method, provider, chain);\n\n // biome-ignore lint/performance/noAccumulatingSpread: valid use case\n return { ...object, [methodName]: wrappedMethod };\n }, {});\n\n return { ...toolbox, ...wrappedMethods };\n}\n"
|
|
5
|
+
"import {\n Chain,\n type CosmosChain,\n type EVMChain,\n filterSupportedChains,\n type GenericTransferParams,\n type SubstrateChain,\n SwapKitError,\n type TCLikeChain,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n} from \"@swapkit/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@swapkit/wallet-core\";\nimport {\n getVultisigAddress,\n getVultisigMethods,\n getVultisigProvider,\n prepareNetworkSwitchCosmos,\n walletTransfer,\n} from \"./walletHelpers\";\n\nexport const vultisigWallet = createWallet({\n connect: ({ addChain, walletType, supportedChains }) =>\n async function connectVultisig(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n const promises = filteredChains\n .filter((chain) => chain !== Chain.Cosmos && chain !== Chain.Kujira)\n .map(async (chain) => {\n const address = await getVultisigAddress(chain);\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n });\n\n const cosmosIncluded = filteredChains.includes(Chain.Cosmos);\n const kujiraIncluded = filteredChains.includes(Chain.Kujira);\n\n // Race condition single cosmos provider exposed.\n if (cosmosIncluded) {\n const addressCosmos = await getVultisigAddress(Chain.Cosmos);\n const walletMethodsCosmos = await getWalletMethods(Chain.Cosmos);\n addChain({ ...walletMethodsCosmos, address: addressCosmos, chain: Chain.Cosmos, walletType });\n }\n if (kujiraIncluded) {\n const addressKujira = await getVultisigAddress(Chain.Kujira);\n const walletMethodsKujira = await getWalletMethods(Chain.Kujira);\n addChain({ ...walletMethodsKujira, address: addressKujira, chain: Chain.Kujira, walletType });\n }\n //--//\n\n await Promise.all(promises);\n\n return true;\n },\n name: \"connectVultisig\",\n supportedChains: [\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Bitcoin,\n Chain.BitcoinCash,\n Chain.Cosmos,\n Chain.Dash,\n Chain.Dogecoin,\n Chain.Ethereum,\n Chain.Kujira,\n Chain.Litecoin,\n Chain.Maya,\n Chain.Optimism,\n Chain.Polkadot,\n Chain.Polygon,\n Chain.Ripple,\n Chain.Solana,\n Chain.THORChain,\n Chain.Zcash,\n ],\n walletType: WalletOption.VULTISIG,\n});\n\nexport const VULTISIG_SUPPORTED_CHAINS = getWalletSupportedChains(vultisigWallet);\n\nasync function getWalletMethods(chain: (typeof VULTISIG_SUPPORTED_CHAINS)[number]) {\n const { match } = await import(\"ts-pattern\");\n return match(chain)\n .with(Chain.Solana, async () => {\n const { getSolanaToolbox } = await import(\"@swapkit/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const toolbox = await getSolanaToolbox({ signer: solanaProvider });\n return { ...toolbox };\n })\n\n .with(Chain.Maya, Chain.THORChain, async () => {\n const { getCosmosToolbox, THORCHAIN_GAS_VALUE, MAYA_GAS_VALUE } = await import(\"@swapkit/toolboxes/cosmos\");\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain>);\n return {\n ...toolbox,\n deposit: (tx: GenericTransferParams) => walletTransfer({ ...tx, recipient: \"\" }, \"deposit_transaction\"),\n transfer: (tx: GenericTransferParams) => walletTransfer({ ...tx, gasLimit }, \"send_transaction\"),\n };\n })\n\n .with(Chain.Cosmos, Chain.Kujira, async () => {\n const { getCosmosToolbox } = await import(\"@swapkit/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Exclude<CosmosChain, TCLikeChain>);\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain>);\n return prepareNetworkSwitchCosmos({ chain, provider, toolbox: { ...toolbox, transfer: walletTransfer } });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@swapkit/toolboxes/utxo\");\n const toolbox = await getUtxoToolbox(chain as UTXOChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.BinanceSmartChain,\n Chain.Ethereum,\n Chain.Optimism,\n Chain.Polygon,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@swapkit/helpers\");\n const { getEvmToolbox } = await import(\"@swapkit/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new SwapKitError(\"wallet_vultisig_not_found\");\n }\n\n const provider = new BrowserProvider(ethereumWindowProvider, \"any\");\n const signer = await provider.getSigner();\n const toolbox = await getEvmToolbox(chain as EVMChain, { provider, signer });\n const vultisigMethods = getVultisigMethods(provider, chain as EVMChain);\n\n try {\n if (chain !== Chain.Ethereum) {\n const networkParams = toolbox.getNetworkParams();\n await switchEVMWalletNetwork(provider, chain, networkParams);\n }\n } catch (_error) {\n throw new SwapKitError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.VULTISIG },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox: { ...toolbox, ...vultisigMethods } });\n },\n )\n\n .with(Chain.Ripple, async () => {\n const { getRippleToolbox } = await import(\"@swapkit/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@swapkit/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as SubstrateChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
|
|
6
|
+
"import {\n type AssetValue,\n Chain,\n ChainId,\n type CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n getChainConfig,\n type NetworkParams,\n providerRequest,\n SwapKitError,\n type UTXOChain,\n WalletOption,\n} from \"@swapkit/helpers\";\nimport { erc20ABI } from \"@swapkit/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@swapkit/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@swapkit/toolboxes/evm\";\nimport type { SolanaProvider } from \"@swapkit/toolboxes/solana\";\nimport type { BrowserProvider, Eip1193Provider } from \"ethers\";\nimport type { VultisigCosmosProvider } from \"../types\";\n\ntype TransactionMethod = \"send_transaction\" | \"deposit_transaction\";\n\ntype TransactionParams = {\n asset: string | { chain: string; symbol: string; ticker: string };\n amount: number | string | { amount: number; decimals?: number };\n decimal?: number;\n to: string;\n data?: string;\n from?: string;\n};\n\nexport type WalletTxParams = {\n feeOptionKey?: FeeOption;\n from?: string;\n memo?: string;\n recipient: string;\n assetValue: AssetValue;\n gasLimit?: string | bigint;\n};\n\ntype VultisigProviderType<T> = T extends typeof Chain.Solana\n ? SolanaProvider\n : T extends Exclude<CosmosChain, typeof Chain.Noble>\n ? VultisigCosmosProvider\n : T extends EVMChain\n ? Eip1193Provider\n : T extends typeof Chain.Maya | typeof Chain.THORChain | typeof Chain.Ripple | typeof Chain.Polkadot | UTXOChain\n ? Eip1193Provider\n : undefined;\n\nexport async function getVultisigProvider<T extends Chain>(chain: T): Promise<VultisigProviderType<T>> {\n if (!window.vultisig) throw new SwapKitError(\"wallet_vultisig_not_found\");\n const { match } = await import(\"ts-pattern\");\n\n return match(chain as Chain)\n .with(...EVMChains, () => window.vultisig?.ethereum as Eip1193Provider)\n .with(Chain.Cosmos, Chain.Kujira, () => window.vultisig?.cosmos as VultisigCosmosProvider)\n .with(Chain.Bitcoin, () => window.vultisig?.bitcoin as Eip1193Provider)\n .with(Chain.BitcoinCash, () => window.vultisig?.bitcoincash as Eip1193Provider)\n .with(Chain.Dash, () => window.vultisig?.dash as Eip1193Provider)\n .with(Chain.Dogecoin, () => window.vultisig?.dogecoin as Eip1193Provider)\n .with(Chain.Litecoin, () => window.vultisig?.litecoin as Eip1193Provider)\n .with(Chain.Solana, () => window.vultisig?.solana as SolanaProvider)\n .with(Chain.THORChain, () => window.vultisig?.thorchain as Eip1193Provider)\n .with(Chain.Maya, () => window.vultisig?.mayachain as Eip1193Provider)\n .with(Chain.Polkadot, () => window.vultisig?.polkadot as Eip1193Provider)\n .with(Chain.Ripple, () => window.vultisig?.ripple as Eip1193Provider)\n .with(Chain.Zcash, () => window.vultisig?.zcash as Eip1193Provider)\n .otherwise(() => undefined) as VultisigProviderType<T>;\n}\n\nasync function transaction({\n method,\n params,\n chain,\n}: {\n method: TransactionMethod;\n params: TransactionParams[];\n chain: Chain;\n}): Promise<string> {\n const client = await getVultisigProvider(chain);\n let finalParams: TransactionParams[] | { from: string; to?: string; value: string; data?: string }[] = params;\n\n if (chain === Chain.Cosmos || chain === Chain.Kujira || chain === Chain.Ripple) {\n finalParams = params.map((p) => ({\n data: p.data as string,\n from: p.from as string,\n to: p.to as string,\n value: (p.amount as { amount: number; decimals?: number }).amount.toString(),\n }));\n }\n\n return new Promise<string>((resolve, reject) => {\n if (client && \"request\" in client) {\n // @ts-expect-error\n client.request({ method, params: finalParams }, (err: string, tx: string) => {\n err ? reject(err) : resolve(tx);\n });\n }\n });\n}\n\nexport async function getVultisigAddress(chain: Chain) {\n try {\n const windowProvider = (await getVultisigProvider(chain)) as Eip1193Provider;\n if (!windowProvider) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n\n if ([Chain.Cosmos, Chain.Kujira].includes(chain as typeof Chain.Cosmos)) {\n const chainId = ChainId[chain];\n\n await windowProvider.request({ method: \"wallet_switch_chain\", params: [{ chainId }] });\n\n let account = await windowProvider.request({ method: \"get_accounts\" });\n if (!account) {\n const connectedAcount = await windowProvider.request({ method: \"request_accounts\" });\n account = connectedAcount[0].address;\n }\n return account;\n }\n\n if (EVMChains.includes(chain as EVMChain)) {\n const { BrowserProvider } = await import(\"ethers\");\n const provider = new BrowserProvider(windowProvider, \"any\");\n const [response] = await providerRequest({ method: \"eth_requestAccounts\", params: [], provider });\n return response;\n }\n\n if (chain === Chain.Solana) {\n const solanaProvider = await getVultisigProvider(Chain.Solana);\n\n const accounts = await solanaProvider.connect();\n return accounts.publicKey.toString();\n }\n\n const accounts = await windowProvider.request({ method: \"request_accounts\", params: [] });\n return accounts[0];\n } catch (_error) {\n throw new SwapKitError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.VULTISIG } });\n }\n}\n\nexport async function walletTransfer(\n { assetValue, recipient, memo, gasLimit }: WalletTxParams,\n method: TransactionMethod = \"send_transaction\",\n) {\n if (!assetValue) {\n throw new SwapKitError(\"wallet_vultisig_asset_not_defined\");\n }\n\n /**\n * EVM requires amount to be hex string\n * UTXO/Cosmos requires amount to be number\n */\n\n const from = await getVultisigAddress(assetValue.chain);\n const params = [\n {\n amount: { amount: assetValue.getBaseValue(\"number\"), decimals: assetValue.decimal },\n asset: {\n chain: assetValue.chain,\n symbol: assetValue.symbol.toUpperCase(),\n ticker: assetValue.symbol.toUpperCase(),\n },\n data: memo || \"\",\n from,\n gasLimit,\n to: recipient,\n },\n ];\n\n return transaction({ chain: assetValue.chain, method, params });\n}\n\nexport function getVultisigMethods(provider: BrowserProvider, chain: EVMChain) {\n return {\n approve: async ({ assetAddress, spenderAddress, amount, from }: ApproveParams) => {\n const { MAX_APPROVAL, getCreateContractTxObject } = await import(\"@swapkit/toolboxes/evm\");\n const funcParams = [spenderAddress, BigInt(amount || MAX_APPROVAL)];\n const txOverrides = { from };\n\n const functionCallParams = {\n abi: erc20ABI,\n contractAddress: assetAddress,\n funcName: \"approve\",\n funcParams,\n txOverrides,\n };\n\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, to, data } = await createTx(functionCallParams);\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n call: async <T>({ contractAddress, abi, funcName, funcParams = [], txOverrides }: CallParams): Promise<T> => {\n if (!contractAddress) {\n throw new SwapKitError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\"@swapkit/toolboxes/evm\");\n\n const isStateChanging = isStateChangingCall({ abi, funcName });\n\n if (isStateChanging) {\n const createTx = getCreateContractTxObject({ chain, provider });\n const { value, from, to, data } = await createTx({ abi, contractAddress, funcName, funcParams, txOverrides });\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash as T;\n }\n const contract = createContract(contractAddress, abi, provider);\n\n const result = await contract[funcName]?.(...funcParams);\n\n return typeof result?.hash === \"string\" ? result?.hash : result;\n },\n sendTransaction: async (txParams: EVMTxParams) => {\n const { from, to, data, value } = txParams;\n if (!to) {\n throw new SwapKitError(\"wallet_vultisig_send_transaction_no_address\");\n }\n\n const signer = await provider.getSigner();\n const tx = await signer.sendTransaction({ data: data || \"0x\", from, to, value: BigInt(value || 0) });\n return tx.hash;\n },\n };\n}\n\nexport async function switchCosmosWalletNetwork(\n provider: VultisigCosmosProvider,\n chain: Exclude<CosmosChain, typeof Chain.Noble>,\n networkParams?: NetworkParams,\n) {\n try {\n await provider.request({ method: \"wallet_switch_chain\", params: [{ chainId: getChainConfig(chain).chainId }] });\n } catch (error) {\n if (!networkParams) {\n throw new SwapKitError(\"helpers_failed_to_switch_network\", {\n error: error,\n reason: \"networkParams not provided\",\n });\n }\n }\n}\n\nexport function wrapMethodWithNetworkSwitch<T extends (...args: any[]) => any>(\n func: T,\n provider: VultisigCosmosProvider,\n chain: Exclude<CosmosChain, typeof Chain.Noble>,\n) {\n return (async (...args: any[]) => {\n try {\n await switchCosmosWalletNetwork(provider, chain);\n } catch (error) {\n throw new SwapKitError({ errorKey: \"helpers_failed_to_switch_network\", info: { error } });\n }\n return func(...args);\n }) as unknown as T;\n}\n\nexport function prepareNetworkSwitchCosmos<T extends Awaited<ReturnType<typeof getCosmosToolbox>>, M extends keyof T>({\n toolbox,\n chain,\n provider = window.ethereum,\n methodNames = [],\n}: {\n toolbox: T;\n chain: Chain;\n provider?: VultisigCosmosProvider;\n methodNames?: M[];\n}) {\n const methodsToWrap = [...methodNames, \"transfer\", \"getAddress\", \"getBalance\"] as M[];\n const wrappedMethods = methodsToWrap.reduce((object, methodName) => {\n if (!toolbox[methodName]) return object;\n\n const method = toolbox[methodName];\n\n if (typeof method !== \"function\") return object;\n\n // @ts-expect-error\n const wrappedMethod = wrapMethodWithNetworkSwitch(method, provider, chain);\n\n // biome-ignore lint/performance/noAccumulatingSpread: valid use case\n return { ...object, [methodName]: wrappedMethod };\n }, {});\n\n return { ...toolbox, ...wrappedMethods };\n}\n"
|
|
7
7
|
],
|
|
8
|
-
"mappings": "
|
|
9
|
-
"debugId": "
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "F314AE2A0E4B604D64756E2164756E21",
|
|
10
10
|
"names": []
|
|
11
11
|
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import{F as B,G as H}from"../../chunk-fxqrst6z.js";import{Chain as D,filterSupportedChains as
|
|
1
|
+
import{F as B,G as H}from"../../chunk-fxqrst6z.js";import{Chain as D,filterSupportedChains as C,SwapKitError as M,UTXOChains as p,WalletOption as V}from"@swapkit/helpers";import{createWallet as d,getWalletSupportedChains as l}from"@swapkit/wallet-core";import{Chain as Y,ChainId as b,EVMChains as A,getChainConfig as x,providerRequest as g,SwapKitError as _,WalletOption as k}from"@swapkit/helpers";import{erc20ABI as v}from"@swapkit/helpers/contracts";async function y(z){if(!window.vultisig)throw new _("wallet_vultisig_not_found");let{match:Z}=await import("ts-pattern");return Z(z).with(...A,()=>window.vultisig?.ethereum).with(Y.Cosmos,Y.Kujira,()=>window.vultisig?.cosmos).with(Y.Bitcoin,()=>window.vultisig?.bitcoin).with(Y.BitcoinCash,()=>window.vultisig?.bitcoincash).with(Y.Dash,()=>window.vultisig?.dash).with(Y.Dogecoin,()=>window.vultisig?.dogecoin).with(Y.Litecoin,()=>window.vultisig?.litecoin).with(Y.Solana,()=>window.vultisig?.solana).with(Y.THORChain,()=>window.vultisig?.thorchain).with(Y.Maya,()=>window.vultisig?.mayachain).with(Y.Polkadot,()=>window.vultisig?.polkadot).with(Y.Ripple,()=>window.vultisig?.ripple).with(Y.Zcash,()=>window.vultisig?.zcash).otherwise(()=>{return})}async function u({method:z,params:Z,chain:F}){let J=await y(F),Q=Z;if(F===Y.Cosmos||F===Y.Kujira||F===Y.Ripple)Q=Z.map(($)=>({data:$.data,from:$.from,to:$.to,value:$.amount.amount.toString()}));return new Promise(($,G)=>{if(J&&"request"in J)J.request({method:z,params:Q},(q,U)=>{q?G(q):$(U)})})}async function j(z){try{let Z=await y(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:k.VULTISIG}});if([Y.Cosmos,Y.Kujira].includes(z)){let J=b[z];await Z.request({method:"wallet_switch_chain",params:[{chainId:J}]});let Q=await Z.request({method:"get_accounts"});if(!Q)Q=(await Z.request({method:"request_accounts"}))[0].address;return Q}if(A.includes(z)){let{BrowserProvider:J}=await import("ethers"),Q=new J(Z,"any"),[$]=await g({method:"eth_requestAccounts",params:[],provider:Q});return $}if(z===Y.Solana)return(await(await y(Y.Solana)).connect()).publicKey.toString();return(await Z.request({method:"request_accounts",params:[]}))[0]}catch(Z){throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:k.VULTISIG}})}}async function L({assetValue:z,recipient:Z,memo:F,gasLimit:J},Q="send_transaction"){if(!z)throw new _("wallet_vultisig_asset_not_defined");let $=await j(z.chain),G=[{amount:{amount:z.getBaseValue("number"),decimals:z.decimal},asset:{chain:z.chain,symbol:z.symbol.toUpperCase(),ticker:z.symbol.toUpperCase()},data:F||"",from:$,gasLimit:J,to:Z}];return u({chain:z.chain,method:Q,params:G})}function T(z,Z){return{approve:async({assetAddress:F,spenderAddress:J,amount:Q,from:$})=>{let{MAX_APPROVAL:G,getCreateContractTxObject:q}=await import("@swapkit/toolboxes/evm"),U=[J,BigInt(Q||G)],R={abi:v,contractAddress:F,funcName:"approve",funcParams:U,txOverrides:{from:$}},I=q({chain:Z,provider:z}),{value:O,to:K,data:W}=await I(R);return(await(await z.getSigner()).sendTransaction({data:W||"0x",from:$,to:K,value:BigInt(O||0)})).hash},call:async({contractAddress:F,abi:J,funcName:Q,funcParams:$=[],txOverrides:G})=>{if(!F)throw new _("wallet_vultisig_contract_address_not_provided");let{createContract:q,getCreateContractTxObject:U,isStateChangingCall:X}=await import("@swapkit/toolboxes/evm");if(X({abi:J,funcName:Q})){let K=U({chain:Z,provider:z}),{value:W,from:N,to:S,data:f}=await K({abi:J,contractAddress:F,funcName:Q,funcParams:$,txOverrides:G});return(await(await z.getSigner()).sendTransaction({data:f||"0x",from:N,to:S,value:BigInt(W||0)})).hash}let O=await q(F,J,z)[Q]?.(...$);return typeof O?.hash==="string"?O?.hash:O},sendTransaction:async(F)=>{let{from:J,to:Q,data:$,value:G}=F;if(!Q)throw new _("wallet_vultisig_send_transaction_no_address");return(await(await z.getSigner()).sendTransaction({data:$||"0x",from:J,to:Q,value:BigInt(G||0)})).hash}}}async function w(z,Z,F){try{await z.request({method:"wallet_switch_chain",params:[{chainId:x(Z).chainId}]})}catch(J){if(!F)throw new _("helpers_failed_to_switch_network",{error:J,reason:"networkParams not provided"})}}function m(z,Z,F){return async(...J)=>{try{await w(Z,F)}catch(Q){throw new _({errorKey:"helpers_failed_to_switch_network",info:{error:Q}})}return z(...J)}}function P({toolbox:z,chain:Z,provider:F=window.ethereum,methodNames:J=[]}){let $=[...J,"transfer","getAddress","getBalance"].reduce((G,q)=>{if(!z[q])return G;let U=z[q];if(typeof U!=="function")return G;let X=m(U,F,Z);return{...G,[q]:X}},{});return{...z,...$}}var c=d({connect:({addChain:z,walletType:Z,supportedChains:F})=>async function(Q){let $=C({chains:Q,supportedChains:F,walletType:Z}),G=$.filter((X)=>X!==D.Cosmos&&X!==D.Kujira).map(async(X)=>{let R=await j(X),I=await E(X);z({...I,address:R,chain:X,walletType:Z})}),q=$.includes(D.Cosmos),U=$.includes(D.Kujira);if(q){let X=await j(D.Cosmos),R=await E(D.Cosmos);z({...R,address:X,chain:D.Cosmos,walletType:Z})}if(U){let X=await j(D.Kujira),R=await E(D.Kujira);z({...R,address:X,chain:D.Kujira,walletType:Z})}return await Promise.all(G),!0},name:"connectVultisig",supportedChains:[D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Bitcoin,D.BitcoinCash,D.Cosmos,D.Dash,D.Dogecoin,D.Ethereum,D.Kujira,D.Litecoin,D.Maya,D.Optimism,D.Polkadot,D.Polygon,D.Ripple,D.Solana,D.THORChain,D.Zcash],walletType:V.VULTISIG}),a=l(c);async function E(z){let{match:Z}=await import("ts-pattern");return Z(z).with(D.Solana,async()=>{let{getSolanaToolbox:F}=await import("@swapkit/toolboxes/solana"),J=window.vultisig?.solana;if(!J)throw new M("wallet_vultisig_not_found");return{...await F({signer:J})}}).with(D.Maya,D.THORChain,async()=>{let{getCosmosToolbox:F,THORCHAIN_GAS_VALUE:J,MAYA_GAS_VALUE:Q}=await import("@swapkit/toolboxes/cosmos"),$=z===D.Maya?Q:J;return{...await F(z),deposit:(q)=>L({...q,recipient:""},"deposit_transaction"),transfer:(q)=>L({...q,gasLimit:$},"send_transaction")}}).with(D.Cosmos,D.Kujira,async()=>{let{getCosmosToolbox:F}=await import("@swapkit/toolboxes/cosmos"),J=await y(z),Q=await F(z);return P({chain:z,provider:J,toolbox:{...Q,transfer:L}})}).with(...p,async()=>{let{getUtxoToolbox:F}=await import("@swapkit/toolboxes/utxo");return{...await F(z),transfer:L}}).with(D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Ethereum,D.Optimism,D.Polygon,async()=>{let{prepareNetworkSwitch:F,switchEVMWalletNetwork:J}=await import("@swapkit/helpers"),{getEvmToolbox:Q}=await import("@swapkit/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),G=await y(z);if(!G)throw new M("wallet_vultisig_not_found");let q=new $(G,"any"),U=await q.getSigner(),X=await Q(z,{provider:q,signer:U}),R=T(q,z);try{if(z!==D.Ethereum){let I=X.getNetworkParams();await J(q,z,I)}}catch(I){throw new M({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:z,wallet:V.VULTISIG}})}return F({chain:z,provider:q,toolbox:{...X,...R}})}).with(D.Ripple,async()=>{let{getRippleToolbox:F}=await import("@swapkit/toolboxes/ripple");return{...await F(),transfer:L}}).with(D.Polkadot,async()=>{let{getSubstrateToolbox:F}=await import("@swapkit/toolboxes/substrate");return{...await F(z),transfer:L}}).otherwise(async()=>null)}export{c as vultisigWallet,a as VULTISIG_SUPPORTED_CHAINS};
|
|
2
2
|
|
|
3
|
-
//# debugId=
|
|
3
|
+
//# debugId=92CC6136B3F8F33164756E2164756E21
|
|
4
4
|
//# sourceMappingURL=index.js.map
|