@talismn/balances-react 0.3.1 → 0.3.2
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/CHANGELOG.md +7 -0
- package/dist/declarations/src/hooks/useBalances.d.ts +5 -2
- package/dist/declarations/src/hooks/useChaindata.d.ts +4 -1
- package/dist/talismn-balances-react.cjs.dev.js +22 -19
- package/dist/talismn-balances-react.cjs.prod.js +22 -19
- package/dist/talismn-balances-react.esm.js +22 -19
- package/package.json +2 -2
package/CHANGELOG.md
CHANGED
@@ -1,3 +1,6 @@
|
|
1
|
-
import { AddressesByToken, BalanceModule
|
1
|
+
import { AddressesByToken, BalanceModule } from "@talismn/balances";
|
2
2
|
import { ChaindataProvider, Token } from "@talismn/chaindata-provider";
|
3
|
-
export
|
3
|
+
export type Options = {
|
4
|
+
onfinalityApiKey?: string;
|
5
|
+
};
|
6
|
+
export declare function useBalances(balanceModules: Array<BalanceModule<any, any, any, any>>, chaindataProvider: ChaindataProvider | null, addressesByToken: AddressesByToken<Token> | null, options?: Options): any;
|
@@ -1,5 +1,8 @@
|
|
1
1
|
import { Chain, ChainId, ChainList, ChaindataProvider, EvmNetwork, EvmNetworkId, EvmNetworkList, Token, TokenId, TokenList } from "@talismn/chaindata-provider";
|
2
|
-
export
|
2
|
+
export type Options = {
|
3
|
+
onfinalityApiKey?: string;
|
4
|
+
};
|
5
|
+
export declare function useChaindata(options?: Options): (ChaindataProvider & {
|
3
6
|
generation?: number | undefined;
|
4
7
|
}) | null;
|
5
8
|
export declare function useChains(chaindata: (ChaindataProvider & {
|
@@ -18,7 +18,7 @@ var anylogger__default = /*#__PURE__*/_interopDefault(anylogger);
|
|
18
18
|
|
19
19
|
var packageJson = {
|
20
20
|
name: "@talismn/balances-react",
|
21
|
-
version: "0.3.
|
21
|
+
version: "0.3.2",
|
22
22
|
author: "Talisman",
|
23
23
|
homepage: "https://talisman.xyz",
|
24
24
|
license: "UNLICENSED",
|
@@ -81,14 +81,15 @@ var packageJson = {
|
|
81
81
|
var log = anylogger__default["default"](packageJson.name);
|
82
82
|
|
83
83
|
// TODO: Allow user to call useChaindata from multiple places
|
84
|
-
|
85
|
-
function useChaindata() {
|
84
|
+
function useChaindata(options = {}) {
|
86
85
|
const [chaindataProvider, setChaindataProvider] = react.useState(null);
|
87
86
|
|
88
87
|
// this number is incremented each time the chaindataProvider has fetched new data
|
89
88
|
const [generation, setGeneration] = react.useState(0);
|
90
89
|
react.useEffect(() => {
|
91
|
-
const chaindataProvider = new chaindataProviderExtension.ChaindataProviderExtension(
|
90
|
+
const chaindataProvider = new chaindataProviderExtension.ChaindataProviderExtension({
|
91
|
+
onfinalityApiKey: options.onfinalityApiKey
|
92
|
+
});
|
92
93
|
let shouldHydrate = true;
|
93
94
|
const timer = 300_000; // 300_000ms = 300s = 5 minutes
|
94
95
|
const hydrate = async () => {
|
@@ -108,7 +109,7 @@ function useChaindata() {
|
|
108
109
|
return () => {
|
109
110
|
shouldHydrate = false;
|
110
111
|
};
|
111
|
-
}, []);
|
112
|
+
}, [options.onfinalityApiKey]);
|
112
113
|
if (chaindataProvider) chaindataProvider.generation = generation;
|
113
114
|
return chaindataProvider;
|
114
115
|
}
|
@@ -121,7 +122,7 @@ function useChains(chaindata) {
|
|
121
122
|
if (thisGeneration !== chaindata.generation) return;
|
122
123
|
setChains(chains);
|
123
124
|
});
|
124
|
-
}, [chaindata?.generation]);
|
125
|
+
}, [chaindata, chaindata?.generation]);
|
125
126
|
return chains || {};
|
126
127
|
}
|
127
128
|
function useChain(chaindata, chainId) {
|
@@ -130,7 +131,7 @@ function useChain(chaindata, chainId) {
|
|
130
131
|
if (chaindata === null) return;
|
131
132
|
if (!chainId) return;
|
132
133
|
chaindata.getChain(chainId).then(setChain);
|
133
|
-
}, [chaindata?.generation]);
|
134
|
+
}, [chainId, chaindata, chaindata?.generation]);
|
134
135
|
return chain;
|
135
136
|
}
|
136
137
|
function useEvmNetworks(chaindata) {
|
@@ -142,7 +143,7 @@ function useEvmNetworks(chaindata) {
|
|
142
143
|
if (thisGeneration !== chaindata.generation) return;
|
143
144
|
setEvmNetworks(evmNetworks);
|
144
145
|
});
|
145
|
-
}, [chaindata?.generation]);
|
146
|
+
}, [chaindata, chaindata?.generation]);
|
146
147
|
return evmNetworks || {};
|
147
148
|
}
|
148
149
|
function useEvmNetwork(chaindata, evmNetworkId) {
|
@@ -151,7 +152,7 @@ function useEvmNetwork(chaindata, evmNetworkId) {
|
|
151
152
|
if (chaindata === null) return;
|
152
153
|
if (!evmNetworkId) return;
|
153
154
|
chaindata.getEvmNetwork(evmNetworkId).then(setEvmNetwork);
|
154
|
-
}, [chaindata?.generation]);
|
155
|
+
}, [chaindata, chaindata?.generation, evmNetworkId]);
|
155
156
|
return evmNetwork;
|
156
157
|
}
|
157
158
|
function useTokens(chaindata) {
|
@@ -163,7 +164,7 @@ function useTokens(chaindata) {
|
|
163
164
|
if (thisGeneration !== chaindata.generation) return;
|
164
165
|
setTokens(tokens);
|
165
166
|
});
|
166
|
-
}, [chaindata?.generation]);
|
167
|
+
}, [chaindata, chaindata?.generation]);
|
167
168
|
return tokens || {};
|
168
169
|
}
|
169
170
|
function useToken(chaindata, tokenId) {
|
@@ -172,7 +173,7 @@ function useToken(chaindata, tokenId) {
|
|
172
173
|
if (chaindata === null) return;
|
173
174
|
if (!tokenId) return;
|
174
175
|
chaindata.getToken(tokenId).then(setToken);
|
175
|
-
}, [chaindata?.generation]);
|
176
|
+
}, [chaindata, chaindata?.generation, tokenId]);
|
176
177
|
return token;
|
177
178
|
}
|
178
179
|
|
@@ -205,8 +206,8 @@ function useTokenRates(tokens) {
|
|
205
206
|
// the caller of useChains/useTokens/etc has provided.
|
206
207
|
function useBalances(
|
207
208
|
// TODO: Make this array of BalanceModules more type-safe
|
208
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
209
|
-
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken);
|
209
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
210
|
+
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken, options);
|
210
211
|
const chains = useChains(chaindataProvider);
|
211
212
|
const evmNetworks = useEvmNetworks(chaindataProvider);
|
212
213
|
const tokens = useTokens(chaindataProvider);
|
@@ -251,7 +252,7 @@ const subscriptions = {};
|
|
251
252
|
// balance subscriptions
|
252
253
|
function useBalancesSubscriptions(
|
253
254
|
// TODO: Make this array of BalanceModules more type-safe
|
254
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
255
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
255
256
|
// const subscriptions = useRef<
|
256
257
|
// Record<string, { unsub: Promise<() => void>; refcount: number; generation: number }>
|
257
258
|
// >({})
|
@@ -307,7 +308,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
307
308
|
}
|
308
309
|
};
|
309
310
|
const chainConnector = useChainConnector(chaindataProvider);
|
310
|
-
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider);
|
311
|
+
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider, options);
|
311
312
|
const tokens = useTokens(chaindataProvider);
|
312
313
|
react.useEffect(() => {
|
313
314
|
if (chainConnector === null) return;
|
@@ -336,7 +337,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
336
337
|
});
|
337
338
|
const unsubAll = () => unsubs.forEach(unsub => unsub());
|
338
339
|
return unsubAll;
|
339
|
-
}, [addressesByToken, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
340
|
+
}, [addressesByToken, balanceModules, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
340
341
|
}
|
341
342
|
|
342
343
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
@@ -349,12 +350,14 @@ function useChainConnector(chaindataProvider) {
|
|
349
350
|
return chainConnector$1;
|
350
351
|
}
|
351
352
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
352
|
-
function useChainConnectorEvm(chaindataProvider) {
|
353
|
+
function useChainConnectorEvm(chaindataProvider, options = {}) {
|
353
354
|
const [chainConnectorEvm$1, setChainConnectorEvm] = react.useState(null);
|
354
355
|
react.useEffect(() => {
|
355
356
|
if (chaindataProvider === null) return;
|
356
|
-
setChainConnectorEvm(new chainConnectorEvm.ChainConnectorEvm(chaindataProvider
|
357
|
-
|
357
|
+
setChainConnectorEvm(new chainConnectorEvm.ChainConnectorEvm(chaindataProvider, {
|
358
|
+
onfinalityApiKey: options.onfinalityApiKey
|
359
|
+
}));
|
360
|
+
}, [chaindataProvider, options.onfinalityApiKey]);
|
358
361
|
return chainConnectorEvm$1;
|
359
362
|
}
|
360
363
|
|
@@ -18,7 +18,7 @@ var anylogger__default = /*#__PURE__*/_interopDefault(anylogger);
|
|
18
18
|
|
19
19
|
var packageJson = {
|
20
20
|
name: "@talismn/balances-react",
|
21
|
-
version: "0.3.
|
21
|
+
version: "0.3.2",
|
22
22
|
author: "Talisman",
|
23
23
|
homepage: "https://talisman.xyz",
|
24
24
|
license: "UNLICENSED",
|
@@ -81,14 +81,15 @@ var packageJson = {
|
|
81
81
|
var log = anylogger__default["default"](packageJson.name);
|
82
82
|
|
83
83
|
// TODO: Allow user to call useChaindata from multiple places
|
84
|
-
|
85
|
-
function useChaindata() {
|
84
|
+
function useChaindata(options = {}) {
|
86
85
|
const [chaindataProvider, setChaindataProvider] = react.useState(null);
|
87
86
|
|
88
87
|
// this number is incremented each time the chaindataProvider has fetched new data
|
89
88
|
const [generation, setGeneration] = react.useState(0);
|
90
89
|
react.useEffect(() => {
|
91
|
-
const chaindataProvider = new chaindataProviderExtension.ChaindataProviderExtension(
|
90
|
+
const chaindataProvider = new chaindataProviderExtension.ChaindataProviderExtension({
|
91
|
+
onfinalityApiKey: options.onfinalityApiKey
|
92
|
+
});
|
92
93
|
let shouldHydrate = true;
|
93
94
|
const timer = 300_000; // 300_000ms = 300s = 5 minutes
|
94
95
|
const hydrate = async () => {
|
@@ -108,7 +109,7 @@ function useChaindata() {
|
|
108
109
|
return () => {
|
109
110
|
shouldHydrate = false;
|
110
111
|
};
|
111
|
-
}, []);
|
112
|
+
}, [options.onfinalityApiKey]);
|
112
113
|
if (chaindataProvider) chaindataProvider.generation = generation;
|
113
114
|
return chaindataProvider;
|
114
115
|
}
|
@@ -121,7 +122,7 @@ function useChains(chaindata) {
|
|
121
122
|
if (thisGeneration !== chaindata.generation) return;
|
122
123
|
setChains(chains);
|
123
124
|
});
|
124
|
-
}, [chaindata?.generation]);
|
125
|
+
}, [chaindata, chaindata?.generation]);
|
125
126
|
return chains || {};
|
126
127
|
}
|
127
128
|
function useChain(chaindata, chainId) {
|
@@ -130,7 +131,7 @@ function useChain(chaindata, chainId) {
|
|
130
131
|
if (chaindata === null) return;
|
131
132
|
if (!chainId) return;
|
132
133
|
chaindata.getChain(chainId).then(setChain);
|
133
|
-
}, [chaindata?.generation]);
|
134
|
+
}, [chainId, chaindata, chaindata?.generation]);
|
134
135
|
return chain;
|
135
136
|
}
|
136
137
|
function useEvmNetworks(chaindata) {
|
@@ -142,7 +143,7 @@ function useEvmNetworks(chaindata) {
|
|
142
143
|
if (thisGeneration !== chaindata.generation) return;
|
143
144
|
setEvmNetworks(evmNetworks);
|
144
145
|
});
|
145
|
-
}, [chaindata?.generation]);
|
146
|
+
}, [chaindata, chaindata?.generation]);
|
146
147
|
return evmNetworks || {};
|
147
148
|
}
|
148
149
|
function useEvmNetwork(chaindata, evmNetworkId) {
|
@@ -151,7 +152,7 @@ function useEvmNetwork(chaindata, evmNetworkId) {
|
|
151
152
|
if (chaindata === null) return;
|
152
153
|
if (!evmNetworkId) return;
|
153
154
|
chaindata.getEvmNetwork(evmNetworkId).then(setEvmNetwork);
|
154
|
-
}, [chaindata?.generation]);
|
155
|
+
}, [chaindata, chaindata?.generation, evmNetworkId]);
|
155
156
|
return evmNetwork;
|
156
157
|
}
|
157
158
|
function useTokens(chaindata) {
|
@@ -163,7 +164,7 @@ function useTokens(chaindata) {
|
|
163
164
|
if (thisGeneration !== chaindata.generation) return;
|
164
165
|
setTokens(tokens);
|
165
166
|
});
|
166
|
-
}, [chaindata?.generation]);
|
167
|
+
}, [chaindata, chaindata?.generation]);
|
167
168
|
return tokens || {};
|
168
169
|
}
|
169
170
|
function useToken(chaindata, tokenId) {
|
@@ -172,7 +173,7 @@ function useToken(chaindata, tokenId) {
|
|
172
173
|
if (chaindata === null) return;
|
173
174
|
if (!tokenId) return;
|
174
175
|
chaindata.getToken(tokenId).then(setToken);
|
175
|
-
}, [chaindata?.generation]);
|
176
|
+
}, [chaindata, chaindata?.generation, tokenId]);
|
176
177
|
return token;
|
177
178
|
}
|
178
179
|
|
@@ -205,8 +206,8 @@ function useTokenRates(tokens) {
|
|
205
206
|
// the caller of useChains/useTokens/etc has provided.
|
206
207
|
function useBalances(
|
207
208
|
// TODO: Make this array of BalanceModules more type-safe
|
208
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
209
|
-
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken);
|
209
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
210
|
+
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken, options);
|
210
211
|
const chains = useChains(chaindataProvider);
|
211
212
|
const evmNetworks = useEvmNetworks(chaindataProvider);
|
212
213
|
const tokens = useTokens(chaindataProvider);
|
@@ -251,7 +252,7 @@ const subscriptions = {};
|
|
251
252
|
// balance subscriptions
|
252
253
|
function useBalancesSubscriptions(
|
253
254
|
// TODO: Make this array of BalanceModules more type-safe
|
254
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
255
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
255
256
|
// const subscriptions = useRef<
|
256
257
|
// Record<string, { unsub: Promise<() => void>; refcount: number; generation: number }>
|
257
258
|
// >({})
|
@@ -307,7 +308,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
307
308
|
}
|
308
309
|
};
|
309
310
|
const chainConnector = useChainConnector(chaindataProvider);
|
310
|
-
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider);
|
311
|
+
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider, options);
|
311
312
|
const tokens = useTokens(chaindataProvider);
|
312
313
|
react.useEffect(() => {
|
313
314
|
if (chainConnector === null) return;
|
@@ -336,7 +337,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
336
337
|
});
|
337
338
|
const unsubAll = () => unsubs.forEach(unsub => unsub());
|
338
339
|
return unsubAll;
|
339
|
-
}, [addressesByToken, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
340
|
+
}, [addressesByToken, balanceModules, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
340
341
|
}
|
341
342
|
|
342
343
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
@@ -349,12 +350,14 @@ function useChainConnector(chaindataProvider) {
|
|
349
350
|
return chainConnector$1;
|
350
351
|
}
|
351
352
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
352
|
-
function useChainConnectorEvm(chaindataProvider) {
|
353
|
+
function useChainConnectorEvm(chaindataProvider, options = {}) {
|
353
354
|
const [chainConnectorEvm$1, setChainConnectorEvm] = react.useState(null);
|
354
355
|
react.useEffect(() => {
|
355
356
|
if (chaindataProvider === null) return;
|
356
|
-
setChainConnectorEvm(new chainConnectorEvm.ChainConnectorEvm(chaindataProvider
|
357
|
-
|
357
|
+
setChainConnectorEvm(new chainConnectorEvm.ChainConnectorEvm(chaindataProvider, {
|
358
|
+
onfinalityApiKey: options.onfinalityApiKey
|
359
|
+
}));
|
360
|
+
}, [chaindataProvider, options.onfinalityApiKey]);
|
358
361
|
return chainConnectorEvm$1;
|
359
362
|
}
|
360
363
|
|
@@ -10,7 +10,7 @@ import { fetchTokenRates } from '@talismn/token-rates';
|
|
10
10
|
|
11
11
|
var packageJson = {
|
12
12
|
name: "@talismn/balances-react",
|
13
|
-
version: "0.3.
|
13
|
+
version: "0.3.2",
|
14
14
|
author: "Talisman",
|
15
15
|
homepage: "https://talisman.xyz",
|
16
16
|
license: "UNLICENSED",
|
@@ -73,14 +73,15 @@ var packageJson = {
|
|
73
73
|
var log = anylogger(packageJson.name);
|
74
74
|
|
75
75
|
// TODO: Allow user to call useChaindata from multiple places
|
76
|
-
|
77
|
-
function useChaindata() {
|
76
|
+
function useChaindata(options = {}) {
|
78
77
|
const [chaindataProvider, setChaindataProvider] = useState(null);
|
79
78
|
|
80
79
|
// this number is incremented each time the chaindataProvider has fetched new data
|
81
80
|
const [generation, setGeneration] = useState(0);
|
82
81
|
useEffect(() => {
|
83
|
-
const chaindataProvider = new ChaindataProviderExtension(
|
82
|
+
const chaindataProvider = new ChaindataProviderExtension({
|
83
|
+
onfinalityApiKey: options.onfinalityApiKey
|
84
|
+
});
|
84
85
|
let shouldHydrate = true;
|
85
86
|
const timer = 300_000; // 300_000ms = 300s = 5 minutes
|
86
87
|
const hydrate = async () => {
|
@@ -100,7 +101,7 @@ function useChaindata() {
|
|
100
101
|
return () => {
|
101
102
|
shouldHydrate = false;
|
102
103
|
};
|
103
|
-
}, []);
|
104
|
+
}, [options.onfinalityApiKey]);
|
104
105
|
if (chaindataProvider) chaindataProvider.generation = generation;
|
105
106
|
return chaindataProvider;
|
106
107
|
}
|
@@ -113,7 +114,7 @@ function useChains(chaindata) {
|
|
113
114
|
if (thisGeneration !== chaindata.generation) return;
|
114
115
|
setChains(chains);
|
115
116
|
});
|
116
|
-
}, [chaindata?.generation]);
|
117
|
+
}, [chaindata, chaindata?.generation]);
|
117
118
|
return chains || {};
|
118
119
|
}
|
119
120
|
function useChain(chaindata, chainId) {
|
@@ -122,7 +123,7 @@ function useChain(chaindata, chainId) {
|
|
122
123
|
if (chaindata === null) return;
|
123
124
|
if (!chainId) return;
|
124
125
|
chaindata.getChain(chainId).then(setChain);
|
125
|
-
}, [chaindata?.generation]);
|
126
|
+
}, [chainId, chaindata, chaindata?.generation]);
|
126
127
|
return chain;
|
127
128
|
}
|
128
129
|
function useEvmNetworks(chaindata) {
|
@@ -134,7 +135,7 @@ function useEvmNetworks(chaindata) {
|
|
134
135
|
if (thisGeneration !== chaindata.generation) return;
|
135
136
|
setEvmNetworks(evmNetworks);
|
136
137
|
});
|
137
|
-
}, [chaindata?.generation]);
|
138
|
+
}, [chaindata, chaindata?.generation]);
|
138
139
|
return evmNetworks || {};
|
139
140
|
}
|
140
141
|
function useEvmNetwork(chaindata, evmNetworkId) {
|
@@ -143,7 +144,7 @@ function useEvmNetwork(chaindata, evmNetworkId) {
|
|
143
144
|
if (chaindata === null) return;
|
144
145
|
if (!evmNetworkId) return;
|
145
146
|
chaindata.getEvmNetwork(evmNetworkId).then(setEvmNetwork);
|
146
|
-
}, [chaindata?.generation]);
|
147
|
+
}, [chaindata, chaindata?.generation, evmNetworkId]);
|
147
148
|
return evmNetwork;
|
148
149
|
}
|
149
150
|
function useTokens(chaindata) {
|
@@ -155,7 +156,7 @@ function useTokens(chaindata) {
|
|
155
156
|
if (thisGeneration !== chaindata.generation) return;
|
156
157
|
setTokens(tokens);
|
157
158
|
});
|
158
|
-
}, [chaindata?.generation]);
|
159
|
+
}, [chaindata, chaindata?.generation]);
|
159
160
|
return tokens || {};
|
160
161
|
}
|
161
162
|
function useToken(chaindata, tokenId) {
|
@@ -164,7 +165,7 @@ function useToken(chaindata, tokenId) {
|
|
164
165
|
if (chaindata === null) return;
|
165
166
|
if (!tokenId) return;
|
166
167
|
chaindata.getToken(tokenId).then(setToken);
|
167
|
-
}, [chaindata?.generation]);
|
168
|
+
}, [chaindata, chaindata?.generation, tokenId]);
|
168
169
|
return token;
|
169
170
|
}
|
170
171
|
|
@@ -197,8 +198,8 @@ function useTokenRates(tokens) {
|
|
197
198
|
// the caller of useChains/useTokens/etc has provided.
|
198
199
|
function useBalances(
|
199
200
|
// TODO: Make this array of BalanceModules more type-safe
|
200
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
201
|
-
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken);
|
201
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
202
|
+
useBalancesSubscriptions(balanceModules, chaindataProvider, addressesByToken, options);
|
202
203
|
const chains = useChains(chaindataProvider);
|
203
204
|
const evmNetworks = useEvmNetworks(chaindataProvider);
|
204
205
|
const tokens = useTokens(chaindataProvider);
|
@@ -243,7 +244,7 @@ const subscriptions = {};
|
|
243
244
|
// balance subscriptions
|
244
245
|
function useBalancesSubscriptions(
|
245
246
|
// TODO: Make this array of BalanceModules more type-safe
|
246
|
-
balanceModules, chaindataProvider, addressesByToken) {
|
247
|
+
balanceModules, chaindataProvider, addressesByToken, options = {}) {
|
247
248
|
// const subscriptions = useRef<
|
248
249
|
// Record<string, { unsub: Promise<() => void>; refcount: number; generation: number }>
|
249
250
|
// >({})
|
@@ -299,7 +300,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
299
300
|
}
|
300
301
|
};
|
301
302
|
const chainConnector = useChainConnector(chaindataProvider);
|
302
|
-
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider);
|
303
|
+
const chainConnectorEvm = useChainConnectorEvm(chaindataProvider, options);
|
303
304
|
const tokens = useTokens(chaindataProvider);
|
304
305
|
useEffect(() => {
|
305
306
|
if (chainConnector === null) return;
|
@@ -328,7 +329,7 @@ balanceModules, chaindataProvider, addressesByToken) {
|
|
328
329
|
});
|
329
330
|
const unsubAll = () => unsubs.forEach(unsub => unsub());
|
330
331
|
return unsubAll;
|
331
|
-
}, [addressesByToken, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
332
|
+
}, [addressesByToken, balanceModules, chainConnector, chainConnectorEvm, chaindataProvider, tokens]);
|
332
333
|
}
|
333
334
|
|
334
335
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
@@ -341,12 +342,14 @@ function useChainConnector(chaindataProvider) {
|
|
341
342
|
return chainConnector;
|
342
343
|
}
|
343
344
|
// TODO: Allow advanced users of this library to provide their own chain connector
|
344
|
-
function useChainConnectorEvm(chaindataProvider) {
|
345
|
+
function useChainConnectorEvm(chaindataProvider, options = {}) {
|
345
346
|
const [chainConnectorEvm, setChainConnectorEvm] = useState(null);
|
346
347
|
useEffect(() => {
|
347
348
|
if (chaindataProvider === null) return;
|
348
|
-
setChainConnectorEvm(new ChainConnectorEvm(chaindataProvider
|
349
|
-
|
349
|
+
setChainConnectorEvm(new ChainConnectorEvm(chaindataProvider, {
|
350
|
+
onfinalityApiKey: options.onfinalityApiKey
|
351
|
+
}));
|
352
|
+
}, [chaindataProvider, options.onfinalityApiKey]);
|
350
353
|
return chainConnectorEvm;
|
351
354
|
}
|
352
355
|
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@talismn/balances-react",
|
3
|
-
"version": "0.3.
|
3
|
+
"version": "0.3.2",
|
4
4
|
"author": "Talisman",
|
5
5
|
"homepage": "https://talisman.xyz",
|
6
6
|
"license": "UNLICENSED",
|
@@ -26,7 +26,7 @@
|
|
26
26
|
"clean": "rm -rf dist && rm -rf .turbo rm -rf node_modules"
|
27
27
|
},
|
28
28
|
"dependencies": {
|
29
|
-
"@talismn/balances": "^0.3.
|
29
|
+
"@talismn/balances": "^0.3.2",
|
30
30
|
"@talismn/chain-connector": "^0.4.1",
|
31
31
|
"@talismn/chain-connector-evm": "^0.4.1",
|
32
32
|
"@talismn/chaindata-provider": "^0.4.1",
|