@tcswap/wallet-extensions 4.1.16
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/chunk-7y3ffnf3.js +4 -0
- package/dist/chunk-7y3ffnf3.js.map +10 -0
- package/dist/chunk-fazw0jvt.js +4 -0
- package/dist/chunk-fazw0jvt.js.map +9 -0
- package/dist/chunk-kx2thqhk.js +5 -0
- package/dist/chunk-kx2thqhk.js.map +9 -0
- package/dist/chunk-swh9jwp7.js +4 -0
- package/dist/chunk-swh9jwp7.js.map +10 -0
- package/dist/src/bitget/index.cjs +4 -0
- package/dist/src/bitget/index.cjs.map +11 -0
- package/dist/src/bitget/index.js +4 -0
- package/dist/src/bitget/index.js.map +11 -0
- package/dist/src/cosmostation/index.cjs +4 -0
- package/dist/src/cosmostation/index.cjs.map +10 -0
- package/dist/src/cosmostation/index.js +4 -0
- package/dist/src/cosmostation/index.js.map +10 -0
- package/dist/src/ctrl/index.cjs +4 -0
- package/dist/src/ctrl/index.cjs.map +11 -0
- package/dist/src/ctrl/index.js +4 -0
- package/dist/src/ctrl/index.js.map +11 -0
- package/dist/src/evm-extensions/index.cjs +4 -0
- package/dist/src/evm-extensions/index.cjs.map +10 -0
- package/dist/src/evm-extensions/index.js +4 -0
- package/dist/src/evm-extensions/index.js.map +10 -0
- package/dist/src/index.cjs +4 -0
- package/dist/src/index.cjs.map +9 -0
- package/dist/src/index.js +3 -0
- package/dist/src/index.js.map +9 -0
- package/dist/src/keepkey-bex/index.cjs +4 -0
- package/dist/src/keepkey-bex/index.cjs.map +11 -0
- package/dist/src/keepkey-bex/index.js +4 -0
- package/dist/src/keepkey-bex/index.js.map +11 -0
- package/dist/src/keplr/index.cjs +4 -0
- package/dist/src/keplr/index.cjs.map +11 -0
- package/dist/src/keplr/index.js +4 -0
- package/dist/src/keplr/index.js.map +11 -0
- package/dist/src/okx/index.cjs +4 -0
- package/dist/src/okx/index.cjs.map +11 -0
- package/dist/src/okx/index.js +4 -0
- package/dist/src/okx/index.js.map +11 -0
- package/dist/src/onekey/index.cjs +4 -0
- package/dist/src/onekey/index.cjs.map +10 -0
- package/dist/src/onekey/index.js +4 -0
- package/dist/src/onekey/index.js.map +10 -0
- package/dist/src/phantom/index.cjs +4 -0
- package/dist/src/phantom/index.cjs.map +10 -0
- package/dist/src/phantom/index.js +4 -0
- package/dist/src/phantom/index.js.map +10 -0
- package/dist/src/polkadotjs/index.cjs +4 -0
- package/dist/src/polkadotjs/index.cjs.map +10 -0
- package/dist/src/polkadotjs/index.js +4 -0
- package/dist/src/polkadotjs/index.js.map +10 -0
- package/dist/src/talisman/index.cjs +4 -0
- package/dist/src/talisman/index.cjs.map +10 -0
- package/dist/src/talisman/index.js +4 -0
- package/dist/src/talisman/index.js.map +10 -0
- package/dist/src/tronlink/index.cjs +4 -0
- package/dist/src/tronlink/index.cjs.map +12 -0
- package/dist/src/tronlink/index.js +4 -0
- package/dist/src/tronlink/index.js.map +12 -0
- package/dist/src/vultisig/index.cjs +4 -0
- package/dist/src/vultisig/index.cjs.map +11 -0
- package/dist/src/vultisig/index.js +4 -0
- package/dist/src/vultisig/index.js.map +11 -0
- package/dist/types/bitget/helpers.d.ts +1607 -0
- package/dist/types/bitget/helpers.d.ts.map +1 -0
- package/dist/types/bitget/index.d.ts +11 -0
- package/dist/types/bitget/index.d.ts.map +1 -0
- package/dist/types/cosmostation/index.d.ts +24 -0
- package/dist/types/cosmostation/index.d.ts.map +1 -0
- package/dist/types/ctrl/index.d.ts +14 -0
- package/dist/types/ctrl/index.d.ts.map +1 -0
- package/dist/types/ctrl/walletHelpers.d.ts +23 -0
- package/dist/types/ctrl/walletHelpers.d.ts.map +1 -0
- package/dist/types/evm-extensions/index.d.ts +747 -0
- package/dist/types/evm-extensions/index.d.ts.map +1 -0
- package/dist/types/evm-extensions/types.d.ts +18 -0
- package/dist/types/evm-extensions/types.d.ts.map +1 -0
- package/dist/types/helpers/near.d.ts +60 -0
- package/dist/types/helpers/near.d.ts.map +1 -0
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/index.d.ts +14 -0
- package/dist/types/keepkey-bex/index.d.ts.map +1 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts +48 -0
- package/dist/types/keepkey-bex/walletHelpers.d.ts.map +1 -0
- package/dist/types/keplr/chainRegistry.d.ts +4 -0
- package/dist/types/keplr/chainRegistry.d.ts.map +1 -0
- package/dist/types/keplr/index.d.ts +14 -0
- package/dist/types/keplr/index.d.ts.map +1 -0
- package/dist/types/okx/helpers.d.ts +855 -0
- package/dist/types/okx/helpers.d.ts.map +1 -0
- package/dist/types/okx/index.d.ts +11 -0
- package/dist/types/okx/index.d.ts.map +1 -0
- package/dist/types/okx/types.d.ts +104 -0
- package/dist/types/okx/types.d.ts.map +1 -0
- package/dist/types/onekey/evmSigner.d.ts +32 -0
- package/dist/types/onekey/evmSigner.d.ts.map +1 -0
- package/dist/types/onekey/index.d.ts +14 -0
- package/dist/types/onekey/index.d.ts.map +1 -0
- package/dist/types/phantom/index.d.ts +15 -0
- package/dist/types/phantom/index.d.ts.map +1 -0
- package/dist/types/polkadotjs/index.d.ts +14 -0
- package/dist/types/polkadotjs/index.d.ts.map +1 -0
- package/dist/types/talisman/index.d.ts +14 -0
- package/dist/types/talisman/index.d.ts.map +1 -0
- package/dist/types/tronlink/helpers.d.ts +29 -0
- package/dist/types/tronlink/helpers.d.ts.map +1 -0
- package/dist/types/tronlink/index.d.ts +13 -0
- package/dist/types/tronlink/index.d.ts.map +1 -0
- package/dist/types/tronlink/types.d.ts +55 -0
- package/dist/types/tronlink/types.d.ts.map +1 -0
- package/dist/types/types.d.ts +166 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/vultisig/index.d.ts +14 -0
- package/dist/types/vultisig/index.d.ts.map +1 -0
- package/dist/types/vultisig/walletHelpers.d.ts +37 -0
- package/dist/types/vultisig/walletHelpers.d.ts.map +1 -0
- package/package.json +133 -0
- package/src/bitget/helpers.ts +181 -0
- package/src/bitget/index.ts +26 -0
- package/src/cosmostation/index.ts +122 -0
- package/src/ctrl/index.ts +194 -0
- package/src/ctrl/walletHelpers.ts +186 -0
- package/src/evm-extensions/index.ts +122 -0
- package/src/evm-extensions/types.ts +15 -0
- package/src/helpers/near-browser-provider.d.ts +270 -0
- package/src/helpers/near.ts +174 -0
- package/src/index.ts +1 -0
- package/src/keepkey-bex/index.ts +151 -0
- package/src/keepkey-bex/walletHelpers.ts +241 -0
- package/src/keplr/chainRegistry.ts +240 -0
- package/src/keplr/index.ts +54 -0
- package/src/okx/helpers.ts +192 -0
- package/src/okx/index.ts +43 -0
- package/src/okx/types.ts +117 -0
- package/src/onekey/evmSigner.ts +116 -0
- package/src/onekey/index.ts +182 -0
- package/src/phantom/index.ts +136 -0
- package/src/polkadotjs/index.ts +61 -0
- package/src/talisman/index.ts +132 -0
- package/src/tronlink/helpers.ts +153 -0
- package/src/tronlink/index.ts +49 -0
- package/src/tronlink/types.ts +44 -0
- package/src/types.ts +157 -0
- package/src/vultisig/index.ts +179 -0
- package/src/vultisig/walletHelpers.ts +295 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/polkadotjs/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport { Chain, filterSupportedChains, USwapError, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\n\nexport const polkadotWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectPolkadotJs(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const { address, ...walletMethods } = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, address, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectPolkadotJs\",\n supportedChains: [Chain.Polkadot],\n walletType: WalletOption.POLKADOT_JS,\n});\n\nexport const POLKADOT_SUPPORTED_CHAINS = getWalletSupportedChains(polkadotWallet);\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Polkadot: {\n const { getSubstrateToolbox } = await import(\"@tcswap/toolboxes/substrate\");\n const injectedExtension = window?.injectedWeb3?.[\"polkadot-js\"];\n\n const rawExtension = await injectedExtension?.enable?.(\"polkadot-js\");\n if (!rawExtension) {\n throw new USwapError({ errorKey: \"wallet_polkadot_not_found\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const [account] = await rawExtension.accounts.get();\n\n if (!account?.address) {\n throw new USwapError({\n errorKey: \"wallet_missing_params\",\n info: { address: account?.address, wallet: WalletOption.POLKADOT_JS },\n });\n }\n\n const address = toolbox.convertAddress(account.address, 0);\n return { ...toolbox, address, getAddress: () => address };\n }\n\n default:\n throw new USwapError({\n errorKey: \"wallet_chain_not_supported\",\n info: { chain, wallet: WalletOption.POLKADOT_JS },\n });\n }\n}\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "mDAIA,gBAAS,2BAAO,gBAAuB,kBAAY,wBACnD,uBAAS,8BAAc,4BAEhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAAgC,CAAC,EAAiB,CAChD,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAQ,aAAY,GAAkB,MAAM,EAAiB,CAAK,EAElE,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,CACH,EAEO,IAEX,KAAM,oBACN,gBAAiB,CAAC,EAAM,QAAQ,EAChC,WAAY,EAAa,WAC3B,CAAC,EAEY,EAA4B,EAAyB,CAAc,EAEhF,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,EAAM,SAAU,CACnB,IAAQ,uBAAwB,KAAa,uCAGvC,EAAe,MAFK,QAAQ,eAAe,gBAEH,SAAS,aAAa,EACpE,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGjF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,GACzE,GAAW,MAAM,EAAa,SAAS,IAAI,EAElD,GAAI,CAAC,GAAS,QACZ,MAAM,IAAI,EAAW,CACnB,SAAU,wBACV,KAAM,CAAE,QAAS,GAAS,QAAS,OAAQ,EAAa,WAAY,CACtE,CAAC,EAGH,IAAM,EAAU,EAAQ,eAAe,EAAQ,QAAS,CAAC,EACzD,MAAO,IAAK,EAAS,UAAS,WAAY,IAAM,CAAQ,CAC1D,SAGE,MAAM,IAAI,EAAW,CACnB,SAAU,6BACV,KAAM,CAAE,QAAO,OAAQ,EAAa,WAAY,CAClD,CAAC",
|
|
8
|
+
"debugId": "B46C72808543ABC464756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var _={};p(_,{talismanWallet:()=>d,TALISMAN_SUPPORTED_CHAINS:()=>f});module.exports=m(_);var t=require("@tcswap/helpers"),s=require("@tcswap/wallet-core"),d=s.createWallet({connect:({addChain:e,supportedChains:a,walletType:r})=>async function(o){let i=t.filterSupportedChains({chains:o,supportedChains:a,walletType:r});return await Promise.all(i.map(async(n)=>{let w=await u(n);e({...w,chain:n,walletType:r})})),!0},name:"connectTalisman",supportedChains:[t.Chain.Ethereum,t.Chain.Arbitrum,t.Chain.Avalanche,t.Chain.Base,t.Chain.Monad,t.Chain.Polygon,t.Chain.BinanceSmartChain,t.Chain.Optimism,t.Chain.XLayer,t.Chain.Polkadot,t.Chain.Chainflip],walletType:t.WalletOption.TALISMAN}),f=s.getWalletSupportedChains(d);async function h({walletProvider:e,chain:a}){let{getEvmToolbox:r}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:l}=await import("ethers");if(!e)throw new t.USwapError({errorKey:"wallet_provider_not_found",info:{chain:a,wallet:t.WalletOption.TALISMAN}});let o=new l(e,"any"),i=await o.getSigner(),n=await r(a,{provider:o,signer:i});try{if(a!==t.Chain.Ethereum)await t.switchEVMWalletNetwork(o,a,n.getNetworkParams())}catch{throw new t.USwapError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:a,wallet:t.WalletOption.TALISMAN}})}return t.prepareNetworkSwitch({chain:a,provider:o,toolbox:n})}async function u(e){switch(e){case t.Chain.Ethereum:case t.Chain.Arbitrum:case t.Chain.Optimism:case t.Chain.Polygon:case t.Chain.Avalanche:case t.Chain.BinanceSmartChain:case t.Chain.Base:case t.Chain.Monad:case t.Chain.XLayer:{if(!(window.talismanEth&&("send"in window.talismanEth)))throw new t.USwapError({errorKey:"wallet_talisman_not_found",info:{chain:e}});let a=await h({chain:e,walletProvider:window.talismanEth}),r=(await window.talismanEth.send("eth_requestAccounts",[]))[0];return{...a,address:r}}case t.Chain.Polkadot:case t.Chain.Chainflip:{let{getSubstrateToolbox:a,SubstrateNetwork:r}=await import("@tcswap/toolboxes/substrate"),o=await window?.injectedWeb3?.talisman?.enable?.("talisman");if(!o)throw new t.USwapError({errorKey:"wallet_talisman_not_enabled",info:{chain:e}});let i=await a(e,{signer:o.signer}),n=await o.accounts.get();if(!n[0]?.address)throw new t.USwapError({errorKey:"wallet_missing_params",info:{accounts:n,address:n[0]?.address,wallet:t.WalletOption.TALISMAN}});let w=i.convertAddress(n[0].address,r[e].prefix);return{...i,address:w}}default:throw new t.USwapError({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:t.WalletOption.TALISMAN}})}}
|
|
2
|
+
|
|
3
|
+
//# debugId=5E1001530E5F7C7F64756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/talisman/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type EVMChain,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport const talismanWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTalisman(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectTalisman\",\n supportedChains: [\n Chain.Ethereum,\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.Monad,\n Chain.Polygon,\n Chain.BinanceSmartChain,\n Chain.Optimism,\n Chain.XLayer,\n Chain.Polkadot,\n Chain.Chainflip,\n ],\n walletType: WalletOption.TALISMAN,\n});\n\nexport const TALISMAN_SUPPORTED_CHAINS = getWalletSupportedChains(talismanWallet);\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n if (!walletProvider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.TALISMAN } });\n }\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) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch {\n throw new USwapError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.TALISMAN },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n}\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Base:\n case Chain.Monad:\n case Chain.XLayer: {\n if (!(window.talismanEth && \"send\" in window.talismanEth)) {\n throw new USwapError({ errorKey: \"wallet_talisman_not_found\", info: { chain } });\n }\n\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: window.talismanEth });\n const address: string = (await window.talismanEth.send(\"eth_requestAccounts\", []))[0];\n\n return { ...evmWallet, address };\n }\n\n case Chain.Polkadot:\n case Chain.Chainflip: {\n const { getSubstrateToolbox, SubstrateNetwork } = await import(\"@tcswap/toolboxes/substrate\");\n\n const injectedExtension = window?.injectedWeb3?.talisman;\n const rawExtension = await injectedExtension?.enable?.(\"talisman\");\n\n if (!rawExtension) {\n throw new USwapError({ errorKey: \"wallet_talisman_not_enabled\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const accounts = await rawExtension.accounts.get();\n\n if (!accounts[0]?.address) {\n throw new USwapError({\n errorKey: \"wallet_missing_params\",\n info: { accounts, address: accounts[0]?.address, wallet: WalletOption.TALISMAN },\n });\n }\n const address = toolbox.convertAddress(accounts[0].address, SubstrateNetwork[chain].prefix);\n\n return { ...toolbox, address };\n }\n\n default:\n throw new USwapError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TALISMAN } });\n }\n}\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "yFAYO,IARP,6BASA,iCAGa,EAAiB,eAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAA8B,CAAC,EAAiB,CAC9C,IAAM,EAAiB,wBAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,IAEX,KAAM,kBACN,gBAAiB,CACf,QAAM,SACN,QAAM,SACN,QAAM,UACN,QAAM,KACN,QAAM,MACN,QAAM,QACN,QAAM,kBACN,QAAM,SACN,QAAM,OACN,QAAM,SACN,QAAM,SACR,EACA,WAAY,eAAa,QAC3B,CAAC,EAEY,EAA4B,2BAAyB,CAAc,EAEhF,eAAe,CAAoB,EACjC,iBACA,SAIC,CACD,IAAQ,iBAAkB,KAAa,kCAC/B,mBAAoB,KAAa,kBAEzC,GAAI,CAAC,EACH,MAAM,IAAI,aAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,QAAO,OAAQ,eAAa,QAAS,CAAE,CAAC,EAGhH,IAAM,EAAW,IAAI,EAAgB,EAAgB,KAAK,EACpD,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE/D,GAAI,CACF,GAAI,IAAU,QAAM,SAClB,MAAM,yBAAuB,EAAU,EAAO,EAAQ,iBAAiB,CAAC,EAE1E,KAAM,CACN,MAAM,IAAI,aAAW,CACnB,SAAU,yCACV,KAAM,CAAE,QAAO,OAAQ,eAAa,QAAS,CAC/C,CAAC,EAGH,OAAO,uBAAqB,CAAE,QAAO,WAAU,SAAQ,CAAC,EAG1D,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,QAAM,cACN,QAAM,cACN,QAAM,cACN,QAAM,aACN,QAAM,eACN,QAAM,uBACN,QAAM,UACN,QAAM,WACN,QAAM,OAAQ,CACjB,GAAI,EAAE,OAAO,cAAe,SAAU,OAAO,cAC3C,MAAM,IAAI,aAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGjF,IAAM,EAAY,MAAM,EAAqB,CAAE,QAAO,eAAgB,OAAO,WAAY,CAAC,EACpF,GAAmB,MAAM,OAAO,YAAY,KAAK,sBAAuB,CAAC,CAAC,GAAG,GAEnF,MAAO,IAAK,EAAW,SAAQ,CACjC,MAEK,QAAM,cACN,QAAM,UAAW,CACpB,IAAQ,sBAAqB,oBAAqB,KAAa,uCAGzD,EAAe,MADK,QAAQ,cAAc,UACF,SAAS,UAAU,EAEjE,GAAI,CAAC,EACH,MAAM,IAAI,aAAW,CAAE,SAAU,8BAA+B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGnF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,EAC1E,EAAW,MAAM,EAAa,SAAS,IAAI,EAEjD,GAAI,CAAC,EAAS,IAAI,QAChB,MAAM,IAAI,aAAW,CACnB,SAAU,wBACV,KAAM,CAAE,WAAU,QAAS,EAAS,IAAI,QAAS,OAAQ,eAAa,QAAS,CACjF,CAAC,EAEH,IAAM,EAAU,EAAQ,eAAe,EAAS,GAAG,QAAS,EAAiB,GAAO,MAAM,EAE1F,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,aAAW,CAAE,SAAU,6BAA8B,KAAM,CAAE,QAAO,OAAQ,eAAa,QAAS,CAAE,CAAC",
|
|
8
|
+
"debugId": "5E1001530E5F7C7F64756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as d,b as m}from"../../chunk-kx2thqhk.js";import{Chain as t,filterSupportedChains as p,prepareNetworkSwitch as f,switchEVMWalletNetwork as h,USwapError as s,WalletOption as l}from"@tcswap/helpers";import{createWallet as u,getWalletSupportedChains as _}from"@tcswap/wallet-core";var y=u({connect:({addChain:e,supportedChains:a,walletType:r})=>async function(o){let i=p({chains:o,supportedChains:a,walletType:r});return await Promise.all(i.map(async(n)=>{let c=await E(n);e({...c,chain:n,walletType:r})})),!0},name:"connectTalisman",supportedChains:[t.Ethereum,t.Arbitrum,t.Avalanche,t.Base,t.Monad,t.Polygon,t.BinanceSmartChain,t.Optimism,t.XLayer,t.Polkadot,t.Chainflip],walletType:l.TALISMAN}),M=_(y);async function A({walletProvider:e,chain:a}){let{getEvmToolbox:r}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:w}=await import("ethers");if(!e)throw new s({errorKey:"wallet_provider_not_found",info:{chain:a,wallet:l.TALISMAN}});let o=new w(e,"any"),i=await o.getSigner(),n=await r(a,{provider:o,signer:i});try{if(a!==t.Ethereum)await h(o,a,n.getNetworkParams())}catch{throw new s({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:a,wallet:l.TALISMAN}})}return f({chain:a,provider:o,toolbox:n})}async function E(e){switch(e){case t.Ethereum:case t.Arbitrum:case t.Optimism:case t.Polygon:case t.Avalanche:case t.BinanceSmartChain:case t.Base:case t.Monad:case t.XLayer:{if(!(window.talismanEth&&("send"in window.talismanEth)))throw new s({errorKey:"wallet_talisman_not_found",info:{chain:e}});let a=await A({chain:e,walletProvider:window.talismanEth}),r=(await window.talismanEth.send("eth_requestAccounts",[]))[0];return{...a,address:r}}case t.Polkadot:case t.Chainflip:{let{getSubstrateToolbox:a,SubstrateNetwork:r}=await import("@tcswap/toolboxes/substrate"),o=await window?.injectedWeb3?.talisman?.enable?.("talisman");if(!o)throw new s({errorKey:"wallet_talisman_not_enabled",info:{chain:e}});let i=await a(e,{signer:o.signer}),n=await o.accounts.get();if(!n[0]?.address)throw new s({errorKey:"wallet_missing_params",info:{accounts:n,address:n[0]?.address,wallet:l.TALISMAN}});let c=i.convertAddress(n[0].address,r[e].prefix);return{...i,address:c}}default:throw new s({errorKey:"wallet_chain_not_supported",info:{chain:e,wallet:l.TALISMAN}})}}export{y as talismanWallet,M as TALISMAN_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=7C9D998FB49780D364756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/talisman/index.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type EVMChain,\n filterSupportedChains,\n prepareNetworkSwitch,\n switchEVMWalletNetwork,\n USwapError,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport type { Eip1193Provider } from \"ethers\";\n\nexport const talismanWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTalisman(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n await Promise.all(\n filteredChains.map(async (chain) => {\n const walletMethods = await getWalletMethods(chain);\n\n addChain({ ...walletMethods, chain, walletType });\n }),\n );\n\n return true;\n },\n name: \"connectTalisman\",\n supportedChains: [\n Chain.Ethereum,\n Chain.Arbitrum,\n Chain.Avalanche,\n Chain.Base,\n Chain.Monad,\n Chain.Polygon,\n Chain.BinanceSmartChain,\n Chain.Optimism,\n Chain.XLayer,\n Chain.Polkadot,\n Chain.Chainflip,\n ],\n walletType: WalletOption.TALISMAN,\n});\n\nexport const TALISMAN_SUPPORTED_CHAINS = getWalletSupportedChains(talismanWallet);\n\nasync function getWeb3WalletMethods({\n walletProvider,\n chain,\n}: {\n walletProvider: Eip1193Provider | undefined;\n chain: EVMChain;\n}) {\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n\n if (!walletProvider) {\n throw new USwapError({ errorKey: \"wallet_provider_not_found\", info: { chain, wallet: WalletOption.TALISMAN } });\n }\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) {\n await switchEVMWalletNetwork(provider, chain, toolbox.getNetworkParams());\n }\n } catch {\n throw new USwapError({\n errorKey: \"wallet_failed_to_add_or_switch_network\",\n info: { chain, wallet: WalletOption.TALISMAN },\n });\n }\n\n return prepareNetworkSwitch({ chain, provider, toolbox });\n}\n\nasync function getWalletMethods(chain: Chain) {\n switch (chain) {\n case Chain.Ethereum:\n case Chain.Arbitrum:\n case Chain.Optimism:\n case Chain.Polygon:\n case Chain.Avalanche:\n case Chain.BinanceSmartChain:\n case Chain.Base:\n case Chain.Monad:\n case Chain.XLayer: {\n if (!(window.talismanEth && \"send\" in window.talismanEth)) {\n throw new USwapError({ errorKey: \"wallet_talisman_not_found\", info: { chain } });\n }\n\n const evmWallet = await getWeb3WalletMethods({ chain, walletProvider: window.talismanEth });\n const address: string = (await window.talismanEth.send(\"eth_requestAccounts\", []))[0];\n\n return { ...evmWallet, address };\n }\n\n case Chain.Polkadot:\n case Chain.Chainflip: {\n const { getSubstrateToolbox, SubstrateNetwork } = await import(\"@tcswap/toolboxes/substrate\");\n\n const injectedExtension = window?.injectedWeb3?.talisman;\n const rawExtension = await injectedExtension?.enable?.(\"talisman\");\n\n if (!rawExtension) {\n throw new USwapError({ errorKey: \"wallet_talisman_not_enabled\", info: { chain } });\n }\n\n const toolbox = await getSubstrateToolbox(chain, { signer: rawExtension.signer });\n const accounts = await rawExtension.accounts.get();\n\n if (!accounts[0]?.address) {\n throw new USwapError({\n errorKey: \"wallet_missing_params\",\n info: { accounts, address: accounts[0]?.address, wallet: WalletOption.TALISMAN },\n });\n }\n const address = toolbox.convertAddress(accounts[0].address, SubstrateNetwork[chain].prefix);\n\n return { ...toolbox, address };\n }\n\n default:\n throw new USwapError({ errorKey: \"wallet_chain_not_supported\", info: { chain, wallet: WalletOption.TALISMAN } });\n }\n}\n"
|
|
6
|
+
],
|
|
7
|
+
"mappings": "mDAIA,gBACE,2BAEA,0BACA,4BACA,gBACA,kBACA,wBAEF,uBAAS,8BAAc,4BAGhB,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,kBAAiB,gBACrC,cAA8B,CAAC,EAAiB,CAC9C,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAUpF,OARA,MAAM,QAAQ,IACZ,EAAe,IAAI,MAAO,IAAU,CAClC,IAAM,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,QAAO,YAAW,CAAC,EACjD,CACH,EAEO,IAEX,KAAM,kBACN,gBAAiB,CACf,EAAM,SACN,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,MACN,EAAM,QACN,EAAM,kBACN,EAAM,SACN,EAAM,OACN,EAAM,SACN,EAAM,SACR,EACA,WAAY,EAAa,QAC3B,CAAC,EAEY,EAA4B,EAAyB,CAAc,EAEhF,eAAe,CAAoB,EACjC,iBACA,SAIC,CACD,IAAQ,iBAAkB,KAAa,kCAC/B,mBAAoB,KAAa,kBAEzC,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAAE,CAAC,EAGhH,IAAM,EAAW,IAAI,EAAgB,EAAgB,KAAK,EACpD,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAO,CAAE,WAAU,QAAO,CAAC,EAE/D,GAAI,CACF,GAAI,IAAU,EAAM,SAClB,MAAM,EAAuB,EAAU,EAAO,EAAQ,iBAAiB,CAAC,EAE1E,KAAM,CACN,MAAM,IAAI,EAAW,CACnB,SAAU,yCACV,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAC/C,CAAC,EAGH,OAAO,EAAqB,CAAE,QAAO,WAAU,SAAQ,CAAC,EAG1D,eAAe,CAAgB,CAAC,EAAc,CAC5C,OAAQ,QACD,EAAM,cACN,EAAM,cACN,EAAM,cACN,EAAM,aACN,EAAM,eACN,EAAM,uBACN,EAAM,UACN,EAAM,WACN,EAAM,OAAQ,CACjB,GAAI,EAAE,OAAO,cAAe,SAAU,OAAO,cAC3C,MAAM,IAAI,EAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGjF,IAAM,EAAY,MAAM,EAAqB,CAAE,QAAO,eAAgB,OAAO,WAAY,CAAC,EACpF,GAAmB,MAAM,OAAO,YAAY,KAAK,sBAAuB,CAAC,CAAC,GAAG,GAEnF,MAAO,IAAK,EAAW,SAAQ,CACjC,MAEK,EAAM,cACN,EAAM,UAAW,CACpB,IAAQ,sBAAqB,oBAAqB,KAAa,uCAGzD,EAAe,MADK,QAAQ,cAAc,UACF,SAAS,UAAU,EAEjE,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,CAAE,SAAU,8BAA+B,KAAM,CAAE,OAAM,CAAE,CAAC,EAGnF,IAAM,EAAU,MAAM,EAAoB,EAAO,CAAE,OAAQ,EAAa,MAAO,CAAC,EAC1E,EAAW,MAAM,EAAa,SAAS,IAAI,EAEjD,GAAI,CAAC,EAAS,IAAI,QAChB,MAAM,IAAI,EAAW,CACnB,SAAU,wBACV,KAAM,CAAE,WAAU,QAAS,EAAS,IAAI,QAAS,OAAQ,EAAa,QAAS,CACjF,CAAC,EAEH,IAAM,EAAU,EAAQ,eAAe,EAAS,GAAG,QAAS,EAAiB,GAAO,MAAM,EAE1F,MAAO,IAAK,EAAS,SAAQ,CAC/B,SAGE,MAAM,IAAI,EAAW,CAAE,SAAU,6BAA8B,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAAE,CAAC",
|
|
8
|
+
"debugId": "7C9D998FB49780D364756E2164756E21",
|
|
9
|
+
"names": []
|
|
10
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var S={};x(S,{waitForTronLink:()=>f,verifyNetwork:()=>k,tronlinkWallet:()=>L,setupEventListeners:()=>m,isTronLinkLocked:()=>h,getWalletForChain:()=>g,getExpectedTronNetwork:()=>T,TronLinkResponseCode:()=>u,TRONLINK_SUPPORTED_CHAINS:()=>y});module.exports=b(S);var c=require("@tcswap/helpers"),d=require("@tcswap/wallet-core");var r=require("@tcswap/helpers"),p=require("@tcswap/toolboxes/tron");var u;((e)=>{e[e.SUCCESS=200]="SUCCESS";e[e.LOCKED=4000]="LOCKED";e[e.REJECTED=4001]="REJECTED";e[e.UNAUTHORIZED=4100]="UNAUTHORIZED";e[e.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";e[e.DISCONNECTED=4900]="DISCONNECTED";e[e.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(u||={});function f(n=3000){return new Promise((t,o)=>{let i=!1,s=()=>{if(i)return;if(i=!0,window.removeEventListener("tronlink#initialized",s),a)clearTimeout(a);if(window.tronLink)t(window.tronLink);else o(new r.USwapError("wallet_provider_not_found",{wallet:r.WalletOption.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",s,{once:!0});let a=setTimeout(s,n)})}async function h(){try{let n=await f(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),o=n.ready!==!1,i=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(!o||!i)}catch{return!1}}async function _(n){let t=await n.request({method:"tron_requestAccounts"});if(t==="")throw new r.USwapError("wallet_tronlink_locked",{message:"TronLink is locked. Please unlock it to continue."});if(t.code!==200)throw new r.USwapError("wallet_tronlink_request_accounts_failed",{code:t.code,message:`TronLink requestAccounts failed: ${t.message}`})}async function g(n,t){if(n!==r.Chain.Tron)throw new r.USwapError("wallet_chain_not_supported",{chain:n,wallet:r.WalletOption.TRONLINK});let o=await f();await h()&&await _(o);let s=o.tronWeb?.defaultAddress?.base58;if(t)k(t);return{...await p.createTronToolbox({signer:{getAddress:async()=>s,signTransaction:async(e)=>{return await o.tronWeb.trx.sign(e)}}}),address:s}}function m(n,t){let o=(i)=>{switch(i.data?.message?.action){case"setAccount":{let a=i.data.message.data.address;if(n){n(a);return}window.location.reload();return}case"setNode":{let a=i.data.message.data.node;if(t)t(a.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",o),()=>window.removeEventListener("message",o)}function k(n){let t=window.tronLink;if(!t)throw new r.USwapError("wallet_provider_not_found",{wallet:r.WalletOption.TRONLINK});let o=t.tronWeb.fullNode?.host;if(o&&!o.includes(n))throw new r.USwapError("wallet_failed_to_add_or_switch_network",{currentNetwork:o,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:r.WalletOption.TRONLINK})}function T(n=!1){return n?"shasta":"api.trongrid.io"}var L=d.createWallet({connect:({addChain:n,supportedChains:t,walletType:o})=>async function(s){if(c.filterSupportedChains({chains:s,supportedChains:t,walletType:o}).length===0)throw Error("TronLink wallet only supports Tron chain");let l=T(!1),e=await g(c.Chain.Tron,l),N=e.address,W=m((w)=>{if(w!==N)window.location.reload()},(w)=>{if(!w.includes(l))window.location.reload()}),E=()=>{W()};return n({...e,balance:[],chain:c.Chain.Tron,disconnect:E,walletType:o}),!0},name:"connectTronLink",supportedChains:[c.Chain.Tron],walletType:c.WalletOption.TRONLINK}),y=d.getWalletSupportedChains(L);
|
|
2
|
+
|
|
3
|
+
//# debugId=E4397BCCFEBD2C8764756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"import { Chain, filterSupportedChains, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n const currentAddress = walletMethods.address;\n\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n window.location.reload();\n }\n },\n (newNetwork) => {\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport { Chain, USwapError, WalletOption } from \"@tcswap/helpers\";\nimport { createTronToolbox, type TronTransaction } from \"@tcswap/toolboxes/tron\";\nimport type { TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new USwapError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function isTronLinkLocked() {\n try {\n const tronLink = await waitForTronLink(1000);\n\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n const isReady = tronLink.ready !== false;\n\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n return !hasDefaultAddress && (!isReady || !hasTronWeb);\n } catch {\n return false;\n }\n}\n\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow) {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response === \"\") {\n throw new USwapError(\"wallet_tronlink_locked\", { message: \"TronLink is locked. Please unlock it to continue.\" });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new USwapError(\"wallet_tronlink_request_accounts_failed\", {\n code: response.code,\n message: `TronLink requestAccounts failed: ${response.message}`,\n });\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new USwapError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n const isLocked = await isTronLinkLocked();\n\n isLocked && (await requestTronLinkAccounts(tronLink));\n\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n const signer = {\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\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n) {\n const messageHandler = (event: MessageEvent) => {\n const eventDataAction = event.data?.message?.action;\n\n switch (eventDataAction) {\n case \"setAccount\": {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n return;\n }\n window.location.reload();\n return;\n }\n case \"setNode\": {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n }\n window.location.reload();\n return;\n }\n default:\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new USwapError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new USwapError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
|
|
7
|
+
"import type { TronSignedTransaction, TronTransaction } from \"@tcswap/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse | \"\">;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n"
|
|
8
|
+
],
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "E4397BCCFEBD2C8764756E2164756E21",
|
|
11
|
+
"names": []
|
|
12
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import"../../chunk-kx2thqhk.js";import{Chain as w,filterSupportedChains as b,WalletOption as x}from"@tcswap/helpers";import{createWallet as y,getWalletSupportedChains as S}from"@tcswap/wallet-core";import{Chain as L,USwapError as a,WalletOption as c}from"@tcswap/helpers";import{createTronToolbox as N}from"@tcswap/toolboxes/tron";var u;((e)=>{e[e.SUCCESS=200]="SUCCESS";e[e.LOCKED=4000]="LOCKED";e[e.REJECTED=4001]="REJECTED";e[e.UNAUTHORIZED=4100]="UNAUTHORIZED";e[e.UNSUPPORTED_METHOD=4200]="UNSUPPORTED_METHOD";e[e.DISCONNECTED=4900]="DISCONNECTED";e[e.CHAIN_DISCONNECTED=4901]="CHAIN_DISCONNECTED"})(u||={});function f(n=3000){return new Promise((t,o)=>{let r=!1,i=()=>{if(r)return;if(r=!0,window.removeEventListener("tronlink#initialized",i),s)clearTimeout(s);if(window.tronLink)t(window.tronLink);else o(new a("wallet_provider_not_found",{wallet:c.TRONLINK}))};if(window.tronLink){t(window.tronLink);return}window.addEventListener("tronlink#initialized",i,{once:!0});let s=setTimeout(i,n)})}async function W(){try{let n=await f(1000),t=Boolean(n.tronWeb?.defaultAddress?.base58),o=n.ready!==!1,r=Boolean(n.tronWeb&&typeof n.tronWeb.trx==="object"&&typeof n.tronWeb.trx.sign==="function");return!t&&(!o||!r)}catch{return!1}}async function E(n){let t=await n.request({method:"tron_requestAccounts"});if(t==="")throw new a("wallet_tronlink_locked",{message:"TronLink is locked. Please unlock it to continue."});if(t.code!==200)throw new a("wallet_tronlink_request_accounts_failed",{code:t.code,message:`TronLink requestAccounts failed: ${t.message}`})}async function g(n,t){if(n!==L.Tron)throw new a("wallet_chain_not_supported",{chain:n,wallet:c.TRONLINK});let o=await f();await W()&&await E(o);let i=o.tronWeb?.defaultAddress?.base58;if(t)_(t);return{...await N({signer:{getAddress:async()=>i,signTransaction:async(e)=>{return await o.tronWeb.trx.sign(e)}}}),address:i}}function m(n,t){let o=(r)=>{switch(r.data?.message?.action){case"setAccount":{let s=r.data.message.data.address;if(n){n(s);return}window.location.reload();return}case"setNode":{let s=r.data.message.data.node;if(t)t(s.fullNode);window.location.reload();return}default:return}};return window.addEventListener("message",o),()=>window.removeEventListener("message",o)}function _(n){let t=window.tronLink;if(!t)throw new a("wallet_provider_not_found",{wallet:c.TRONLINK});let o=t.tronWeb.fullNode?.host;if(o&&!o.includes(n))throw new a("wallet_failed_to_add_or_switch_network",{currentNetwork:o,expectedNetwork:n,message:`Wrong network. Please switch to ${n} in TronLink.`,wallet:c.TRONLINK})}function T(n=!1){return n?"shasta":"api.trongrid.io"}var A=y({connect:({addChain:n,supportedChains:t,walletType:o})=>async function(i){if(b({chains:i,supportedChains:t,walletType:o}).length===0)throw Error("TronLink wallet only supports Tron chain");let d=T(!1),e=await g(w.Tron,d),p=e.address,h=m((l)=>{if(l!==p)window.location.reload()},(l)=>{if(!l.includes(d))window.location.reload()}),k=()=>{h()};return n({...e,balance:[],chain:w.Tron,disconnect:k,walletType:o}),!0},name:"connectTronLink",supportedChains:[w.Tron],walletType:x.TRONLINK}),q=S(A);export{f as waitForTronLink,_ as verifyNetwork,A as tronlinkWallet,m as setupEventListeners,W as isTronLinkLocked,g as getWalletForChain,T as getExpectedTronNetwork,u as TronLinkResponseCode,q as TRONLINK_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=26057193226A3A0964756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/tronlink/index.ts", "../src/tronlink/helpers.ts", "../src/tronlink/types.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"import { Chain, filterSupportedChains, WalletOption } from \"@tcswap/helpers\";\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/wallet-core\";\nimport { getExpectedTronNetwork, getWalletForChain, setupEventListeners } from \"./helpers.js\";\n\nexport const tronlinkWallet = createWallet({\n connect: ({ addChain, supportedChains, walletType }) =>\n async function connectTronLink(chains: Chain[]) {\n const filteredChains = filterSupportedChains({ chains, supportedChains, walletType });\n\n if (filteredChains.length === 0) {\n throw new Error(\"TronLink wallet only supports Tron chain\");\n }\n\n const expectedNetwork = getExpectedTronNetwork(false);\n\n const walletMethods = await getWalletForChain(Chain.Tron, expectedNetwork);\n\n const currentAddress = walletMethods.address;\n\n const cleanup = setupEventListeners(\n (newAddress) => {\n if (newAddress !== currentAddress) {\n window.location.reload();\n }\n },\n (newNetwork) => {\n if (!newNetwork.includes(expectedNetwork)) {\n window.location.reload();\n }\n },\n );\n\n const disconnect = () => {\n cleanup();\n };\n\n addChain({ ...walletMethods, balance: [], chain: Chain.Tron, disconnect, walletType });\n\n return true;\n },\n name: \"connectTronLink\",\n supportedChains: [Chain.Tron],\n walletType: WalletOption.TRONLINK,\n});\n\nexport const TRONLINK_SUPPORTED_CHAINS = getWalletSupportedChains(tronlinkWallet);\n\nexport * from \"./helpers.js\";\nexport * from \"./types.js\";\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport { Chain, USwapError, WalletOption } from \"@tcswap/helpers\";\nimport { createTronToolbox, type TronTransaction } from \"@tcswap/toolboxes/tron\";\nimport type { TronLinkWindow } from \"./types.js\";\nimport { TronLinkResponseCode } from \"./types.js\";\n\nexport function waitForTronLink(timeout = 3000): Promise<TronLinkWindow> {\n return new Promise((resolve, reject) => {\n let handled = false;\n\n const handleProvider = () => {\n if (handled) return;\n handled = true;\n window.removeEventListener(\"tronlink#initialized\", handleProvider);\n if (timeoutId) clearTimeout(timeoutId);\n\n if (window.tronLink) {\n resolve(window.tronLink);\n } else {\n reject(new USwapError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK }));\n }\n };\n\n if (window.tronLink) {\n resolve(window.tronLink);\n return;\n }\n\n window.addEventListener(\"tronlink#initialized\", handleProvider, { once: true });\n\n const timeoutId = setTimeout(handleProvider, timeout);\n });\n}\n\nexport async function isTronLinkLocked() {\n try {\n const tronLink = await waitForTronLink(1000);\n\n const hasDefaultAddress = Boolean(tronLink.tronWeb?.defaultAddress?.base58);\n\n const isReady = tronLink.ready !== false;\n\n const hasTronWeb = Boolean(\n tronLink.tronWeb && typeof tronLink.tronWeb.trx === \"object\" && typeof tronLink.tronWeb.trx.sign === \"function\",\n );\n\n return !hasDefaultAddress && (!isReady || !hasTronWeb);\n } catch {\n return false;\n }\n}\n\nasync function requestTronLinkAccounts(tronLink: TronLinkWindow) {\n const response = await tronLink.request({ method: \"tron_requestAccounts\" });\n\n if (response === \"\") {\n throw new USwapError(\"wallet_tronlink_locked\", { message: \"TronLink is locked. Please unlock it to continue.\" });\n }\n\n if (response.code !== TronLinkResponseCode.SUCCESS) {\n throw new USwapError(\"wallet_tronlink_request_accounts_failed\", {\n code: response.code,\n message: `TronLink requestAccounts failed: ${response.message}`,\n });\n }\n}\n\nexport async function getWalletForChain(chain: Chain, expectedNetwork?: string) {\n if (chain !== Chain.Tron) {\n throw new USwapError(\"wallet_chain_not_supported\", { chain, wallet: WalletOption.TRONLINK });\n }\n\n const tronLink = await waitForTronLink();\n const isLocked = await isTronLinkLocked();\n\n isLocked && (await requestTronLinkAccounts(tronLink));\n\n const address = tronLink.tronWeb?.defaultAddress?.base58;\n\n if (expectedNetwork) {\n verifyNetwork(expectedNetwork);\n }\n\n const signer = {\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\nexport function setupEventListeners(\n onAccountChange?: (address: string) => void,\n onNetworkChange?: (network: string) => void,\n) {\n const messageHandler = (event: MessageEvent) => {\n const eventDataAction = event.data?.message?.action;\n\n switch (eventDataAction) {\n case \"setAccount\": {\n const newAddress = event.data.message.data.address;\n if (onAccountChange) {\n onAccountChange(newAddress);\n return;\n }\n window.location.reload();\n return;\n }\n case \"setNode\": {\n const node = event.data.message.data.node;\n if (onNetworkChange) {\n onNetworkChange(node.fullNode);\n }\n window.location.reload();\n return;\n }\n default:\n return;\n }\n };\n\n window.addEventListener(\"message\", messageHandler);\n\n return () => window.removeEventListener(\"message\", messageHandler);\n}\n\nexport function verifyNetwork(expectedNetwork: string) {\n const tronLink = window.tronLink;\n if (!tronLink) {\n throw new USwapError(\"wallet_provider_not_found\", { wallet: WalletOption.TRONLINK });\n }\n\n const currentNode = tronLink.tronWeb.fullNode?.host;\n if (currentNode && !currentNode.includes(expectedNetwork)) {\n throw new USwapError(\"wallet_failed_to_add_or_switch_network\", {\n currentNetwork: currentNode,\n expectedNetwork,\n message: `Wrong network. Please switch to ${expectedNetwork} in TronLink.`,\n wallet: WalletOption.TRONLINK,\n });\n }\n}\n\nexport function getExpectedTronNetwork(testnet = false): string {\n return testnet ? \"shasta\" : \"api.trongrid.io\";\n}\n",
|
|
7
|
+
"import type { TronSignedTransaction, TronTransaction } from \"@tcswap/toolboxes/tron\";\n\ndeclare global {\n interface Window {\n tronLink?: TronLinkWindow;\n tronWeb?: TronLinkWindow[\"tronWeb\"];\n }\n}\n\nexport interface TronLinkWindow {\n ready: boolean;\n request: (args: { method: string; params?: unknown }) => Promise<TronLinkResponse | \"\">;\n tronWeb: {\n defaultAddress: { base58: string; hex: string };\n fullNode?: { host: string };\n trx: {\n sign: (transaction: TronTransaction) => Promise<TronSignedTransaction>;\n sendRawTransaction: (signedTx: TronSignedTransaction) => Promise<string>;\n getBalance: (address: string) => Promise<number>;\n getAccountResources: (address: string) => Promise<unknown>;\n };\n };\n sunWeb?: unknown; // For sidechain support\n}\n\nexport enum TronLinkResponseCode {\n SUCCESS = 200,\n LOCKED = 4000,\n REJECTED = 4001,\n UNAUTHORIZED = 4100,\n UNSUPPORTED_METHOD = 4200,\n DISCONNECTED = 4900,\n CHAIN_DISCONNECTED = 4901,\n}\n\nexport interface TronLinkResponse {\n code: TronLinkResponseCode;\n message: string;\n}\n\nexport interface TronLinkEvents {\n setAccount: { address: string };\n setNode: { node: { chain: string; fullNode: string } };\n}\n"
|
|
8
|
+
],
|
|
9
|
+
"mappings": "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",
|
|
10
|
+
"debugId": "26057193226A3A0964756E2164756E21",
|
|
11
|
+
"names": []
|
|
12
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var v={};x(v,{vultisigWallet:()=>A,VULTISIG_SUPPORTED_CHAINS:()=>g});module.exports=b(v);var z=require("@tcswap/helpers"),k=require("@tcswap/wallet-core");var F=require("@tcswap/helpers"),E=require("@tcswap/helpers/contracts");async function I(D){if(!window.vultisig)throw new F.USwapError("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,B)=>{Y?G(Y):q(B)})})}async function y(D){try{let $=await I(D);if(!$)throw new F.USwapError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}});if([F.Chain.Cosmos,F.Chain.Kujira].includes(D)){let Q=F.ChainToChainId[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.USwapError({errorKey:"wallet_provider_not_found",info:{chain:D,wallet:F.WalletOption.VULTISIG}})}}async function R({assetValue:D,recipient:$,memo:J,gasLimit:Q},Z="send_transaction"){if(!D)throw new F.USwapError("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 N(D,$){return{approve:async({assetAddress:J,spenderAddress:Q,amount:Z,from:q})=>{let{MAX_APPROVAL:G,getCreateContractTxObject:Y}=await import("@tcswap/toolboxes/evm"),B=[Q,BigInt(Z||G)],H={abi:E.erc20ABI,contractAddress:J,funcName:"approve",funcParams:B,txOverrides:{from:q}},_=Y({chain:$,provider:D}),{value:L,to:O,data:j}=await _(H);return(await(await D.getSigner()).sendTransaction({data:j||"0x",from:q,to:O,value:BigInt(L||0)})).hash},call:async({contractAddress:J,abi:Q,funcName:Z,funcParams:q=[],txOverrides:G})=>{if(!J)throw new F.USwapError("wallet_vultisig_contract_address_not_provided");let{createContract:Y,getCreateContractTxObject:B,isStateChangingCall:K}=await import("@tcswap/toolboxes/evm");if(K({abi:Q,funcName:Z})){let O=B({chain:$,provider:D}),{value:j,from:W,to:M,data:T}=await O({abi:Q,contractAddress:J,funcName:Z,funcParams:q,txOverrides:G});return(await(await D.getSigner()).sendTransaction({data:T||"0x",from:W,to:M,value:BigInt(j||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.USwapError("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.USwapError("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.USwapError({errorKey:"helpers_failed_to_switch_network",info:{error:Z}})}return D(...Q)}}function S({toolbox:D,chain:$,provider:J=window.ethereum,methodNames:Q=[]}){let q=[...Q,"transfer","getAddress","getBalance"].reduce((G,Y)=>{if(!D[Y])return G;let B=D[Y];if(typeof B!=="function")return G;let K=f(B,J,$);return{...G,[Y]:K}},{});return{...D,...q}}var A=k.createWallet({connect:({addChain:D,walletType:$,supportedChains:J})=>async function(Z){let q=z.filterSupportedChains({chains:Z,supportedChains:J,walletType:$}),G=q.filter((K)=>K!==z.Chain.Cosmos&&K!==z.Chain.Kujira).map(async(K)=>{let H=await y(K),_=await U(K);D({..._,address:H,chain:K,walletType:$})}),Y=q.includes(z.Chain.Cosmos),B=q.includes(z.Chain.Kujira);if(Y){let K=await y(z.Chain.Cosmos),H=await U(z.Chain.Cosmos);D({...H,address:K,chain:z.Chain.Cosmos,walletType:$})}if(B){let K=await y(z.Chain.Kujira),H=await U(z.Chain.Kujira);D({...H,address:K,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,z.Chain.XLayer],walletType:z.WalletOption.VULTISIG}),g=k.getWalletSupportedChains(A);async function U(D){let{match:$}=await import("ts-pattern");return $(D).with(z.Chain.Solana,async()=>{let{getSolanaToolbox:J}=await import("@tcswap/toolboxes/solana"),Q=window.vultisig?.solana;if(!Q)throw new z.USwapError("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("@tcswap/toolboxes/cosmos"),q=D===z.Chain.Maya?Z:Q;return{...await J(D),deposit:(Y)=>R({...Y,recipient:""},"deposit_transaction"),transfer:(Y)=>R({...Y,gasLimit:q},"send_transaction")}}).with(z.Chain.Cosmos,z.Chain.Kujira,async()=>{let{getCosmosToolbox:J}=await import("@tcswap/toolboxes/cosmos"),Q=await I(D),Z=await J(D);return S({chain:D,provider:Q,toolbox:{...Z,transfer:R}})}).with(...z.UTXOChains,async()=>{let{getUtxoToolbox:J}=await import("@tcswap/toolboxes/utxo");return{...await J(D),transfer:R}}).with(z.Chain.Arbitrum,z.Chain.Avalanche,z.Chain.Base,z.Chain.BinanceSmartChain,z.Chain.Ethereum,z.Chain.Optimism,z.Chain.Polygon,z.Chain.XLayer,async()=>{let{prepareNetworkSwitch:J,switchEVMWalletNetwork:Q}=await import("@tcswap/helpers"),{getEvmToolbox:Z}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:q}=await import("ethers"),G=await I(D);if(!G)throw new z.USwapError("wallet_vultisig_not_found");let Y=new q(G,"any"),B=await Y.getSigner(),K=await Z(D,{provider:Y,signer:B}),H=N(Y,D);try{if(D!==z.Chain.Ethereum){let _=K.getNetworkParams();await Q(Y,D,_)}}catch{throw new z.USwapError({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:D,wallet:z.WalletOption.VULTISIG}})}return J({chain:D,provider:Y,toolbox:{...K,...H}})}).with(z.Chain.Ripple,async()=>{let{getRippleToolbox:J}=await import("@tcswap/toolboxes/ripple");return{...await J(),transfer:R}}).with(z.Chain.Polkadot,async()=>{let{getSubstrateToolbox:J}=await import("@tcswap/toolboxes/substrate");return{...await J(D),transfer:R}}).otherwise(async()=>null)}
|
|
2
|
+
|
|
3
|
+
//# debugId=4C8797DF71FD25A364756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.cjs.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/vultisig/index.ts", "../src/vultisig/walletHelpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type CosmosChain,\n type EVMChain,\n filterSupportedChains,\n type GenericTransferParams,\n type SubstrateChain,\n type TCLikeChain,\n USwapError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n} from \"@tcswap/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/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 Chain.XLayer,\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(\"@tcswap/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new USwapError(\"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(\"@tcswap/toolboxes/cosmos\");\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain | Chain.Harbor>);\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(\"@tcswap/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Exclude<CosmosChain, TCLikeChain>);\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain | Chain.Harbor>);\n return prepareNetworkSwitchCosmos({ chain, provider, toolbox: { ...toolbox, transfer: walletTransfer } });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@tcswap/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 Chain.XLayer,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@tcswap/helpers\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new USwapError(\"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 {\n throw new USwapError({\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(\"@tcswap/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@tcswap/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as SubstrateChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n getChainConfig,\n type NetworkParams,\n providerRequest,\n USwapError,\n type UTXOChain,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { erc20ABI } from \"@tcswap/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@tcswap/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@tcswap/toolboxes/evm\";\nimport type { SolanaProvider } from \"@tcswap/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 USwapError(\"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 USwapError({ 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 = ChainToChainId[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 {\n throw new USwapError({ 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 USwapError(\"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(\"@tcswap/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 USwapError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\"@tcswap/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 USwapError(\"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 USwapError(\"helpers_failed_to_switch_network\", { error: error, reason: \"networkParams not provided\" });\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 USwapError({ 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
|
+
],
|
|
8
|
+
"mappings": "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",
|
|
9
|
+
"debugId": "4C8797DF71FD25A364756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import{a as X,b as B}from"../../chunk-kx2thqhk.js";import{Chain as D,filterSupportedChains as C,USwapError as W,UTXOChains as p,WalletOption as V}from"@tcswap/helpers";import{createWallet as d,getWalletSupportedChains as l}from"@tcswap/wallet-core";import{Chain as Y,ChainToChainId as b,EVMChains as A,getChainConfig as x,providerRequest as g,USwapError as _,WalletOption as S}from"@tcswap/helpers";import{erc20ABI as v}from"@tcswap/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,H)=>{q?G(q):$(H)})})}async function O(z){try{let Z=await y(z);if(!Z)throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:S.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{throw new _({errorKey:"wallet_provider_not_found",info:{chain:z,wallet:S.VULTISIG}})}}async function I({assetValue:z,recipient:Z,memo:F,gasLimit:J},Q="send_transaction"){if(!z)throw new _("wallet_vultisig_asset_not_defined");let $=await O(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("@tcswap/toolboxes/evm"),H=[J,BigInt(Q||G)],R={abi:v,contractAddress:F,funcName:"approve",funcParams:H,txOverrides:{from:$}},L=q({chain:Z,provider:z}),{value:k,to:j,data:U}=await L(R);return(await(await z.getSigner()).sendTransaction({data:U||"0x",from:$,to:j,value:BigInt(k||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:H,isStateChangingCall:K}=await import("@tcswap/toolboxes/evm");if(K({abi:J,funcName:Q})){let j=H({chain:Z,provider:z}),{value:U,from:E,to:N,data:f}=await j({abi:J,contractAddress:F,funcName:Q,funcParams:$,txOverrides:G});return(await(await z.getSigner()).sendTransaction({data:f||"0x",from:E,to:N,value:BigInt(U||0)})).hash}let k=await q(F,J,z)[Q]?.(...$);return typeof k?.hash==="string"?k?.hash:k},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 H=z[q];if(typeof H!=="function")return G;let K=m(H,F,Z);return{...G,[q]:K}},{});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((K)=>K!==D.Cosmos&&K!==D.Kujira).map(async(K)=>{let R=await O(K),L=await M(K);z({...L,address:R,chain:K,walletType:Z})}),q=$.includes(D.Cosmos),H=$.includes(D.Kujira);if(q){let K=await O(D.Cosmos),R=await M(D.Cosmos);z({...R,address:K,chain:D.Cosmos,walletType:Z})}if(H){let K=await O(D.Kujira),R=await M(D.Kujira);z({...R,address:K,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,D.XLayer],walletType:V.VULTISIG}),a=l(c);async function M(z){let{match:Z}=await import("ts-pattern");return Z(z).with(D.Solana,async()=>{let{getSolanaToolbox:F}=await import("@tcswap/toolboxes/solana"),J=window.vultisig?.solana;if(!J)throw new W("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("@tcswap/toolboxes/cosmos"),$=z===D.Maya?Q:J;return{...await F(z),deposit:(q)=>I({...q,recipient:""},"deposit_transaction"),transfer:(q)=>I({...q,gasLimit:$},"send_transaction")}}).with(D.Cosmos,D.Kujira,async()=>{let{getCosmosToolbox:F}=await import("@tcswap/toolboxes/cosmos"),J=await y(z),Q=await F(z);return P({chain:z,provider:J,toolbox:{...Q,transfer:I}})}).with(...p,async()=>{let{getUtxoToolbox:F}=await import("@tcswap/toolboxes/utxo");return{...await F(z),transfer:I}}).with(D.Arbitrum,D.Avalanche,D.Base,D.BinanceSmartChain,D.Ethereum,D.Optimism,D.Polygon,D.XLayer,async()=>{let{prepareNetworkSwitch:F,switchEVMWalletNetwork:J}=await import("@tcswap/helpers"),{getEvmToolbox:Q}=await import("@tcswap/toolboxes/evm"),{BrowserProvider:$}=await import("ethers"),G=await y(z);if(!G)throw new W("wallet_vultisig_not_found");let q=new $(G,"any"),H=await q.getSigner(),K=await Q(z,{provider:q,signer:H}),R=T(q,z);try{if(z!==D.Ethereum){let L=K.getNetworkParams();await J(q,z,L)}}catch{throw new W({errorKey:"wallet_failed_to_add_or_switch_network",info:{chain:z,wallet:V.VULTISIG}})}return F({chain:z,provider:q,toolbox:{...K,...R}})}).with(D.Ripple,async()=>{let{getRippleToolbox:F}=await import("@tcswap/toolboxes/ripple");return{...await F(),transfer:I}}).with(D.Polkadot,async()=>{let{getSubstrateToolbox:F}=await import("@tcswap/toolboxes/substrate");return{...await F(z),transfer:I}}).otherwise(async()=>null)}export{c as vultisigWallet,a as VULTISIG_SUPPORTED_CHAINS};
|
|
2
|
+
|
|
3
|
+
//# debugId=F6477614ED5D506664756E2164756E21
|
|
4
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/vultisig/index.ts", "../src/vultisig/walletHelpers.ts"],
|
|
4
|
+
"sourcesContent": [
|
|
5
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n Chain,\n type CosmosChain,\n type EVMChain,\n filterSupportedChains,\n type GenericTransferParams,\n type SubstrateChain,\n type TCLikeChain,\n USwapError,\n type UTXOChain,\n UTXOChains,\n WalletOption,\n} from \"@tcswap/helpers\";\n\nimport { createWallet, getWalletSupportedChains } from \"@tcswap/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 Chain.XLayer,\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(\"@tcswap/toolboxes/solana\");\n const solanaProvider = window.vultisig?.solana;\n if (!solanaProvider) throw new USwapError(\"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(\"@tcswap/toolboxes/cosmos\");\n const gasLimit = chain === Chain.Maya ? MAYA_GAS_VALUE : THORCHAIN_GAS_VALUE;\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain | Chain.Harbor>);\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(\"@tcswap/toolboxes/cosmos\");\n const provider = await getVultisigProvider(chain as Exclude<CosmosChain, TCLikeChain>);\n const toolbox = await getCosmosToolbox(chain as Exclude<CosmosChain, TCLikeChain | Chain.Harbor>);\n return prepareNetworkSwitchCosmos({ chain, provider, toolbox: { ...toolbox, transfer: walletTransfer } });\n })\n\n .with(...UTXOChains, async () => {\n const { getUtxoToolbox } = await import(\"@tcswap/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 Chain.XLayer,\n async () => {\n const { prepareNetworkSwitch, switchEVMWalletNetwork } = await import(\"@tcswap/helpers\");\n const { getEvmToolbox } = await import(\"@tcswap/toolboxes/evm\");\n const { BrowserProvider } = await import(\"ethers\");\n const ethereumWindowProvider = await getVultisigProvider(chain as EVMChain);\n\n if (!ethereumWindowProvider) {\n throw new USwapError(\"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 {\n throw new USwapError({\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(\"@tcswap/toolboxes/ripple\");\n const toolbox = await getRippleToolbox();\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .with(Chain.Polkadot, async () => {\n const { getSubstrateToolbox } = await import(\"@tcswap/toolboxes/substrate\");\n const toolbox = await getSubstrateToolbox(chain as SubstrateChain);\n return { ...toolbox, transfer: walletTransfer };\n })\n\n .otherwise(async () => null);\n}\n",
|
|
6
|
+
"/**\n * Modifications © 2025 Horizontal Systems.\n */\n\nimport {\n type AssetValue,\n Chain,\n ChainToChainId,\n type CosmosChain,\n type EVMChain,\n EVMChains,\n type FeeOption,\n getChainConfig,\n type NetworkParams,\n providerRequest,\n USwapError,\n type UTXOChain,\n WalletOption,\n} from \"@tcswap/helpers\";\nimport { erc20ABI } from \"@tcswap/helpers/contracts\";\nimport type { getCosmosToolbox } from \"@tcswap/toolboxes/cosmos\";\nimport type { ApproveParams, CallParams, EVMTxParams } from \"@tcswap/toolboxes/evm\";\nimport type { SolanaProvider } from \"@tcswap/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 USwapError(\"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 USwapError({ 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 = ChainToChainId[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 {\n throw new USwapError({ 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 USwapError(\"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(\"@tcswap/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 USwapError(\"wallet_vultisig_contract_address_not_provided\");\n }\n const { createContract, getCreateContractTxObject, isStateChangingCall } = await import(\"@tcswap/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 USwapError(\"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 USwapError(\"helpers_failed_to_switch_network\", { error: error, reason: \"networkParams not provided\" });\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 USwapError({ 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
|
+
],
|
|
8
|
+
"mappings": "mDAIA,gBACE,2BAGA,gBAIA,gBAEA,kBACA,wBAGF,uBAAS,8BAAc,4BCdvB,gBAEE,oBACA,eAGA,oBAEA,qBAEA,gBACA,kBAEA,wBAEF,mBAAS,kCAqCT,eAAsB,CAAoC,CAAC,EAA4C,CACrG,GAAI,CAAC,OAAO,SAAU,MAAM,IAAI,EAAW,2BAA2B,EACtE,IAAQ,SAAU,KAAa,sBAE/B,OAAO,EAAM,CAAc,EACxB,KAAK,GAAG,EAAW,IAAM,OAAO,UAAU,QAA2B,EACrE,KAAK,EAAM,OAAQ,EAAM,OAAQ,IAAM,OAAO,UAAU,MAAgC,EACxF,KAAK,EAAM,QAAS,IAAM,OAAO,UAAU,OAA0B,EACrE,KAAK,EAAM,YAAa,IAAM,OAAO,UAAU,WAA8B,EAC7E,KAAK,EAAM,KAAM,IAAM,OAAO,UAAU,IAAuB,EAC/D,KAAK,EAAM,SAAU,IAAM,OAAO,UAAU,QAA2B,EACvE,KAAK,EAAM,SAAU,IAAM,OAAO,UAAU,QAA2B,EACvE,KAAK,EAAM,OAAQ,IAAM,OAAO,UAAU,MAAwB,EAClE,KAAK,EAAM,UAAW,IAAM,OAAO,UAAU,SAA4B,EACzE,KAAK,EAAM,KAAM,IAAM,OAAO,UAAU,SAA4B,EACpE,KAAK,EAAM,SAAU,IAAM,OAAO,UAAU,QAA2B,EACvE,KAAK,EAAM,OAAQ,IAAM,OAAO,UAAU,MAAyB,EACnE,KAAK,EAAM,MAAO,IAAM,OAAO,UAAU,KAAwB,EACjE,UAAU,IAAG,CAAG,OAAS,EAG9B,eAAe,CAAW,EACxB,SACA,SACA,SAKkB,CAClB,IAAM,EAAS,MAAM,EAAoB,CAAK,EAC1C,EAAmG,EAEvG,GAAI,IAAU,EAAM,QAAU,IAAU,EAAM,QAAU,IAAU,EAAM,OACtE,EAAc,EAAO,IAAI,CAAC,KAAO,CAC/B,KAAM,EAAE,KACR,KAAM,EAAE,KACR,GAAI,EAAE,GACN,MAAQ,EAAE,OAAiD,OAAO,SAAS,CAC7E,EAAE,EAGJ,OAAO,IAAI,QAAgB,CAAC,EAAS,IAAW,CAC9C,GAAI,GAAU,YAAa,EAEzB,EAAO,QAAQ,CAAE,SAAQ,OAAQ,CAAY,EAAG,CAAC,EAAa,IAAe,CAC3E,EAAM,EAAO,CAAG,EAAI,EAAQ,CAAE,EAC/B,EAEJ,EAGH,eAAsB,CAAkB,CAAC,EAAc,CACrD,GAAI,CACF,IAAM,EAAkB,MAAM,EAAoB,CAAK,EACvD,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAAE,CAAC,EAGhH,GAAI,CAAC,EAAM,OAAQ,EAAM,MAAM,EAAE,SAAS,CAA4B,EAAG,CACvE,IAAM,EAAU,EAAe,GAE/B,MAAM,EAAe,QAAQ,CAAE,OAAQ,sBAAuB,OAAQ,CAAC,CAAE,SAAQ,CAAC,CAAE,CAAC,EAErF,IAAI,EAAU,MAAM,EAAe,QAAQ,CAAE,OAAQ,cAAe,CAAC,EACrE,GAAI,CAAC,EAEH,GADwB,MAAM,EAAe,QAAQ,CAAE,OAAQ,kBAAmB,CAAC,GACzD,GAAG,QAE/B,OAAO,EAGT,GAAI,EAAU,SAAS,CAAiB,EAAG,CACzC,IAAQ,mBAAoB,KAAa,kBACnC,EAAW,IAAI,EAAgB,EAAgB,KAAK,GACnD,GAAY,MAAM,EAAgB,CAAE,OAAQ,sBAAuB,OAAQ,CAAC,EAAG,UAAS,CAAC,EAChG,OAAO,EAGT,GAAI,IAAU,EAAM,OAIlB,OADiB,MAFM,MAAM,EAAoB,EAAM,MAAM,GAEvB,QAAQ,GAC9B,UAAU,SAAS,EAIrC,OADiB,MAAM,EAAe,QAAQ,CAAE,OAAQ,mBAAoB,OAAQ,CAAC,CAAE,CAAC,GACxE,GAChB,KAAM,CACN,MAAM,IAAI,EAAW,CAAE,SAAU,4BAA6B,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAAE,CAAC,GAIlH,eAAsB,CAAc,EAChC,aAAY,YAAW,OAAM,YAC/B,EAA4B,mBAC5B,CACA,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,mCAAmC,EAQ1D,IAAM,EAAO,MAAM,EAAmB,EAAW,KAAK,EAChD,EAAS,CACb,CACE,OAAQ,CAAE,OAAQ,EAAW,aAAa,QAAQ,EAAG,SAAU,EAAW,OAAQ,EAClF,MAAO,CACL,MAAO,EAAW,MAClB,OAAQ,EAAW,OAAO,YAAY,EACtC,OAAQ,EAAW,OAAO,YAAY,CACxC,EACA,KAAM,GAAQ,GACd,OACA,WACA,GAAI,CACN,CACF,EAEA,OAAO,EAAY,CAAE,MAAO,EAAW,MAAO,SAAQ,QAAO,CAAC,EAGzD,SAAS,CAAkB,CAAC,EAA2B,EAAiB,CAC7E,MAAO,CACL,QAAS,OAAS,eAAc,iBAAgB,SAAQ,UAA0B,CAChF,IAAQ,eAAc,6BAA8B,KAAa,iCAC3D,EAAa,CAAC,EAAgB,OAAO,GAAU,CAAY,CAAC,EAG5D,EAAqB,CACzB,IAAK,EACL,gBAAiB,EACjB,SAAU,UACV,aACA,YAPkB,CAAE,MAAK,CAQ3B,EAEM,EAAW,EAA0B,CAAE,QAAO,UAAS,CAAC,GACtD,QAAO,KAAI,QAAS,MAAM,EAAS,CAAkB,EAI7D,OADW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CAAE,KAAM,GAAQ,KAAM,OAAM,KAAI,MAAO,OAAO,GAAS,CAAC,CAAE,CAAC,GACzF,MAEZ,KAAM,OAAY,kBAAiB,MAAK,WAAU,aAAa,CAAC,EAAG,iBAA0C,CAC3G,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,+CAA+C,EAEtE,IAAQ,iBAAgB,4BAA2B,uBAAwB,KAAa,iCAIxF,GAFwB,EAAoB,CAAE,MAAK,UAAS,CAAC,EAExC,CACnB,IAAM,EAAW,EAA0B,CAAE,QAAO,UAAS,CAAC,GACtD,QAAO,OAAM,KAAI,QAAS,MAAM,EAAS,CAAE,MAAK,kBAAiB,WAAU,aAAY,aAAY,CAAC,EAI5G,OADW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CAAE,KAAM,GAAQ,KAAM,OAAM,KAAI,MAAO,OAAO,GAAS,CAAC,CAAE,CAAC,GACzF,KAIZ,IAAM,EAAS,MAFE,EAAe,EAAiB,EAAK,CAAQ,EAEhC,KAAY,GAAG,CAAU,EAEvD,OAAO,OAAO,GAAQ,OAAS,SAAW,GAAQ,KAAO,GAE3D,gBAAiB,MAAO,IAA0B,CAChD,IAAQ,OAAM,KAAI,OAAM,SAAU,EAClC,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,6CAA6C,EAKpE,OADW,MADI,MAAM,EAAS,UAAU,GAChB,gBAAgB,CAAE,KAAM,GAAQ,KAAM,OAAM,KAAI,MAAO,OAAO,GAAS,CAAC,CAAE,CAAC,GACzF,KAEd,EAGF,eAAsB,CAAyB,CAC7C,EACA,EACA,EACA,CACA,GAAI,CACF,MAAM,EAAS,QAAQ,CAAE,OAAQ,sBAAuB,OAAQ,CAAC,CAAE,QAAS,EAAe,CAAK,EAAE,OAAQ,CAAC,CAAE,CAAC,EAC9G,MAAO,EAAO,CACd,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,mCAAoC,CAAE,MAAO,EAAO,OAAQ,4BAA6B,CAAC,GAK9G,SAAS,CAA8D,CAC5E,EACA,EACA,EACA,CACA,MAAQ,UAAU,IAAgB,CAChC,GAAI,CACF,MAAM,EAA0B,EAAU,CAAK,EAC/C,MAAO,EAAO,CACd,MAAM,IAAI,EAAW,CAAE,SAAU,mCAAoC,KAAM,CAAE,OAAM,CAAE,CAAC,EAExF,OAAO,EAAK,GAAG,CAAI,GAIhB,SAAS,CAAqG,EACnH,UACA,QACA,WAAW,OAAO,SAClB,cAAc,CAAC,GAMd,CAED,IAAM,EADgB,CAAC,GAAG,EAAa,WAAY,aAAc,YAAY,EACxC,OAAO,CAAC,EAAQ,IAAe,CAClE,GAAI,CAAC,EAAQ,GAAa,OAAO,EAEjC,IAAM,EAAS,EAAQ,GAEvB,GAAI,OAAO,IAAW,WAAY,OAAO,EAGzC,IAAM,EAAgB,EAA4B,EAAQ,EAAU,CAAK,EAGzE,MAAO,IAAK,GAAS,GAAa,CAAc,GAC/C,CAAC,CAAC,EAEL,MAAO,IAAK,KAAY,CAAe,ED1QlC,IAAM,EAAiB,EAAa,CACzC,QAAS,EAAG,WAAU,aAAY,qBAChC,cAA8B,CAAC,EAAiB,CAC9C,IAAM,EAAiB,EAAsB,CAAE,SAAQ,kBAAiB,YAAW,CAAC,EAE9E,EAAW,EACd,OAAO,CAAC,IAAU,IAAU,EAAM,QAAU,IAAU,EAAM,MAAM,EAClE,IAAI,MAAO,IAAU,CACpB,IAAM,EAAU,MAAM,EAAmB,CAAK,EACxC,EAAgB,MAAM,EAAiB,CAAK,EAElD,EAAS,IAAK,EAAe,UAAS,QAAO,YAAW,CAAC,EAC1D,EAEG,EAAiB,EAAe,SAAS,EAAM,MAAM,EACrD,EAAiB,EAAe,SAAS,EAAM,MAAM,EAG3D,GAAI,EAAgB,CAClB,IAAM,EAAgB,MAAM,EAAmB,EAAM,MAAM,EACrD,EAAsB,MAAM,EAAiB,EAAM,MAAM,EAC/D,EAAS,IAAK,EAAqB,QAAS,EAAe,MAAO,EAAM,OAAQ,YAAW,CAAC,EAE9F,GAAI,EAAgB,CAClB,IAAM,EAAgB,MAAM,EAAmB,EAAM,MAAM,EACrD,EAAsB,MAAM,EAAiB,EAAM,MAAM,EAC/D,EAAS,IAAK,EAAqB,QAAS,EAAe,MAAO,EAAM,OAAQ,YAAW,CAAC,EAM9F,OAFA,MAAM,QAAQ,IAAI,CAAQ,EAEnB,IAEX,KAAM,kBACN,gBAAiB,CACf,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,QACN,EAAM,YACN,EAAM,OACN,EAAM,KACN,EAAM,SACN,EAAM,SACN,EAAM,OACN,EAAM,SACN,EAAM,KACN,EAAM,SACN,EAAM,SACN,EAAM,QACN,EAAM,OACN,EAAM,OACN,EAAM,UACN,EAAM,MACN,EAAM,MACR,EACA,WAAY,EAAa,QAC3B,CAAC,EAEY,EAA4B,EAAyB,CAAc,EAEhF,eAAe,CAAgB,CAAC,EAAmD,CACjF,IAAQ,SAAU,KAAa,sBAC/B,OAAO,EAAM,CAAK,EACf,KAAK,EAAM,OAAQ,SAAY,CAC9B,IAAQ,oBAAqB,KAAa,oCACpC,EAAiB,OAAO,UAAU,OACxC,GAAI,CAAC,EAAgB,MAAM,IAAI,EAAW,2BAA2B,EAErE,MAAO,IADS,MAAM,EAAiB,CAAE,OAAQ,CAAe,CAAC,CAC7C,EACrB,EAEA,KAAK,EAAM,KAAM,EAAM,UAAW,SAAY,CAC7C,IAAQ,mBAAkB,sBAAqB,kBAAmB,KAAa,oCACzE,EAAW,IAAU,EAAM,KAAO,EAAiB,EAEzD,MAAO,IADS,MAAM,EAAiB,CAAyD,EAG9F,QAAS,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAW,EAAG,EAAG,qBAAqB,EACtG,SAAU,CAAC,IAA8B,EAAe,IAAK,EAAI,UAAS,EAAG,kBAAkB,CACjG,EACD,EAEA,KAAK,EAAM,OAAQ,EAAM,OAAQ,SAAY,CAC5C,IAAQ,oBAAqB,KAAa,oCACpC,EAAW,MAAM,EAAoB,CAA0C,EAC/E,EAAU,MAAM,EAAiB,CAAyD,EAChG,OAAO,EAA2B,CAAE,QAAO,WAAU,QAAS,IAAK,EAAS,SAAU,CAAe,CAAE,CAAC,EACzG,EAEA,KAAK,GAAG,EAAY,SAAY,CAC/B,IAAQ,kBAAmB,KAAa,kCAExC,MAAO,IADS,MAAM,EAAe,CAAkB,EAClC,SAAU,CAAe,EAC/C,EAEA,KACC,EAAM,SACN,EAAM,UACN,EAAM,KACN,EAAM,kBACN,EAAM,SACN,EAAM,SACN,EAAM,QACN,EAAM,OACN,SAAY,CACV,IAAQ,uBAAsB,0BAA2B,KAAa,4BAC9D,iBAAkB,KAAa,kCAC/B,mBAAoB,KAAa,kBACnC,EAAyB,MAAM,EAAoB,CAAiB,EAE1E,GAAI,CAAC,EACH,MAAM,IAAI,EAAW,2BAA2B,EAGlD,IAAM,EAAW,IAAI,EAAgB,EAAwB,KAAK,EAC5D,EAAS,MAAM,EAAS,UAAU,EAClC,EAAU,MAAM,EAAc,EAAmB,CAAE,WAAU,QAAO,CAAC,EACrE,EAAkB,EAAmB,EAAU,CAAiB,EAEtE,GAAI,CACF,GAAI,IAAU,EAAM,SAAU,CAC5B,IAAM,EAAgB,EAAQ,iBAAiB,EAC/C,MAAM,EAAuB,EAAU,EAAO,CAAa,GAE7D,KAAM,CACN,MAAM,IAAI,EAAW,CACnB,SAAU,yCACV,KAAM,CAAE,QAAO,OAAQ,EAAa,QAAS,CAC/C,CAAC,EAGH,OAAO,EAAqB,CAAE,QAAO,WAAU,QAAS,IAAK,KAAY,CAAgB,CAAE,CAAC,EAEhG,EAEC,KAAK,EAAM,OAAQ,SAAY,CAC9B,IAAQ,oBAAqB,KAAa,oCAE1C,MAAO,IADS,MAAM,EAAiB,EAClB,SAAU,CAAe,EAC/C,EAEA,KAAK,EAAM,SAAU,SAAY,CAChC,IAAQ,uBAAwB,KAAa,uCAE7C,MAAO,IADS,MAAM,EAAoB,CAAuB,EAC5C,SAAU,CAAe,EAC/C,EAEA,UAAU,SAAY,IAAI",
|
|
9
|
+
"debugId": "F6477614ED5D506664756E2164756E21",
|
|
10
|
+
"names": []
|
|
11
|
+
}
|