@dynamic-labs-sdk/tron 0.2.3 → 0.3.0
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/TronNetworkProvider.types.d.ts +8 -0
- package/dist/TronNetworkProvider.types.d.ts.map +1 -0
- package/dist/TronWalletAccount.types.d.ts +8 -0
- package/dist/TronWalletAccount.types.d.ts.map +1 -0
- package/dist/TronWalletProvider.types.d.ts +22 -0
- package/dist/TronWalletProvider.types.d.ts.map +1 -0
- package/dist/addTronWalletAdaptersExtension-BzQOeaSX.cjs.js +177 -0
- package/dist/addTronWalletAdaptersExtension-BzQOeaSX.cjs.js.map +1 -0
- package/dist/addTronWalletAdaptersExtension-CODXe59h.esm.js +160 -0
- package/dist/addTronWalletAdaptersExtension-CODXe59h.esm.js.map +1 -0
- package/dist/errors/NotTronProviderError/NotTronProviderError.d.ts +8 -0
- package/dist/errors/NotTronProviderError/NotTronProviderError.d.ts.map +1 -0
- package/dist/errors/NotTronProviderError/index.d.ts +2 -0
- package/dist/errors/NotTronProviderError/index.d.ts.map +1 -0
- package/dist/exports/index.d.ts +7 -0
- package/dist/exports/index.d.ts.map +1 -1
- package/dist/getTronWeb/getTronWeb.d.ts +16 -0
- package/dist/getTronWeb/getTronWeb.d.ts.map +1 -0
- package/dist/getTronWeb/index.d.ts +2 -0
- package/dist/getTronWeb/index.d.ts.map +1 -0
- package/dist/index.cjs.js +71 -1
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +69 -3
- package/dist/index.esm.js.map +1 -1
- package/dist/isTronNetworkProvider/index.d.ts +2 -0
- package/dist/isTronNetworkProvider/index.d.ts.map +1 -0
- package/dist/isTronNetworkProvider/isTronNetworkProvider.d.ts +4 -0
- package/dist/isTronNetworkProvider/isTronNetworkProvider.d.ts.map +1 -0
- package/dist/isTronWalletAccount/index.d.ts +2 -0
- package/dist/isTronWalletAccount/index.d.ts.map +1 -0
- package/dist/isTronWalletAccount/isTronWalletAccount.d.ts +4 -0
- package/dist/isTronWalletAccount/isTronWalletAccount.d.ts.map +1 -0
- package/dist/isTronWalletProvider/index.d.ts +2 -0
- package/dist/isTronWalletProvider/index.d.ts.map +1 -0
- package/dist/isTronWalletProvider/isTronWalletProvider.d.ts +4 -0
- package/dist/isTronWalletProvider/isTronWalletProvider.d.ts.map +1 -0
- package/dist/registerTronNetworkProviderBuilder/index.d.ts +2 -0
- package/dist/registerTronNetworkProviderBuilder/index.d.ts.map +1 -0
- package/dist/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.d.ts +3 -0
- package/dist/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.d.ts.map +1 -0
- package/dist/sendTransaction/index.d.ts +2 -0
- package/dist/sendTransaction/index.d.ts.map +1 -0
- package/dist/sendTransaction/sendTransaction.d.ts +19 -0
- package/dist/sendTransaction/sendTransaction.d.ts.map +1 -0
- package/dist/tsconfig.lib.tsbuildinfo +1 -1
- package/dist/utils/constants.d.ts +2 -0
- package/dist/utils/constants.d.ts.map +1 -0
- package/dist/utils/convertChainIdToDecimal/convertChainIdToDecimal.d.ts +2 -0
- package/dist/utils/convertChainIdToDecimal/convertChainIdToDecimal.d.ts.map +1 -0
- package/dist/utils/convertChainIdToDecimal/index.d.ts +2 -0
- package/dist/utils/convertChainIdToDecimal/index.d.ts.map +1 -0
- package/dist/utils/createTronNetworkProvider/createTronNetworkProvider.d.ts +4 -0
- package/dist/utils/createTronNetworkProvider/createTronNetworkProvider.d.ts.map +1 -0
- package/dist/utils/createTronNetworkProvider/index.d.ts +2 -0
- package/dist/utils/createTronNetworkProvider/index.d.ts.map +1 -0
- package/dist/utils/fetchTronBalance/fetchTronBalance.d.ts +8 -0
- package/dist/utils/fetchTronBalance/fetchTronBalance.d.ts.map +1 -0
- package/dist/utils/fetchTronBalance/index.d.ts +2 -0
- package/dist/utils/fetchTronBalance/index.d.ts.map +1 -0
- package/dist/walletAdapters/addTronWalletAdaptersExtension/addTronWalletAdaptersExtension.d.ts.map +1 -1
- package/dist/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.d.ts +10 -0
- package/dist/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.d.ts.map +1 -0
- package/dist/walletAdapters/utils/createWalletProviderForTronWalletAdapter/index.d.ts +2 -0
- package/dist/walletAdapters/utils/createWalletProviderForTronWalletAdapter/index.d.ts.map +1 -0
- package/dist/walletAdapters.cjs.js +1 -1
- package/dist/walletAdapters.esm.js +1 -1
- package/package.json +12 -8
- package/dist/addTronWalletAdaptersExtension-BmdGLluT.esm.js +0 -25
- package/dist/addTronWalletAdaptersExtension-BmdGLluT.esm.js.map +0 -1
- package/dist/addTronWalletAdaptersExtension-CsJRLzRp.cjs.js +0 -42
- package/dist/addTronWalletAdaptersExtension-CsJRLzRp.cjs.js.map +0 -1
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { BaseNetworkProvider } from '@dynamic-labs-sdk/client/core';
|
|
2
|
+
export type TronNetworkProvider = BaseNetworkProvider<'TRON'>;
|
|
3
|
+
declare global {
|
|
4
|
+
interface NetworkProviderMap {
|
|
5
|
+
TRON: TronNetworkProvider;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=TronNetworkProvider.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TronNetworkProvider.types.d.ts","sourceRoot":"","sources":["../src/TronNetworkProvider.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAEzE,MAAM,MAAM,mBAAmB,GAAG,mBAAmB,CAAC,MAAM,CAAC,CAAC;AAE9D,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,kBAAkB;QAC1B,IAAI,EAAE,mBAAmB,CAAC;KAC3B;CACF"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { BaseWalletAccount } from '@dynamic-labs-sdk/client/core';
|
|
2
|
+
export type TronWalletAccount = BaseWalletAccount<'TRON'>;
|
|
3
|
+
declare global {
|
|
4
|
+
interface WalletAccountMap {
|
|
5
|
+
TRON: TronWalletAccount;
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=TronWalletAccount.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TronWalletAccount.types.d.ts","sourceRoot":"","sources":["../src/TronWalletAccount.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,+BAA+B,CAAC;AAEvE,MAAM,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC;AAE1D,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,gBAAgB;QACxB,IAAI,EAAE,iBAAiB,CAAC;KACzB;CACF"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import type { WalletProvider } from '@dynamic-labs-sdk/client/core';
|
|
2
|
+
import type { Adapter, Network } from '@tronweb3/tronwallet-abstract-adapter';
|
|
3
|
+
import type { TronWeb, Types } from 'tronweb';
|
|
4
|
+
import type { TronWalletAccount } from './TronWalletAccount.types';
|
|
5
|
+
export type { TronWeb } from 'tronweb';
|
|
6
|
+
export type TronBroadcastReturnSignedTransaction = Types.BroadcastReturn<Types.SignedTransaction>;
|
|
7
|
+
export type TronAdapter = Adapter & {
|
|
8
|
+
_wallet?: {
|
|
9
|
+
tron?: {
|
|
10
|
+
tronWeb?: TronWeb;
|
|
11
|
+
};
|
|
12
|
+
tronWeb?: TronWeb;
|
|
13
|
+
};
|
|
14
|
+
network(): Promise<Network>;
|
|
15
|
+
};
|
|
16
|
+
export type TronWalletProvider = WalletProvider & {
|
|
17
|
+
chain: 'TRON';
|
|
18
|
+
getTronWeb: (args: {
|
|
19
|
+
walletAccount: TronWalletAccount;
|
|
20
|
+
}) => Promise<TronWeb>;
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=TronWalletProvider.types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TronWalletProvider.types.d.ts","sourceRoot":"","sources":["../src/TronWalletProvider.types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AACpE,OAAO,KAAK,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,uCAAuC,CAAC;AAC9E,OAAO,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAE9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,2BAA2B,CAAC;AAEnE,YAAY,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAEvC,MAAM,MAAM,oCAAoC,GAC9C,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC;AAEjD,MAAM,MAAM,WAAW,GAAG,OAAO,GAAG;IAClC,OAAO,CAAC,EAAE;QACR,IAAI,CAAC,EAAE;YACL,OAAO,CAAC,EAAE,OAAO,CAAC;SACnB,CAAC;QACF,OAAO,CAAC,EAAE,OAAO,CAAC;KACnB,CAAC;IACF,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;CAC7B,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,cAAc,GAAG;IAChD,KAAK,EAAE,MAAM,CAAC;IACd,UAAU,EAAE,CAAC,IAAI,EAAE;QAAE,aAAa,EAAE,iBAAiB,CAAA;KAAE,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;CAC9E,CAAC"}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
let _dynamic_labs_sdk_client_core = require("@dynamic-labs-sdk/client/core");
|
|
2
|
+
let _tronweb3_tronwallet_adapters = require("@tronweb3/tronwallet-adapters");
|
|
3
|
+
let tronweb = require("tronweb");
|
|
4
|
+
let _dynamic_labs_sdk_client = require("@dynamic-labs-sdk/client");
|
|
5
|
+
let _dynamic_labs_sdk_api_core = require("@dynamic-labs/sdk-api-core");
|
|
6
|
+
let _tronweb3_tronwallet_abstract_adapter = require("@tronweb3/tronwallet-abstract-adapter");
|
|
7
|
+
|
|
8
|
+
//#region package.json
|
|
9
|
+
var name = "@dynamic-labs-sdk/tron";
|
|
10
|
+
var version = "0.3.0";
|
|
11
|
+
|
|
12
|
+
//#endregion
|
|
13
|
+
//#region src/utils/constants.ts
|
|
14
|
+
const SUN_PER_TRX = 1e6;
|
|
15
|
+
|
|
16
|
+
//#endregion
|
|
17
|
+
//#region src/utils/fetchTronBalance/fetchTronBalance.ts
|
|
18
|
+
const fetchTronBalance = async ({ address, networkData }) => {
|
|
19
|
+
const balanceInSun = await new tronweb.TronWeb({ fullHost: networkData.rpcUrls.http[0] }).trx.getBalance(address);
|
|
20
|
+
return (Number(balanceInSun) / SUN_PER_TRX).toString();
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
//#endregion
|
|
24
|
+
//#region src/utils/createTronNetworkProvider/createTronNetworkProvider.ts
|
|
25
|
+
const createTronNetworkProvider = (networkData) => ({
|
|
26
|
+
...(0, _dynamic_labs_sdk_client_core.createBaseNetworkProvider)("TRON", networkData),
|
|
27
|
+
getBalance: async ({ address }) => ({ balance: await fetchTronBalance({
|
|
28
|
+
address,
|
|
29
|
+
networkData
|
|
30
|
+
}) })
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
//#endregion
|
|
34
|
+
//#region src/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.ts
|
|
35
|
+
const registerTronNetworkProviderBuilder = (client) => {
|
|
36
|
+
const networkProviderBuilderRegistry = (0, _dynamic_labs_sdk_client_core.getNetworkProviderBuilderRegistry)(client);
|
|
37
|
+
if (networkProviderBuilderRegistry.get().get("TRON")) return;
|
|
38
|
+
networkProviderBuilderRegistry.register({
|
|
39
|
+
builder: createTronNetworkProvider,
|
|
40
|
+
chain: "TRON"
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
//#endregion
|
|
45
|
+
//#region src/utils/convertChainIdToDecimal/convertChainIdToDecimal.ts
|
|
46
|
+
const convertChainIdToDecimal = (chainId) => chainId.startsWith("0x") ? parseInt(chainId, 16).toString() : chainId;
|
|
47
|
+
|
|
48
|
+
//#endregion
|
|
49
|
+
//#region src/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.ts
|
|
50
|
+
const createWalletProviderForTronWalletAdapter = ({ dynamicClient, adapter }) => {
|
|
51
|
+
const chain = "TRON";
|
|
52
|
+
const tronAdapter = adapter;
|
|
53
|
+
if (tronAdapter.readyState !== _tronweb3_tronwallet_abstract_adapter.WalletReadyState.Found) return;
|
|
54
|
+
const metadata = {
|
|
55
|
+
displayName: tronAdapter.name,
|
|
56
|
+
icon: tronAdapter.icon
|
|
57
|
+
};
|
|
58
|
+
const walletProviderType = _dynamic_labs_sdk_api_core.WalletProviderEnum.BrowserExtension;
|
|
59
|
+
const key = (0, _dynamic_labs_sdk_client_core.formatWalletProviderKey)({
|
|
60
|
+
chain,
|
|
61
|
+
displayName: metadata.displayName,
|
|
62
|
+
walletProviderType
|
|
63
|
+
});
|
|
64
|
+
const connect = async () => {
|
|
65
|
+
await tronAdapter.connect();
|
|
66
|
+
const startTime = Date.now();
|
|
67
|
+
while (!tronAdapter.address?.length && Date.now() - startTime < 1e3) await new Promise((resolve) => setTimeout(resolve, 50));
|
|
68
|
+
return { addresses: tronAdapter.address ? [{ address: tronAdapter.address }] : [] };
|
|
69
|
+
};
|
|
70
|
+
const disconnect = async () => {
|
|
71
|
+
return tronAdapter.disconnect();
|
|
72
|
+
};
|
|
73
|
+
const getActiveNetworkId = async () => {
|
|
74
|
+
return { networkId: convertChainIdToDecimal((await tronAdapter.network()).chainId) };
|
|
75
|
+
};
|
|
76
|
+
const getConnectedAddresses = async () => {
|
|
77
|
+
return { addresses: tronAdapter.address ? [tronAdapter.address] : [] };
|
|
78
|
+
};
|
|
79
|
+
const signMessage = async ({ message, walletAccount }) => {
|
|
80
|
+
(0, _dynamic_labs_sdk_client_core.assertDefined)(walletAccount, "Wallet account not found");
|
|
81
|
+
await (0, _dynamic_labs_sdk_client.assertWalletAccountSigningAvailability)({ walletAccount }, dynamicClient);
|
|
82
|
+
return { signature: await tronAdapter.signMessage(message) };
|
|
83
|
+
};
|
|
84
|
+
const getTronWeb = async ({ walletAccount }) => {
|
|
85
|
+
const tronWeb = tronAdapter._wallet?.tronWeb || tronAdapter._wallet?.tron?.tronWeb;
|
|
86
|
+
if (tronWeb) return tronWeb;
|
|
87
|
+
const activeNetworkData = await (0, _dynamic_labs_sdk_client.getActiveNetworkData)({ walletAccount }, dynamicClient);
|
|
88
|
+
(0, _dynamic_labs_sdk_client_core.assertDefined)(activeNetworkData, "No active network data found");
|
|
89
|
+
const url = activeNetworkData.networkData?.rpcUrls.http[0];
|
|
90
|
+
(0, _dynamic_labs_sdk_client_core.assertDefined)(url, "No RPC URL found for active network");
|
|
91
|
+
return new tronweb.TronWeb({ fullHost: url });
|
|
92
|
+
};
|
|
93
|
+
return {
|
|
94
|
+
chain,
|
|
95
|
+
connect,
|
|
96
|
+
disconnect,
|
|
97
|
+
getActiveNetworkId,
|
|
98
|
+
getConnectedAddresses,
|
|
99
|
+
getTronWeb,
|
|
100
|
+
groupKey: (0, _dynamic_labs_sdk_client_core.formatWalletProviderGroupKey)(metadata.displayName),
|
|
101
|
+
key,
|
|
102
|
+
metadata,
|
|
103
|
+
signMessage,
|
|
104
|
+
walletProviderType
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
//#endregion
|
|
109
|
+
//#region src/walletAdapters/addTronWalletAdaptersExtension/addTronWalletAdaptersExtension.ts
|
|
110
|
+
const TRON_WALLET_ADAPTERS_EXTENSION_KEY = "tronWalletAdapters";
|
|
111
|
+
/**
|
|
112
|
+
* Adds the Tron Wallet Adapters extension to the Dynamic client.
|
|
113
|
+
*
|
|
114
|
+
* This extension enables integration with wallets that have related Tron Wallet Adapters ('@tronweb3/tronwallet-adapters'),
|
|
115
|
+
* automatically registering compatible wallets for use with the Dynamic SDK.
|
|
116
|
+
*
|
|
117
|
+
* @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
|
|
118
|
+
*/
|
|
119
|
+
const addTronWalletAdaptersExtension = (client = (0, _dynamic_labs_sdk_client_core.getDefaultClient)()) => {
|
|
120
|
+
if ((0, _dynamic_labs_sdk_client_core.hasExtension)({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client)) return;
|
|
121
|
+
(0, _dynamic_labs_sdk_client_core.registerExtension)({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client);
|
|
122
|
+
registerTronNetworkProviderBuilder(client);
|
|
123
|
+
const walletProviderRegistry = (0, _dynamic_labs_sdk_client_core.getWalletProviderRegistry)(client);
|
|
124
|
+
const tronWalletProviders = [];
|
|
125
|
+
const okxWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
126
|
+
adapter: new _tronweb3_tronwallet_adapters.OkxWalletAdapter(),
|
|
127
|
+
dynamicClient: client
|
|
128
|
+
});
|
|
129
|
+
if (okxWalletProvider) tronWalletProviders.push(okxWalletProvider);
|
|
130
|
+
const tronLinkWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
131
|
+
adapter: new _tronweb3_tronwallet_adapters.TronLinkAdapter(),
|
|
132
|
+
dynamicClient: client
|
|
133
|
+
});
|
|
134
|
+
if (tronLinkWalletProvider) tronWalletProviders.push(tronLinkWalletProvider);
|
|
135
|
+
const trustWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
136
|
+
adapter: new _tronweb3_tronwallet_adapters.TrustAdapter(),
|
|
137
|
+
dynamicClient: client
|
|
138
|
+
});
|
|
139
|
+
if (trustWalletProvider) tronWalletProviders.push(trustWalletProvider);
|
|
140
|
+
const tokenPocketWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
141
|
+
adapter: new _tronweb3_tronwallet_adapters.TokenPocketAdapter(),
|
|
142
|
+
dynamicClient: client
|
|
143
|
+
});
|
|
144
|
+
if (tokenPocketWalletProvider) tronWalletProviders.push(tokenPocketWalletProvider);
|
|
145
|
+
const bitgetWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
146
|
+
adapter: new _tronweb3_tronwallet_adapters.BitKeepAdapter(),
|
|
147
|
+
dynamicClient: client
|
|
148
|
+
});
|
|
149
|
+
if (bitgetWalletProvider) tronWalletProviders.push(bitgetWalletProvider);
|
|
150
|
+
tronWalletProviders.forEach((walletProvider) => {
|
|
151
|
+
walletProviderRegistry.register({
|
|
152
|
+
priority: _dynamic_labs_sdk_client_core.WalletProviderPriority.WINDOW_INJECT,
|
|
153
|
+
walletProvider
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
};
|
|
157
|
+
|
|
158
|
+
//#endregion
|
|
159
|
+
Object.defineProperty(exports, 'addTronWalletAdaptersExtension', {
|
|
160
|
+
enumerable: true,
|
|
161
|
+
get: function () {
|
|
162
|
+
return addTronWalletAdaptersExtension;
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
Object.defineProperty(exports, 'name', {
|
|
166
|
+
enumerable: true,
|
|
167
|
+
get: function () {
|
|
168
|
+
return name;
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
Object.defineProperty(exports, 'version', {
|
|
172
|
+
enumerable: true,
|
|
173
|
+
get: function () {
|
|
174
|
+
return version;
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
//# sourceMappingURL=addTronWalletAdaptersExtension-BzQOeaSX.cjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addTronWalletAdaptersExtension-BzQOeaSX.cjs.js","names":["TronWeb","chain: Chain","WalletReadyState","metadata: WalletProviderMetadata","WalletProviderEnum","connect: TronWalletProvider['connect']","disconnect: TronWalletProvider['disconnect']","getActiveNetworkId: TronWalletProvider['getActiveNetworkId']","getConnectedAddresses: TronWalletProvider['getConnectedAddresses']","signMessage: TronWalletProvider['signMessage']","getTronWeb: TronWalletProvider['getTronWeb']","TronWeb","tronWalletProviders: TronWalletProvider[]","OkxWalletAdapter","TronLinkAdapter","TrustAdapter","TokenPocketAdapter","BitKeepAdapter","WalletProviderPriority"],"sources":["../package.json","../src/utils/constants.ts","../src/utils/fetchTronBalance/fetchTronBalance.ts","../src/utils/createTronNetworkProvider/createTronNetworkProvider.ts","../src/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.ts","../src/utils/convertChainIdToDecimal/convertChainIdToDecimal.ts","../src/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.ts","../src/walletAdapters/addTronWalletAdaptersExtension/addTronWalletAdaptersExtension.ts"],"sourcesContent":["","// 1 TRX = 10^6 SUN (similar to wei for Ethereum)\nexport const SUN_PER_TRX = 1e6;\n","import type { NetworkData } from '@dynamic-labs-sdk/client';\nimport { TronWeb } from 'tronweb';\n\nimport { SUN_PER_TRX } from '../constants';\n\ntype FetchTronBalanceParams = {\n address: string;\n networkData: NetworkData;\n};\n\nexport const fetchTronBalance = async ({\n address,\n networkData,\n}: FetchTronBalanceParams): Promise<string | null> => {\n const tronWeb = new TronWeb({\n fullHost: networkData.rpcUrls.http[0],\n });\n\n const balanceInSun = await tronWeb.trx.getBalance(address);\n\n return (Number(balanceInSun) / SUN_PER_TRX).toString();\n};\n","import type { NetworkData } from '@dynamic-labs-sdk/client';\nimport { createBaseNetworkProvider } from '@dynamic-labs-sdk/client/core';\n\nimport type { TronNetworkProvider } from '../../TronNetworkProvider.types';\nimport { fetchTronBalance } from '../fetchTronBalance';\n\nexport const createTronNetworkProvider = (\n networkData: NetworkData\n): TronNetworkProvider => ({\n ...createBaseNetworkProvider('TRON', networkData),\n getBalance: async ({ address }) => ({\n balance: await fetchTronBalance({\n address,\n networkData,\n }),\n }),\n});\n","import type { DynamicClient } from '@dynamic-labs-sdk/client';\nimport { getNetworkProviderBuilderRegistry } from '@dynamic-labs-sdk/client/core';\n\nimport { createTronNetworkProvider } from '../utils/createTronNetworkProvider';\n\nexport const registerTronNetworkProviderBuilder = (\n client: DynamicClient\n): void => {\n const networkProviderBuilderRegistry =\n getNetworkProviderBuilderRegistry(client);\n\n // If the Tron network provider builder is already registered, return.\n if (networkProviderBuilderRegistry.get().get('TRON')) {\n return;\n }\n\n networkProviderBuilderRegistry.register({\n builder: createTronNetworkProvider,\n chain: 'TRON',\n });\n};\n","export const convertChainIdToDecimal = (chainId: string): string =>\n chainId.startsWith('0x') ? parseInt(chainId, 16).toString() : chainId;\n","import {\n type Chain,\n type DynamicClient,\n type WalletProviderMetadata,\n assertWalletAccountSigningAvailability,\n getActiveNetworkData,\n} from '@dynamic-labs-sdk/client';\nimport {\n assertDefined,\n formatWalletProviderGroupKey,\n formatWalletProviderKey,\n} from '@dynamic-labs-sdk/client/core';\nimport { WalletProviderEnum } from '@dynamic-labs/sdk-api-core';\nimport type { Adapter } from '@tronweb3/tronwallet-abstract-adapter';\nimport { WalletReadyState } from '@tronweb3/tronwallet-abstract-adapter';\nimport { TronWeb } from 'tronweb';\n\nimport type {\n TronAdapter,\n TronWalletProvider,\n} from '../../../TronWalletProvider.types';\nimport { convertChainIdToDecimal } from '../../../utils/convertChainIdToDecimal';\n\ntype CreateWalletProviderForTronWalletAdapterParams = {\n adapter: Adapter;\n dynamicClient: DynamicClient;\n};\n\nexport const createWalletProviderForTronWalletAdapter = ({\n dynamicClient,\n adapter,\n}: CreateWalletProviderForTronWalletAdapterParams):\n | TronWalletProvider\n | undefined => {\n const chain: Chain = 'TRON';\n\n // we have to do this type cast because these adapters have the _wallet property private,\n // but we need to access it to get the TronWeb instance\n const tronAdapter = adapter as unknown as TronAdapter;\n\n // Wallet is not installed\n if (tronAdapter.readyState !== WalletReadyState.Found) {\n return undefined;\n }\n\n const metadata: WalletProviderMetadata = {\n displayName: tronAdapter.name,\n icon: tronAdapter.icon,\n };\n\n const walletProviderType = WalletProviderEnum.BrowserExtension;\n\n const key = formatWalletProviderKey({\n chain,\n displayName: metadata.displayName,\n walletProviderType,\n });\n\n const connect: TronWalletProvider['connect'] = async () => {\n await tronAdapter.connect();\n\n // Some wallets (Trust, Bitget) populate the address asynchronously after connect()\n // Wait briefly for the address to be populated by the wallet\n const startTime = Date.now();\n while (!tronAdapter.address?.length && Date.now() - startTime < 1000) {\n await new Promise((resolve) => setTimeout(resolve, 50));\n }\n\n return {\n addresses: tronAdapter.address ? [{ address: tronAdapter.address }] : [],\n };\n };\n\n const disconnect: TronWalletProvider['disconnect'] = async () => {\n return tronAdapter.disconnect();\n };\n\n const getActiveNetworkId: TronWalletProvider['getActiveNetworkId'] =\n async () => {\n const networkInfo = await tronAdapter.network();\n\n const networkId = convertChainIdToDecimal(networkInfo.chainId);\n\n return { networkId };\n };\n\n const getConnectedAddresses: TronWalletProvider['getConnectedAddresses'] =\n async () => {\n return {\n addresses: tronAdapter.address ? [tronAdapter.address] : [],\n };\n };\n\n const signMessage: TronWalletProvider['signMessage'] = async ({\n message,\n walletAccount,\n }) => {\n assertDefined(walletAccount, 'Wallet account not found');\n\n await assertWalletAccountSigningAvailability(\n { walletAccount },\n dynamicClient\n );\n\n const signedMessage = await tronAdapter.signMessage(message);\n\n return {\n signature: signedMessage,\n };\n };\n\n const getTronWeb: TronWalletProvider['getTronWeb'] = async ({\n walletAccount,\n }) => {\n const tronWeb =\n tronAdapter._wallet?.tronWeb || tronAdapter._wallet?.tron?.tronWeb;\n\n if (tronWeb) {\n return tronWeb;\n }\n\n const activeNetworkData = await getActiveNetworkData(\n { walletAccount },\n dynamicClient\n );\n assertDefined(activeNetworkData, 'No active network data found');\n\n const url = activeNetworkData.networkData?.rpcUrls.http[0];\n assertDefined(url, 'No RPC URL found for active network');\n\n return new TronWeb({ fullHost: url });\n };\n\n return {\n chain,\n connect,\n disconnect,\n getActiveNetworkId,\n getConnectedAddresses,\n getTronWeb,\n groupKey: formatWalletProviderGroupKey(metadata.displayName),\n key,\n metadata,\n signMessage,\n walletProviderType,\n };\n};\n","import {\n WalletProviderPriority,\n getDefaultClient,\n getWalletProviderRegistry,\n hasExtension,\n registerExtension,\n} from '@dynamic-labs-sdk/client/core';\nimport {\n BitKeepAdapter,\n OkxWalletAdapter,\n TokenPocketAdapter,\n TronLinkAdapter,\n TrustAdapter,\n} from '@tronweb3/tronwallet-adapters';\n\nimport { registerTronNetworkProviderBuilder } from '../../registerTronNetworkProviderBuilder';\nimport type { TronWalletProvider } from '../../TronWalletProvider.types';\nimport { createWalletProviderForTronWalletAdapter } from '../utils/createWalletProviderForTronWalletAdapter';\n\nexport const TRON_WALLET_ADAPTERS_EXTENSION_KEY = 'tronWalletAdapters';\n\n/**\n * Adds the Tron Wallet Adapters extension to the Dynamic client.\n *\n * This extension enables integration with wallets that have related Tron Wallet Adapters ('@tronweb3/tronwallet-adapters'),\n * automatically registering compatible wallets for use with the Dynamic SDK.\n *\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n */\nexport const addTronWalletAdaptersExtension = (\n client = getDefaultClient()\n): void => {\n if (\n hasExtension({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client)\n ) {\n return;\n }\n\n registerExtension(\n { extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY },\n client\n );\n\n registerTronNetworkProviderBuilder(client);\n\n const walletProviderRegistry = getWalletProviderRegistry(client);\n\n const tronWalletProviders: TronWalletProvider[] = [];\n\n // Create and register OKX wallet provider\n const okxWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new OkxWalletAdapter(),\n dynamicClient: client,\n });\n if (okxWalletProvider) {\n tronWalletProviders.push(okxWalletProvider);\n }\n\n // Create and register TronLink wallet provider\n const tronLinkWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TronLinkAdapter(),\n dynamicClient: client,\n });\n if (tronLinkWalletProvider) {\n tronWalletProviders.push(tronLinkWalletProvider);\n }\n\n // Create and register Trust wallet provider\n const trustWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TrustAdapter(),\n dynamicClient: client,\n });\n if (trustWalletProvider) {\n tronWalletProviders.push(trustWalletProvider);\n }\n\n // Create and register TokenPocket wallet provider\n const tokenPocketWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TokenPocketAdapter(),\n dynamicClient: client,\n });\n if (tokenPocketWalletProvider) {\n tronWalletProviders.push(tokenPocketWalletProvider);\n }\n\n // Create and register Bitget wallet provider\n const bitgetWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new BitKeepAdapter(),\n dynamicClient: client,\n });\n if (bitgetWalletProvider) {\n tronWalletProviders.push(bitgetWalletProvider);\n }\n\n tronWalletProviders.forEach((walletProvider) => {\n walletProviderRegistry.register({\n priority: WalletProviderPriority.WINDOW_INJECT,\n walletProvider,\n });\n });\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { WalletProviderPriority, assertDefined, createBaseNetworkProvider, formatWalletProviderGroupKey, formatWalletProviderKey, getDefaultClient, getNetworkProviderBuilderRegistry, getWalletProviderRegistry, hasExtension, registerExtension } from "@dynamic-labs-sdk/client/core";
|
|
2
|
+
import { BitKeepAdapter, OkxWalletAdapter, TokenPocketAdapter, TronLinkAdapter, TrustAdapter } from "@tronweb3/tronwallet-adapters";
|
|
3
|
+
import { TronWeb } from "tronweb";
|
|
4
|
+
import { assertWalletAccountSigningAvailability, getActiveNetworkData } from "@dynamic-labs-sdk/client";
|
|
5
|
+
import { WalletProviderEnum } from "@dynamic-labs/sdk-api-core";
|
|
6
|
+
import { WalletReadyState } from "@tronweb3/tronwallet-abstract-adapter";
|
|
7
|
+
|
|
8
|
+
//#region package.json
|
|
9
|
+
var name = "@dynamic-labs-sdk/tron";
|
|
10
|
+
var version = "0.3.0";
|
|
11
|
+
|
|
12
|
+
//#endregion
|
|
13
|
+
//#region src/utils/constants.ts
|
|
14
|
+
const SUN_PER_TRX = 1e6;
|
|
15
|
+
|
|
16
|
+
//#endregion
|
|
17
|
+
//#region src/utils/fetchTronBalance/fetchTronBalance.ts
|
|
18
|
+
const fetchTronBalance = async ({ address, networkData }) => {
|
|
19
|
+
const balanceInSun = await new TronWeb({ fullHost: networkData.rpcUrls.http[0] }).trx.getBalance(address);
|
|
20
|
+
return (Number(balanceInSun) / SUN_PER_TRX).toString();
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
//#endregion
|
|
24
|
+
//#region src/utils/createTronNetworkProvider/createTronNetworkProvider.ts
|
|
25
|
+
const createTronNetworkProvider = (networkData) => ({
|
|
26
|
+
...createBaseNetworkProvider("TRON", networkData),
|
|
27
|
+
getBalance: async ({ address }) => ({ balance: await fetchTronBalance({
|
|
28
|
+
address,
|
|
29
|
+
networkData
|
|
30
|
+
}) })
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
//#endregion
|
|
34
|
+
//#region src/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.ts
|
|
35
|
+
const registerTronNetworkProviderBuilder = (client) => {
|
|
36
|
+
const networkProviderBuilderRegistry = getNetworkProviderBuilderRegistry(client);
|
|
37
|
+
if (networkProviderBuilderRegistry.get().get("TRON")) return;
|
|
38
|
+
networkProviderBuilderRegistry.register({
|
|
39
|
+
builder: createTronNetworkProvider,
|
|
40
|
+
chain: "TRON"
|
|
41
|
+
});
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
//#endregion
|
|
45
|
+
//#region src/utils/convertChainIdToDecimal/convertChainIdToDecimal.ts
|
|
46
|
+
const convertChainIdToDecimal = (chainId) => chainId.startsWith("0x") ? parseInt(chainId, 16).toString() : chainId;
|
|
47
|
+
|
|
48
|
+
//#endregion
|
|
49
|
+
//#region src/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.ts
|
|
50
|
+
const createWalletProviderForTronWalletAdapter = ({ dynamicClient, adapter }) => {
|
|
51
|
+
const chain = "TRON";
|
|
52
|
+
const tronAdapter = adapter;
|
|
53
|
+
if (tronAdapter.readyState !== WalletReadyState.Found) return;
|
|
54
|
+
const metadata = {
|
|
55
|
+
displayName: tronAdapter.name,
|
|
56
|
+
icon: tronAdapter.icon
|
|
57
|
+
};
|
|
58
|
+
const walletProviderType = WalletProviderEnum.BrowserExtension;
|
|
59
|
+
const key = formatWalletProviderKey({
|
|
60
|
+
chain,
|
|
61
|
+
displayName: metadata.displayName,
|
|
62
|
+
walletProviderType
|
|
63
|
+
});
|
|
64
|
+
const connect = async () => {
|
|
65
|
+
await tronAdapter.connect();
|
|
66
|
+
const startTime = Date.now();
|
|
67
|
+
while (!tronAdapter.address?.length && Date.now() - startTime < 1e3) await new Promise((resolve) => setTimeout(resolve, 50));
|
|
68
|
+
return { addresses: tronAdapter.address ? [{ address: tronAdapter.address }] : [] };
|
|
69
|
+
};
|
|
70
|
+
const disconnect = async () => {
|
|
71
|
+
return tronAdapter.disconnect();
|
|
72
|
+
};
|
|
73
|
+
const getActiveNetworkId = async () => {
|
|
74
|
+
return { networkId: convertChainIdToDecimal((await tronAdapter.network()).chainId) };
|
|
75
|
+
};
|
|
76
|
+
const getConnectedAddresses = async () => {
|
|
77
|
+
return { addresses: tronAdapter.address ? [tronAdapter.address] : [] };
|
|
78
|
+
};
|
|
79
|
+
const signMessage = async ({ message, walletAccount }) => {
|
|
80
|
+
assertDefined(walletAccount, "Wallet account not found");
|
|
81
|
+
await assertWalletAccountSigningAvailability({ walletAccount }, dynamicClient);
|
|
82
|
+
return { signature: await tronAdapter.signMessage(message) };
|
|
83
|
+
};
|
|
84
|
+
const getTronWeb = async ({ walletAccount }) => {
|
|
85
|
+
const tronWeb = tronAdapter._wallet?.tronWeb || tronAdapter._wallet?.tron?.tronWeb;
|
|
86
|
+
if (tronWeb) return tronWeb;
|
|
87
|
+
const activeNetworkData = await getActiveNetworkData({ walletAccount }, dynamicClient);
|
|
88
|
+
assertDefined(activeNetworkData, "No active network data found");
|
|
89
|
+
const url = activeNetworkData.networkData?.rpcUrls.http[0];
|
|
90
|
+
assertDefined(url, "No RPC URL found for active network");
|
|
91
|
+
return new TronWeb({ fullHost: url });
|
|
92
|
+
};
|
|
93
|
+
return {
|
|
94
|
+
chain,
|
|
95
|
+
connect,
|
|
96
|
+
disconnect,
|
|
97
|
+
getActiveNetworkId,
|
|
98
|
+
getConnectedAddresses,
|
|
99
|
+
getTronWeb,
|
|
100
|
+
groupKey: formatWalletProviderGroupKey(metadata.displayName),
|
|
101
|
+
key,
|
|
102
|
+
metadata,
|
|
103
|
+
signMessage,
|
|
104
|
+
walletProviderType
|
|
105
|
+
};
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
//#endregion
|
|
109
|
+
//#region src/walletAdapters/addTronWalletAdaptersExtension/addTronWalletAdaptersExtension.ts
|
|
110
|
+
const TRON_WALLET_ADAPTERS_EXTENSION_KEY = "tronWalletAdapters";
|
|
111
|
+
/**
|
|
112
|
+
* Adds the Tron Wallet Adapters extension to the Dynamic client.
|
|
113
|
+
*
|
|
114
|
+
* This extension enables integration with wallets that have related Tron Wallet Adapters ('@tronweb3/tronwallet-adapters'),
|
|
115
|
+
* automatically registering compatible wallets for use with the Dynamic SDK.
|
|
116
|
+
*
|
|
117
|
+
* @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
|
|
118
|
+
*/
|
|
119
|
+
const addTronWalletAdaptersExtension = (client = getDefaultClient()) => {
|
|
120
|
+
if (hasExtension({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client)) return;
|
|
121
|
+
registerExtension({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client);
|
|
122
|
+
registerTronNetworkProviderBuilder(client);
|
|
123
|
+
const walletProviderRegistry = getWalletProviderRegistry(client);
|
|
124
|
+
const tronWalletProviders = [];
|
|
125
|
+
const okxWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
126
|
+
adapter: new OkxWalletAdapter(),
|
|
127
|
+
dynamicClient: client
|
|
128
|
+
});
|
|
129
|
+
if (okxWalletProvider) tronWalletProviders.push(okxWalletProvider);
|
|
130
|
+
const tronLinkWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
131
|
+
adapter: new TronLinkAdapter(),
|
|
132
|
+
dynamicClient: client
|
|
133
|
+
});
|
|
134
|
+
if (tronLinkWalletProvider) tronWalletProviders.push(tronLinkWalletProvider);
|
|
135
|
+
const trustWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
136
|
+
adapter: new TrustAdapter(),
|
|
137
|
+
dynamicClient: client
|
|
138
|
+
});
|
|
139
|
+
if (trustWalletProvider) tronWalletProviders.push(trustWalletProvider);
|
|
140
|
+
const tokenPocketWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
141
|
+
adapter: new TokenPocketAdapter(),
|
|
142
|
+
dynamicClient: client
|
|
143
|
+
});
|
|
144
|
+
if (tokenPocketWalletProvider) tronWalletProviders.push(tokenPocketWalletProvider);
|
|
145
|
+
const bitgetWalletProvider = createWalletProviderForTronWalletAdapter({
|
|
146
|
+
adapter: new BitKeepAdapter(),
|
|
147
|
+
dynamicClient: client
|
|
148
|
+
});
|
|
149
|
+
if (bitgetWalletProvider) tronWalletProviders.push(bitgetWalletProvider);
|
|
150
|
+
tronWalletProviders.forEach((walletProvider) => {
|
|
151
|
+
walletProviderRegistry.register({
|
|
152
|
+
priority: WalletProviderPriority.WINDOW_INJECT,
|
|
153
|
+
walletProvider
|
|
154
|
+
});
|
|
155
|
+
});
|
|
156
|
+
};
|
|
157
|
+
|
|
158
|
+
//#endregion
|
|
159
|
+
export { name as n, version as r, addTronWalletAdaptersExtension as t };
|
|
160
|
+
//# sourceMappingURL=addTronWalletAdaptersExtension-CODXe59h.esm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"addTronWalletAdaptersExtension-CODXe59h.esm.js","names":["chain: Chain","metadata: WalletProviderMetadata","connect: TronWalletProvider['connect']","disconnect: TronWalletProvider['disconnect']","getActiveNetworkId: TronWalletProvider['getActiveNetworkId']","getConnectedAddresses: TronWalletProvider['getConnectedAddresses']","signMessage: TronWalletProvider['signMessage']","getTronWeb: TronWalletProvider['getTronWeb']","tronWalletProviders: TronWalletProvider[]"],"sources":["../package.json","../src/utils/constants.ts","../src/utils/fetchTronBalance/fetchTronBalance.ts","../src/utils/createTronNetworkProvider/createTronNetworkProvider.ts","../src/registerTronNetworkProviderBuilder/registerTronNetworkProviderBuilder.ts","../src/utils/convertChainIdToDecimal/convertChainIdToDecimal.ts","../src/walletAdapters/utils/createWalletProviderForTronWalletAdapter/createWalletProviderForTronWalletAdapter.ts","../src/walletAdapters/addTronWalletAdaptersExtension/addTronWalletAdaptersExtension.ts"],"sourcesContent":["","// 1 TRX = 10^6 SUN (similar to wei for Ethereum)\nexport const SUN_PER_TRX = 1e6;\n","import type { NetworkData } from '@dynamic-labs-sdk/client';\nimport { TronWeb } from 'tronweb';\n\nimport { SUN_PER_TRX } from '../constants';\n\ntype FetchTronBalanceParams = {\n address: string;\n networkData: NetworkData;\n};\n\nexport const fetchTronBalance = async ({\n address,\n networkData,\n}: FetchTronBalanceParams): Promise<string | null> => {\n const tronWeb = new TronWeb({\n fullHost: networkData.rpcUrls.http[0],\n });\n\n const balanceInSun = await tronWeb.trx.getBalance(address);\n\n return (Number(balanceInSun) / SUN_PER_TRX).toString();\n};\n","import type { NetworkData } from '@dynamic-labs-sdk/client';\nimport { createBaseNetworkProvider } from '@dynamic-labs-sdk/client/core';\n\nimport type { TronNetworkProvider } from '../../TronNetworkProvider.types';\nimport { fetchTronBalance } from '../fetchTronBalance';\n\nexport const createTronNetworkProvider = (\n networkData: NetworkData\n): TronNetworkProvider => ({\n ...createBaseNetworkProvider('TRON', networkData),\n getBalance: async ({ address }) => ({\n balance: await fetchTronBalance({\n address,\n networkData,\n }),\n }),\n});\n","import type { DynamicClient } from '@dynamic-labs-sdk/client';\nimport { getNetworkProviderBuilderRegistry } from '@dynamic-labs-sdk/client/core';\n\nimport { createTronNetworkProvider } from '../utils/createTronNetworkProvider';\n\nexport const registerTronNetworkProviderBuilder = (\n client: DynamicClient\n): void => {\n const networkProviderBuilderRegistry =\n getNetworkProviderBuilderRegistry(client);\n\n // If the Tron network provider builder is already registered, return.\n if (networkProviderBuilderRegistry.get().get('TRON')) {\n return;\n }\n\n networkProviderBuilderRegistry.register({\n builder: createTronNetworkProvider,\n chain: 'TRON',\n });\n};\n","export const convertChainIdToDecimal = (chainId: string): string =>\n chainId.startsWith('0x') ? parseInt(chainId, 16).toString() : chainId;\n","import {\n type Chain,\n type DynamicClient,\n type WalletProviderMetadata,\n assertWalletAccountSigningAvailability,\n getActiveNetworkData,\n} from '@dynamic-labs-sdk/client';\nimport {\n assertDefined,\n formatWalletProviderGroupKey,\n formatWalletProviderKey,\n} from '@dynamic-labs-sdk/client/core';\nimport { WalletProviderEnum } from '@dynamic-labs/sdk-api-core';\nimport type { Adapter } from '@tronweb3/tronwallet-abstract-adapter';\nimport { WalletReadyState } from '@tronweb3/tronwallet-abstract-adapter';\nimport { TronWeb } from 'tronweb';\n\nimport type {\n TronAdapter,\n TronWalletProvider,\n} from '../../../TronWalletProvider.types';\nimport { convertChainIdToDecimal } from '../../../utils/convertChainIdToDecimal';\n\ntype CreateWalletProviderForTronWalletAdapterParams = {\n adapter: Adapter;\n dynamicClient: DynamicClient;\n};\n\nexport const createWalletProviderForTronWalletAdapter = ({\n dynamicClient,\n adapter,\n}: CreateWalletProviderForTronWalletAdapterParams):\n | TronWalletProvider\n | undefined => {\n const chain: Chain = 'TRON';\n\n // we have to do this type cast because these adapters have the _wallet property private,\n // but we need to access it to get the TronWeb instance\n const tronAdapter = adapter as unknown as TronAdapter;\n\n // Wallet is not installed\n if (tronAdapter.readyState !== WalletReadyState.Found) {\n return undefined;\n }\n\n const metadata: WalletProviderMetadata = {\n displayName: tronAdapter.name,\n icon: tronAdapter.icon,\n };\n\n const walletProviderType = WalletProviderEnum.BrowserExtension;\n\n const key = formatWalletProviderKey({\n chain,\n displayName: metadata.displayName,\n walletProviderType,\n });\n\n const connect: TronWalletProvider['connect'] = async () => {\n await tronAdapter.connect();\n\n // Some wallets (Trust, Bitget) populate the address asynchronously after connect()\n // Wait briefly for the address to be populated by the wallet\n const startTime = Date.now();\n while (!tronAdapter.address?.length && Date.now() - startTime < 1000) {\n await new Promise((resolve) => setTimeout(resolve, 50));\n }\n\n return {\n addresses: tronAdapter.address ? [{ address: tronAdapter.address }] : [],\n };\n };\n\n const disconnect: TronWalletProvider['disconnect'] = async () => {\n return tronAdapter.disconnect();\n };\n\n const getActiveNetworkId: TronWalletProvider['getActiveNetworkId'] =\n async () => {\n const networkInfo = await tronAdapter.network();\n\n const networkId = convertChainIdToDecimal(networkInfo.chainId);\n\n return { networkId };\n };\n\n const getConnectedAddresses: TronWalletProvider['getConnectedAddresses'] =\n async () => {\n return {\n addresses: tronAdapter.address ? [tronAdapter.address] : [],\n };\n };\n\n const signMessage: TronWalletProvider['signMessage'] = async ({\n message,\n walletAccount,\n }) => {\n assertDefined(walletAccount, 'Wallet account not found');\n\n await assertWalletAccountSigningAvailability(\n { walletAccount },\n dynamicClient\n );\n\n const signedMessage = await tronAdapter.signMessage(message);\n\n return {\n signature: signedMessage,\n };\n };\n\n const getTronWeb: TronWalletProvider['getTronWeb'] = async ({\n walletAccount,\n }) => {\n const tronWeb =\n tronAdapter._wallet?.tronWeb || tronAdapter._wallet?.tron?.tronWeb;\n\n if (tronWeb) {\n return tronWeb;\n }\n\n const activeNetworkData = await getActiveNetworkData(\n { walletAccount },\n dynamicClient\n );\n assertDefined(activeNetworkData, 'No active network data found');\n\n const url = activeNetworkData.networkData?.rpcUrls.http[0];\n assertDefined(url, 'No RPC URL found for active network');\n\n return new TronWeb({ fullHost: url });\n };\n\n return {\n chain,\n connect,\n disconnect,\n getActiveNetworkId,\n getConnectedAddresses,\n getTronWeb,\n groupKey: formatWalletProviderGroupKey(metadata.displayName),\n key,\n metadata,\n signMessage,\n walletProviderType,\n };\n};\n","import {\n WalletProviderPriority,\n getDefaultClient,\n getWalletProviderRegistry,\n hasExtension,\n registerExtension,\n} from '@dynamic-labs-sdk/client/core';\nimport {\n BitKeepAdapter,\n OkxWalletAdapter,\n TokenPocketAdapter,\n TronLinkAdapter,\n TrustAdapter,\n} from '@tronweb3/tronwallet-adapters';\n\nimport { registerTronNetworkProviderBuilder } from '../../registerTronNetworkProviderBuilder';\nimport type { TronWalletProvider } from '../../TronWalletProvider.types';\nimport { createWalletProviderForTronWalletAdapter } from '../utils/createWalletProviderForTronWalletAdapter';\n\nexport const TRON_WALLET_ADAPTERS_EXTENSION_KEY = 'tronWalletAdapters';\n\n/**\n * Adds the Tron Wallet Adapters extension to the Dynamic client.\n *\n * This extension enables integration with wallets that have related Tron Wallet Adapters ('@tronweb3/tronwallet-adapters'),\n * automatically registering compatible wallets for use with the Dynamic SDK.\n *\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n */\nexport const addTronWalletAdaptersExtension = (\n client = getDefaultClient()\n): void => {\n if (\n hasExtension({ extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY }, client)\n ) {\n return;\n }\n\n registerExtension(\n { extensionKey: TRON_WALLET_ADAPTERS_EXTENSION_KEY },\n client\n );\n\n registerTronNetworkProviderBuilder(client);\n\n const walletProviderRegistry = getWalletProviderRegistry(client);\n\n const tronWalletProviders: TronWalletProvider[] = [];\n\n // Create and register OKX wallet provider\n const okxWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new OkxWalletAdapter(),\n dynamicClient: client,\n });\n if (okxWalletProvider) {\n tronWalletProviders.push(okxWalletProvider);\n }\n\n // Create and register TronLink wallet provider\n const tronLinkWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TronLinkAdapter(),\n dynamicClient: client,\n });\n if (tronLinkWalletProvider) {\n tronWalletProviders.push(tronLinkWalletProvider);\n }\n\n // Create and register Trust wallet provider\n const trustWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TrustAdapter(),\n dynamicClient: client,\n });\n if (trustWalletProvider) {\n tronWalletProviders.push(trustWalletProvider);\n }\n\n // Create and register TokenPocket wallet provider\n const tokenPocketWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new TokenPocketAdapter(),\n dynamicClient: client,\n });\n if (tokenPocketWalletProvider) {\n tronWalletProviders.push(tokenPocketWalletProvider);\n }\n\n // Create and register Bitget wallet provider\n const bitgetWalletProvider = createWalletProviderForTronWalletAdapter({\n adapter: new BitKeepAdapter(),\n dynamicClient: client,\n });\n if (bitgetWalletProvider) {\n tronWalletProviders.push(bitgetWalletProvider);\n }\n\n tronWalletProviders.forEach((walletProvider) => {\n walletProviderRegistry.register({\n priority: WalletProviderPriority.WINDOW_INJECT,\n walletProvider,\n });\n });\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"NotTronProviderError.d.ts","sourceRoot":"","sources":["../../../src/errors/NotTronProviderError/NotTronProviderError.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;AAErD,qBAAa,oBAAqB,SAAQ,SAAS;IACjD,SAAgB,WAAW,EAAE,MAAM,CAAC;gBAExB,MAAM,EAAE;QAAE,WAAW,EAAE,MAAM,CAAA;KAAE;CAW5C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/errors/NotTronProviderError/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC"}
|
package/dist/exports/index.d.ts
CHANGED
|
@@ -1,2 +1,9 @@
|
|
|
1
1
|
export { addTronExtension } from '../addTronExtension';
|
|
2
|
+
export { getTronWeb } from '../getTronWeb';
|
|
3
|
+
export { isTronNetworkProvider } from '../isTronNetworkProvider';
|
|
4
|
+
export { isTronWalletAccount } from '../isTronWalletAccount';
|
|
5
|
+
export { sendTransaction } from '../sendTransaction';
|
|
6
|
+
export type { TronNetworkProvider } from '../TronNetworkProvider.types';
|
|
7
|
+
export type { TronWalletAccount } from '../TronWalletAccount.types';
|
|
8
|
+
export type { TronBroadcastReturnSignedTransaction, TronWeb, } from '../TronWalletProvider.types';
|
|
2
9
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/exports/index.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/exports/index.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,YAAY,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AACxE,YAAY,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AACpE,YAAY,EACV,oCAAoC,EACpC,OAAO,GACR,MAAM,6BAA6B,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { TronWeb } from 'tronweb';
|
|
2
|
+
import type { TronWalletAccount } from '../TronWalletAccount.types';
|
|
3
|
+
type GetTronWebParams = {
|
|
4
|
+
walletAccount: TronWalletAccount;
|
|
5
|
+
};
|
|
6
|
+
/**
|
|
7
|
+
* Retrieves a TronWeb from a wallet account.
|
|
8
|
+
*
|
|
9
|
+
* @param params.walletAccount - The wallet account to get the TronWeb for.
|
|
10
|
+
* @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
|
|
11
|
+
* @returns A promise that resolves to a TronWeb instance
|
|
12
|
+
* @throws NotTronProviderError If the wallet account's provider is not a Tron provider
|
|
13
|
+
*/
|
|
14
|
+
export declare const getTronWeb: ({ walletAccount }: GetTronWebParams, client?: import("@dynamic-labs-sdk/client").DynamicClient) => Promise<TronWeb>;
|
|
15
|
+
export {};
|
|
16
|
+
//# sourceMappingURL=getTronWeb.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getTronWeb.d.ts","sourceRoot":"","sources":["../../src/getTronWeb/getTronWeb.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAIvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAEpE,KAAK,gBAAgB,GAAG;IACtB,aAAa,EAAE,iBAAiB,CAAC;CAClC,CAAC;AAEF;;;;;;;GAOG;AACH,eAAO,MAAM,UAAU,sBACF,gBAAgB,gEAElC,OAAO,CAAC,OAAO,CAajB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/getTronWeb/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC"}
|
package/dist/index.cjs.js
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
const require_addTronWalletAdaptersExtension = require('./addTronWalletAdaptersExtension-
|
|
1
|
+
const require_addTronWalletAdaptersExtension = require('./addTronWalletAdaptersExtension-BzQOeaSX.cjs.js');
|
|
2
2
|
let _dynamic_labs_sdk_assert_package_version = require("@dynamic-labs-sdk/assert-package-version");
|
|
3
3
|
let _dynamic_labs_sdk_client_core = require("@dynamic-labs-sdk/client/core");
|
|
4
|
+
let _dynamic_labs_sdk_client = require("@dynamic-labs-sdk/client");
|
|
4
5
|
|
|
5
6
|
//#region src/addTronExtension/addTronExtension.ts
|
|
6
7
|
/**
|
|
@@ -14,10 +15,79 @@ const addTronExtension = (client = (0, _dynamic_labs_sdk_client_core.getDefaultC
|
|
|
14
15
|
require_addTronWalletAdaptersExtension.addTronWalletAdaptersExtension(client);
|
|
15
16
|
};
|
|
16
17
|
|
|
18
|
+
//#endregion
|
|
19
|
+
//#region src/errors/NotTronProviderError/NotTronProviderError.ts
|
|
20
|
+
var NotTronProviderError = class extends _dynamic_labs_sdk_client.BaseError {
|
|
21
|
+
providerKey;
|
|
22
|
+
constructor(params) {
|
|
23
|
+
super({
|
|
24
|
+
cause: null,
|
|
25
|
+
code: "not_tron_provider_error",
|
|
26
|
+
docsUrl: null,
|
|
27
|
+
name: "NotTronProviderError",
|
|
28
|
+
shortMessage: "Provider is not a Tron wallet provider"
|
|
29
|
+
});
|
|
30
|
+
this.providerKey = params.providerKey;
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
//#endregion
|
|
35
|
+
//#region src/isTronWalletProvider/isTronWalletProvider.ts
|
|
36
|
+
const isTronWalletProvider = (provider) => {
|
|
37
|
+
return provider.chain === "TRON";
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
//#endregion
|
|
41
|
+
//#region src/getTronWeb/getTronWeb.ts
|
|
42
|
+
/**
|
|
43
|
+
* Retrieves a TronWeb from a wallet account.
|
|
44
|
+
*
|
|
45
|
+
* @param params.walletAccount - The wallet account to get the TronWeb for.
|
|
46
|
+
* @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
|
|
47
|
+
* @returns A promise that resolves to a TronWeb instance
|
|
48
|
+
* @throws NotTronProviderError If the wallet account's provider is not a Tron provider
|
|
49
|
+
*/
|
|
50
|
+
const getTronWeb = async ({ walletAccount }, client = (0, _dynamic_labs_sdk_client_core.getDefaultClient)()) => {
|
|
51
|
+
const provider = (0, _dynamic_labs_sdk_client_core.getWalletProviderFromWalletAccount)({ walletAccount }, client);
|
|
52
|
+
if (!isTronWalletProvider(provider)) throw new NotTronProviderError({ providerKey: provider.key });
|
|
53
|
+
return provider.getTronWeb({ walletAccount });
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
//#endregion
|
|
57
|
+
//#region src/isTronNetworkProvider/isTronNetworkProvider.ts
|
|
58
|
+
const isTronNetworkProvider = (networkProvider) => networkProvider.chain === "TRON";
|
|
59
|
+
|
|
60
|
+
//#endregion
|
|
61
|
+
//#region src/isTronWalletAccount/isTronWalletAccount.ts
|
|
62
|
+
const isTronWalletAccount = (walletAccount) => walletAccount.chain === "TRON";
|
|
63
|
+
|
|
64
|
+
//#endregion
|
|
65
|
+
//#region src/sendTransaction/sendTransaction.ts
|
|
66
|
+
/**
|
|
67
|
+
* Sends a Tron transaction
|
|
68
|
+
* @param params.transaction - The transaction to send
|
|
69
|
+
* @param params.walletAccount - The wallet account to sign and send the transaction with
|
|
70
|
+
* @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.
|
|
71
|
+
* @returns A promise that resolves to the broadcast return of the signed transaction
|
|
72
|
+
*/
|
|
73
|
+
const sendTransaction = async ({ walletAccount, transaction }, client = (0, _dynamic_labs_sdk_client.getDefaultClient)()) => {
|
|
74
|
+
await (0, _dynamic_labs_sdk_client.assertWalletAccountSigningAvailability)({ walletAccount }, client);
|
|
75
|
+
const provider = (0, _dynamic_labs_sdk_client_core.getWalletProviderFromWalletAccount)({ walletAccount }, client);
|
|
76
|
+
if (!isTronWalletProvider(provider)) throw new NotTronProviderError({ providerKey: provider.key });
|
|
77
|
+
const tronWeb = await provider.getTronWeb({ walletAccount });
|
|
78
|
+
const { amount, to } = transaction;
|
|
79
|
+
const amountInSun = tronWeb.toSun(amount);
|
|
80
|
+
return tronWeb.trx.sendTransaction(to, Number(amountInSun), { address: walletAccount.address });
|
|
81
|
+
};
|
|
82
|
+
|
|
17
83
|
//#endregion
|
|
18
84
|
//#region src/exports/index.ts
|
|
19
85
|
(0, _dynamic_labs_sdk_assert_package_version.assertPackageVersion)(require_addTronWalletAdaptersExtension.name, require_addTronWalletAdaptersExtension.version);
|
|
20
86
|
|
|
21
87
|
//#endregion
|
|
22
88
|
exports.addTronExtension = addTronExtension;
|
|
89
|
+
exports.getTronWeb = getTronWeb;
|
|
90
|
+
exports.isTronNetworkProvider = isTronNetworkProvider;
|
|
91
|
+
exports.isTronWalletAccount = isTronWalletAccount;
|
|
92
|
+
exports.sendTransaction = sendTransaction;
|
|
23
93
|
//# sourceMappingURL=index.cjs.js.map
|
package/dist/index.cjs.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.cjs.js","names":["packageName","packageVersion"],"sources":["../src/addTronExtension/addTronExtension.ts","../src/exports/index.ts"],"sourcesContent":["import { getDefaultClient } from '@dynamic-labs-sdk/client/core';\n\nimport { addTronWalletAdaptersExtension } from '../walletAdapters/addTronWalletAdaptersExtension';\n\n/**\n * Adds the Tron extension to the Dynamic client.\n *\n * This is a convenience function that adds support for Tron wallets.\n *\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n */\nexport const addTronExtension = (client = getDefaultClient()): void => {\n addTronWalletAdaptersExtension(client);\n};\n","import { assertPackageVersion } from '@dynamic-labs-sdk/assert-package-version';\n\nimport {\n name as packageName,\n version as packageVersion,\n} from '../../package.json';\nassertPackageVersion(packageName, packageVersion);\n\nexport { addTronExtension } from '../addTronExtension';\n"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.cjs.js","names":["BaseError","packageName","packageVersion"],"sources":["../src/addTronExtension/addTronExtension.ts","../src/errors/NotTronProviderError/NotTronProviderError.ts","../src/isTronWalletProvider/isTronWalletProvider.ts","../src/getTronWeb/getTronWeb.ts","../src/isTronNetworkProvider/isTronNetworkProvider.ts","../src/isTronWalletAccount/isTronWalletAccount.ts","../src/sendTransaction/sendTransaction.ts","../src/exports/index.ts"],"sourcesContent":["import { getDefaultClient } from '@dynamic-labs-sdk/client/core';\n\nimport { addTronWalletAdaptersExtension } from '../walletAdapters/addTronWalletAdaptersExtension';\n\n/**\n * Adds the Tron extension to the Dynamic client.\n *\n * This is a convenience function that adds support for Tron wallets.\n *\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n */\nexport const addTronExtension = (client = getDefaultClient()): void => {\n addTronWalletAdaptersExtension(client);\n};\n","import { BaseError } from '@dynamic-labs-sdk/client';\n\nexport class NotTronProviderError extends BaseError {\n public readonly providerKey: string;\n\n constructor(params: { providerKey: string }) {\n super({\n cause: null,\n code: 'not_tron_provider_error',\n docsUrl: null,\n name: 'NotTronProviderError',\n shortMessage: 'Provider is not a Tron wallet provider',\n });\n\n this.providerKey = params.providerKey;\n }\n}\n","import type { WalletProvider } from '@dynamic-labs-sdk/client/core';\n\nimport type { TronWalletProvider } from '../TronWalletProvider.types';\n\nexport const isTronWalletProvider = (\n provider: WalletProvider | TronWalletProvider\n): provider is TronWalletProvider => {\n return provider.chain === 'TRON';\n};\n","import {\n getDefaultClient,\n getWalletProviderFromWalletAccount,\n} from '@dynamic-labs-sdk/client/core';\nimport type { TronWeb } from 'tronweb';\n\nimport { NotTronProviderError } from '../errors/NotTronProviderError';\nimport { isTronWalletProvider } from '../isTronWalletProvider';\nimport type { TronWalletAccount } from '../TronWalletAccount.types';\n\ntype GetTronWebParams = {\n walletAccount: TronWalletAccount;\n};\n\n/**\n * Retrieves a TronWeb from a wallet account.\n *\n * @param params.walletAccount - The wallet account to get the TronWeb for.\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n * @returns A promise that resolves to a TronWeb instance\n * @throws NotTronProviderError If the wallet account's provider is not a Tron provider\n */\nexport const getTronWeb = async (\n { walletAccount }: GetTronWebParams,\n client = getDefaultClient()\n): Promise<TronWeb> => {\n const provider = getWalletProviderFromWalletAccount(\n {\n walletAccount,\n },\n client\n );\n\n if (!isTronWalletProvider(provider)) {\n throw new NotTronProviderError({ providerKey: provider.key });\n }\n\n return provider.getTronWeb({ walletAccount });\n};\n","import type { NetworkProvider } from '@dynamic-labs-sdk/client';\n\nimport type { TronNetworkProvider } from '../TronNetworkProvider.types';\n\nexport const isTronNetworkProvider = (\n networkProvider: NetworkProvider\n): networkProvider is TronNetworkProvider => networkProvider.chain === 'TRON';\n","import type { WalletAccount } from '@dynamic-labs-sdk/client';\n\nimport type { TronWalletAccount } from '../TronWalletAccount.types';\n\nexport const isTronWalletAccount = (\n walletAccount: WalletAccount\n): walletAccount is TronWalletAccount => walletAccount.chain === 'TRON';\n","import {\n assertWalletAccountSigningAvailability,\n getDefaultClient,\n} from '@dynamic-labs-sdk/client';\nimport { getWalletProviderFromWalletAccount } from '@dynamic-labs-sdk/client/core';\n\nimport { NotTronProviderError } from '../errors/NotTronProviderError';\nimport { isTronWalletProvider } from '../isTronWalletProvider';\nimport type { TronWalletAccount } from '../TronWalletAccount.types';\nimport type { TronBroadcastReturnSignedTransaction } from '../TronWalletProvider.types';\n\ntype SendTransactionParams = {\n transaction: {\n amount: number;\n to: string;\n };\n walletAccount: TronWalletAccount;\n};\n\n/**\n * Sends a Tron transaction\n * @param params.transaction - The transaction to send\n * @param params.walletAccount - The wallet account to sign and send the transaction with\n * @param [client] - The Dynamic client instance. Only required when using multiple Dynamic clients.\n * @returns A promise that resolves to the broadcast return of the signed transaction\n */\nexport const sendTransaction = async (\n { walletAccount, transaction }: SendTransactionParams,\n client = getDefaultClient()\n): Promise<TronBroadcastReturnSignedTransaction> => {\n await assertWalletAccountSigningAvailability({ walletAccount }, client);\n\n const provider = getWalletProviderFromWalletAccount(\n {\n walletAccount,\n },\n client\n );\n\n if (!isTronWalletProvider(provider)) {\n throw new NotTronProviderError({ providerKey: provider.key });\n }\n\n const tronWeb = await provider.getTronWeb({ walletAccount });\n\n const { amount, to } = transaction;\n const amountInSun = tronWeb.toSun(amount);\n\n return tronWeb.trx.sendTransaction(to, Number(amountInSun), {\n address: walletAccount.address,\n });\n};\n","import { assertPackageVersion } from '@dynamic-labs-sdk/assert-package-version';\n\nimport {\n name as packageName,\n version as packageVersion,\n} from '../../package.json';\nassertPackageVersion(packageName, packageVersion);\n\nexport { addTronExtension } from '../addTronExtension';\nexport { getTronWeb } from '../getTronWeb';\nexport { isTronNetworkProvider } from '../isTronNetworkProvider';\nexport { isTronWalletAccount } from '../isTronWalletAccount';\nexport { sendTransaction } from '../sendTransaction';\nexport type { TronNetworkProvider } from '../TronNetworkProvider.types';\nexport type { TronWalletAccount } from '../TronWalletAccount.types';\nexport type {\n TronBroadcastReturnSignedTransaction,\n TronWeb,\n} from '../TronWalletProvider.types';\n"],"mappings":";;;;;;;;;;;;;AAWA,MAAa,oBAAoB,8DAA2B,KAAW;AACrE,uEAA+B,OAAO;;;;;ACVxC,IAAa,uBAAb,cAA0CA,mCAAU;CAClD,AAAgB;CAEhB,YAAY,QAAiC;AAC3C,QAAM;GACJ,OAAO;GACP,MAAM;GACN,SAAS;GACT,MAAM;GACN,cAAc;GACf,CAAC;AAEF,OAAK,cAAc,OAAO;;;;;;ACV9B,MAAa,wBACX,aACmC;AACnC,QAAO,SAAS,UAAU;;;;;;;;;;;;;ACe5B,MAAa,aAAa,OACxB,EAAE,iBACF,8DAA2B,KACN;CACrB,MAAM,iFACJ,EACE,eACD,EACD,OACD;AAED,KAAI,CAAC,qBAAqB,SAAS,CACjC,OAAM,IAAI,qBAAqB,EAAE,aAAa,SAAS,KAAK,CAAC;AAG/D,QAAO,SAAS,WAAW,EAAE,eAAe,CAAC;;;;;ACjC/C,MAAa,yBACX,oBAC2C,gBAAgB,UAAU;;;;ACFvE,MAAa,uBACX,kBACuC,cAAc,UAAU;;;;;;;;;;;ACoBjE,MAAa,kBAAkB,OAC7B,EAAE,eAAe,eACjB,yDAA2B,KACuB;AAClD,4EAA6C,EAAE,eAAe,EAAE,OAAO;CAEvE,MAAM,iFACJ,EACE,eACD,EACD,OACD;AAED,KAAI,CAAC,qBAAqB,SAAS,CACjC,OAAM,IAAI,qBAAqB,EAAE,aAAa,SAAS,KAAK,CAAC;CAG/D,MAAM,UAAU,MAAM,SAAS,WAAW,EAAE,eAAe,CAAC;CAE5D,MAAM,EAAE,QAAQ,OAAO;CACvB,MAAM,cAAc,QAAQ,MAAM,OAAO;AAEzC,QAAO,QAAQ,IAAI,gBAAgB,IAAI,OAAO,YAAY,EAAE,EAC1D,SAAS,cAAc,SACxB,CAAC;;;;;mEC5CiBC,6CAAaC,+CAAe"}
|