@ledgerhq/live-common 34.53.0-nightly.20251120023735 → 34.53.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.
Files changed (615) hide show
  1. package/lib/__tests__/test-helpers/bridge.d.ts.map +1 -1
  2. package/lib/__tests__/test-helpers/bridge.js +4 -0
  3. package/lib/__tests__/test-helpers/bridge.js.map +1 -1
  4. package/lib/__tests__/test-helpers/environment.js +0 -3
  5. package/lib/__tests__/test-helpers/environment.js.map +1 -1
  6. package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  7. package/lib/bridge/generic-alpaca/getAccountShape.js +10 -12
  8. package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  9. package/lib/currencies/helpers.d.ts +3 -1
  10. package/lib/currencies/helpers.d.ts.map +1 -1
  11. package/lib/currencies/helpers.js +27 -1
  12. package/lib/currencies/helpers.js.map +1 -1
  13. package/lib/dada-client/hooks/useAssetsData.d.ts +0 -1
  14. package/lib/dada-client/hooks/useAssetsData.d.ts.map +1 -1
  15. package/lib/dada-client/hooks/useAssetsData.js +0 -1
  16. package/lib/dada-client/hooks/useAssetsData.js.map +1 -1
  17. package/lib/deposit/helper.d.ts +8 -0
  18. package/lib/deposit/helper.d.ts.map +1 -0
  19. package/lib/deposit/helper.js +125 -0
  20. package/lib/deposit/helper.js.map +1 -0
  21. package/lib/deposit/index.d.ts +3 -0
  22. package/lib/deposit/index.d.ts.map +1 -0
  23. package/lib/deposit/index.js +6 -0
  24. package/lib/deposit/index.js.map +1 -0
  25. package/lib/deposit/mock.d.ts +75 -0
  26. package/lib/deposit/mock.d.ts.map +1 -0
  27. package/lib/deposit/mock.js +15111 -0
  28. package/lib/deposit/mock.js.map +1 -0
  29. package/lib/deposit/type.d.ts +17 -0
  30. package/lib/deposit/type.d.ts.map +1 -1
  31. package/lib/deposit/type.js.map +1 -1
  32. package/lib/deposit/useGroupedCurrenciesByProvider.hook.d.ts +3 -0
  33. package/lib/deposit/useGroupedCurrenciesByProvider.hook.d.ts.map +1 -0
  34. package/lib/deposit/useGroupedCurrenciesByProvider.hook.js +40 -0
  35. package/lib/deposit/useGroupedCurrenciesByProvider.hook.js.map +1 -0
  36. package/lib/deviceSDK/hooks/useBatteryStatuses.d.ts +1 -2
  37. package/lib/deviceSDK/hooks/useBatteryStatuses.d.ts.map +1 -1
  38. package/lib/deviceSDK/hooks/useBatteryStatuses.js +2 -4
  39. package/lib/deviceSDK/hooks/useBatteryStatuses.js.map +1 -1
  40. package/lib/deviceSDK/tasks/core.d.ts +1 -1
  41. package/lib/deviceSDK/tasks/core.d.ts.map +1 -1
  42. package/lib/deviceSDK/tasks/core.js +1 -1
  43. package/lib/deviceSDK/tasks/core.js.map +1 -1
  44. package/lib/deviceSDK/tasks/getDeviceInfo.d.ts.map +1 -1
  45. package/lib/deviceSDK/tasks/getDeviceInfo.js +0 -2
  46. package/lib/deviceSDK/tasks/getDeviceInfo.js.map +1 -1
  47. package/lib/deviceSDK/tasks/getLatestFirmware.d.ts.map +1 -1
  48. package/lib/deviceSDK/tasks/getLatestFirmware.js +2 -2
  49. package/lib/deviceSDK/tasks/getLatestFirmware.js.map +1 -1
  50. package/lib/deviceSDK/tasks/updateFirmware.d.ts.map +1 -1
  51. package/lib/deviceSDK/tasks/updateFirmware.js +0 -1
  52. package/lib/deviceSDK/tasks/updateFirmware.js.map +1 -1
  53. package/lib/e2e/deviceInteraction/ButtonDeviceSimulator.d.ts +3 -0
  54. package/lib/e2e/deviceInteraction/ButtonDeviceSimulator.d.ts.map +1 -0
  55. package/lib/e2e/deviceInteraction/ButtonDeviceSimulator.js +26 -0
  56. package/lib/e2e/deviceInteraction/ButtonDeviceSimulator.js.map +1 -0
  57. package/lib/e2e/enum/Account.d.ts +1 -0
  58. package/lib/e2e/enum/Account.d.ts.map +1 -1
  59. package/lib/e2e/enum/Account.js +1 -0
  60. package/lib/e2e/enum/Account.js.map +1 -1
  61. package/lib/e2e/enum/Currency.d.ts +1 -0
  62. package/lib/e2e/enum/Currency.d.ts.map +1 -1
  63. package/lib/e2e/enum/Currency.js +6 -2
  64. package/lib/e2e/enum/Currency.js.map +1 -1
  65. package/lib/e2e/families/algorand.d.ts +1 -1
  66. package/lib/e2e/families/algorand.d.ts.map +1 -1
  67. package/lib/e2e/families/algorand.js +5 -5
  68. package/lib/e2e/families/algorand.js.map +1 -1
  69. package/lib/e2e/families/aptos.d.ts +2 -2
  70. package/lib/e2e/families/aptos.d.ts.map +1 -1
  71. package/lib/e2e/families/aptos.js +9 -9
  72. package/lib/e2e/families/aptos.js.map +1 -1
  73. package/lib/e2e/families/bitcoin.d.ts +2 -2
  74. package/lib/e2e/families/bitcoin.d.ts.map +1 -1
  75. package/lib/e2e/families/bitcoin.js +11 -11
  76. package/lib/e2e/families/bitcoin.js.map +1 -1
  77. package/lib/e2e/families/cardano.d.ts +0 -6
  78. package/lib/e2e/families/cardano.d.ts.map +1 -1
  79. package/lib/e2e/families/cardano.js +26 -28
  80. package/lib/e2e/families/cardano.js.map +1 -1
  81. package/lib/e2e/families/celo.d.ts +1 -1
  82. package/lib/e2e/families/celo.d.ts.map +1 -1
  83. package/lib/e2e/families/celo.js +5 -5
  84. package/lib/e2e/families/celo.js.map +1 -1
  85. package/lib/e2e/families/cosmos.d.ts +2 -2
  86. package/lib/e2e/families/cosmos.d.ts.map +1 -1
  87. package/lib/e2e/families/cosmos.js +9 -9
  88. package/lib/e2e/families/cosmos.js.map +1 -1
  89. package/lib/e2e/families/evm.d.ts +0 -2
  90. package/lib/e2e/families/evm.d.ts.map +1 -1
  91. package/lib/e2e/families/evm.js +12 -13
  92. package/lib/e2e/families/evm.js.map +1 -1
  93. package/lib/e2e/families/hedera.d.ts +1 -1
  94. package/lib/e2e/families/hedera.d.ts.map +1 -1
  95. package/lib/e2e/families/hedera.js +5 -5
  96. package/lib/e2e/families/hedera.js.map +1 -1
  97. package/lib/e2e/families/kaspa.d.ts +2 -2
  98. package/lib/e2e/families/kaspa.d.ts.map +1 -1
  99. package/lib/e2e/families/kaspa.js +9 -9
  100. package/lib/e2e/families/kaspa.js.map +1 -1
  101. package/lib/e2e/families/multiversX.d.ts +1 -1
  102. package/lib/e2e/families/multiversX.d.ts.map +1 -1
  103. package/lib/e2e/families/multiversX.js +5 -5
  104. package/lib/e2e/families/multiversX.js.map +1 -1
  105. package/lib/e2e/families/near.d.ts +1 -1
  106. package/lib/e2e/families/near.d.ts.map +1 -1
  107. package/lib/e2e/families/near.js +6 -6
  108. package/lib/e2e/families/near.js.map +1 -1
  109. package/lib/e2e/families/osmosis.d.ts +1 -1
  110. package/lib/e2e/families/osmosis.d.ts.map +1 -1
  111. package/lib/e2e/families/osmosis.js +5 -5
  112. package/lib/e2e/families/osmosis.js.map +1 -1
  113. package/lib/e2e/families/polkadot.d.ts +1 -1
  114. package/lib/e2e/families/polkadot.d.ts.map +1 -1
  115. package/lib/e2e/families/polkadot.js +5 -5
  116. package/lib/e2e/families/polkadot.js.map +1 -1
  117. package/lib/e2e/families/solana.d.ts +2 -2
  118. package/lib/e2e/families/solana.d.ts.map +1 -1
  119. package/lib/e2e/families/solana.js +9 -9
  120. package/lib/e2e/families/solana.js.map +1 -1
  121. package/lib/e2e/families/stellar.d.ts +1 -1
  122. package/lib/e2e/families/stellar.d.ts.map +1 -1
  123. package/lib/e2e/families/stellar.js +5 -5
  124. package/lib/e2e/families/stellar.js.map +1 -1
  125. package/lib/e2e/families/sui.d.ts +1 -1
  126. package/lib/e2e/families/sui.d.ts.map +1 -1
  127. package/lib/e2e/families/sui.js +5 -5
  128. package/lib/e2e/families/sui.js.map +1 -1
  129. package/lib/e2e/families/tezos.d.ts +1 -1
  130. package/lib/e2e/families/tezos.d.ts.map +1 -1
  131. package/lib/e2e/families/tezos.js +8 -7
  132. package/lib/e2e/families/tezos.js.map +1 -1
  133. package/lib/e2e/families/tron.d.ts +1 -1
  134. package/lib/e2e/families/tron.d.ts.map +1 -1
  135. package/lib/e2e/families/tron.js +5 -5
  136. package/lib/e2e/families/tron.js.map +1 -1
  137. package/lib/e2e/families/xrp.d.ts +1 -1
  138. package/lib/e2e/families/xrp.d.ts.map +1 -1
  139. package/lib/e2e/families/xrp.js +5 -5
  140. package/lib/e2e/families/xrp.js.map +1 -1
  141. package/lib/e2e/index.d.ts +0 -15
  142. package/lib/e2e/index.d.ts.map +1 -1
  143. package/lib/e2e/speculos.d.ts +11 -11
  144. package/lib/e2e/speculos.d.ts.map +1 -1
  145. package/lib/e2e/speculos.js +78 -78
  146. package/lib/e2e/speculos.js.map +1 -1
  147. package/lib/exchange/providers/swap.d.ts +0 -1
  148. package/lib/exchange/providers/swap.d.ts.map +1 -1
  149. package/lib/exchange/providers/swap.js +1 -5
  150. package/lib/exchange/providers/swap.js.map +1 -1
  151. package/lib/exchange/swap/hooks/v5/useFetchCurrencyAll.d.ts.map +1 -1
  152. package/lib/exchange/swap/hooks/v5/useFetchCurrencyAll.js +3 -2
  153. package/lib/exchange/swap/hooks/v5/useFetchCurrencyAll.js.map +1 -1
  154. package/lib/exchange/swap/hooks/v5/useFilteredProviders.d.ts.map +1 -1
  155. package/lib/exchange/swap/hooks/v5/useFilteredProviders.js +10 -15
  156. package/lib/exchange/swap/hooks/v5/useFilteredProviders.js.map +1 -1
  157. package/lib/families/canton/bridge/mock.d.ts.map +1 -1
  158. package/lib/families/canton/bridge/mock.js +0 -1
  159. package/lib/families/canton/bridge/mock.js.map +1 -1
  160. package/lib/families/evm/config.d.ts.map +1 -1
  161. package/lib/families/evm/config.js +0 -49
  162. package/lib/families/evm/config.js.map +1 -1
  163. package/lib/featureFlags/defaultFeatures.d.ts +0 -3
  164. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
  165. package/lib/featureFlags/defaultFeatures.js +0 -6
  166. package/lib/featureFlags/defaultFeatures.js.map +1 -1
  167. package/lib/featureFlags/useFeature.d.ts +1 -1
  168. package/lib/featureFlags/useFeature.d.ts.map +1 -1
  169. package/lib/market/hooks/useMarketDataProvider.js +0 -1
  170. package/lib/market/hooks/useMarketDataProvider.js.map +1 -1
  171. package/lib/market/utils/types.d.ts +0 -1
  172. package/lib/market/utils/types.d.ts.map +1 -1
  173. package/lib/market/utils/types.js.map +1 -1
  174. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.d.ts +22 -0
  175. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.d.ts.map +1 -0
  176. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js +41 -0
  177. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js.map +1 -0
  178. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
  179. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +0 -11
  180. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
  181. package/lib/modularDrawer/hooks/useNetworkAccountCounts.d.ts +5 -1
  182. package/lib/modularDrawer/hooks/useNetworkAccountCounts.d.ts.map +1 -1
  183. package/lib/modularDrawer/hooks/useNetworkAccountCounts.js +2 -2
  184. package/lib/modularDrawer/hooks/useNetworkAccountCounts.js.map +1 -1
  185. package/lib/modularDrawer/modules/createNetworkConfiguration.d.ts +1 -1
  186. package/lib/modularDrawer/modules/createNetworkConfiguration.d.ts.map +1 -1
  187. package/lib/modularDrawer/modules/createNetworkConfiguration.js +2 -1
  188. package/lib/modularDrawer/modules/createNetworkConfiguration.js.map +1 -1
  189. package/lib/modularDrawer/utils/currencyUtils.d.ts +10 -0
  190. package/lib/modularDrawer/utils/currencyUtils.d.ts.map +1 -0
  191. package/lib/modularDrawer/utils/currencyUtils.js +74 -0
  192. package/lib/modularDrawer/utils/currencyUtils.js.map +1 -0
  193. package/lib/modularDrawer/utils/{groupCurrenciesByAsset.d.ts → groupCurrenciesByProvider.d.ts} +2 -2
  194. package/lib/modularDrawer/utils/groupCurrenciesByProvider.d.ts.map +1 -0
  195. package/lib/modularDrawer/utils/groupCurrenciesByProvider.js +21 -0
  196. package/lib/modularDrawer/utils/groupCurrenciesByProvider.js.map +1 -0
  197. package/lib/modularDrawer/utils/index.d.ts +1 -1
  198. package/lib/modularDrawer/utils/index.d.ts.map +1 -1
  199. package/lib/modularDrawer/utils/index.js +3 -3
  200. package/lib/modularDrawer/utils/index.js.map +1 -1
  201. package/lib/modularDrawer/utils/type.d.ts +5 -0
  202. package/lib/modularDrawer/utils/type.d.ts.map +1 -1
  203. package/lib/platform/filters.d.ts +2 -1
  204. package/lib/platform/filters.d.ts.map +1 -1
  205. package/lib/platform/filters.js +17 -1
  206. package/lib/platform/filters.js.map +1 -1
  207. package/lib/platform/helpers.d.ts +5 -1
  208. package/lib/platform/helpers.d.ts.map +1 -1
  209. package/lib/platform/helpers.js +33 -1
  210. package/lib/platform/helpers.js.map +1 -1
  211. package/lib/platform/react.d.ts +3 -2
  212. package/lib/platform/react.d.ts.map +1 -1
  213. package/lib/platform/react.js +16 -66
  214. package/lib/platform/react.js.map +1 -1
  215. package/lib/platform/types.d.ts +3 -3
  216. package/lib/platform/types.d.ts.map +1 -1
  217. package/lib/postOnboarding/reducer.d.ts +0 -2
  218. package/lib/postOnboarding/reducer.d.ts.map +1 -1
  219. package/lib/utils/getAccountTuplesForCurrency.d.ts +1 -1
  220. package/lib/utils/getAccountTuplesForCurrency.d.ts.map +1 -1
  221. package/lib/utils/getAccountTuplesForCurrency.js +3 -2
  222. package/lib/utils/getAccountTuplesForCurrency.js.map +1 -1
  223. package/lib/wallet-api/Exchange/server.d.ts.map +1 -1
  224. package/lib/wallet-api/Exchange/server.js +4 -5
  225. package/lib/wallet-api/Exchange/server.js.map +1 -1
  226. package/lib/wallet-api/converters.d.ts +0 -1
  227. package/lib/wallet-api/converters.d.ts.map +1 -1
  228. package/lib/wallet-api/converters.js +2 -7
  229. package/lib/wallet-api/converters.js.map +1 -1
  230. package/lib/wallet-api/react.d.ts +11 -6
  231. package/lib/wallet-api/react.d.ts.map +1 -1
  232. package/lib/wallet-api/react.js +135 -293
  233. package/lib/wallet-api/react.js.map +1 -1
  234. package/lib/wallet-api/tracking.d.ts +0 -6
  235. package/lib/wallet-api/tracking.d.ts.map +1 -1
  236. package/lib/wallet-api/tracking.js +0 -20
  237. package/lib/wallet-api/tracking.js.map +1 -1
  238. package/lib/wallet-api/types.d.ts +0 -3
  239. package/lib/wallet-api/types.d.ts.map +1 -1
  240. package/lib/wallet-api/useDappLogic.d.ts.map +1 -1
  241. package/lib/wallet-api/useDappLogic.js +80 -65
  242. package/lib/wallet-api/useDappLogic.js.map +1 -1
  243. package/lib/wallet-api/utils/deriveAccountIdForManifest.d.ts +0 -6
  244. package/lib/wallet-api/utils/deriveAccountIdForManifest.d.ts.map +1 -1
  245. package/lib/wallet-api/utils/deriveAccountIdForManifest.js +3 -13
  246. package/lib/wallet-api/utils/deriveAccountIdForManifest.js.map +1 -1
  247. package/lib-es/__tests__/test-helpers/bridge.d.ts.map +1 -1
  248. package/lib-es/__tests__/test-helpers/bridge.js +4 -0
  249. package/lib-es/__tests__/test-helpers/bridge.js.map +1 -1
  250. package/lib-es/__tests__/test-helpers/environment.js +0 -3
  251. package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
  252. package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  253. package/lib-es/bridge/generic-alpaca/getAccountShape.js +11 -13
  254. package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  255. package/lib-es/currencies/helpers.d.ts +3 -1
  256. package/lib-es/currencies/helpers.d.ts.map +1 -1
  257. package/lib-es/currencies/helpers.js +24 -0
  258. package/lib-es/currencies/helpers.js.map +1 -1
  259. package/lib-es/dada-client/hooks/useAssetsData.d.ts +0 -1
  260. package/lib-es/dada-client/hooks/useAssetsData.d.ts.map +1 -1
  261. package/lib-es/dada-client/hooks/useAssetsData.js +0 -1
  262. package/lib-es/dada-client/hooks/useAssetsData.js.map +1 -1
  263. package/lib-es/deposit/helper.d.ts +8 -0
  264. package/lib-es/deposit/helper.d.ts.map +1 -0
  265. package/lib-es/deposit/helper.js +117 -0
  266. package/lib-es/deposit/helper.js.map +1 -0
  267. package/lib-es/deposit/index.d.ts +3 -0
  268. package/lib-es/deposit/index.d.ts.map +1 -0
  269. package/lib-es/deposit/index.js +3 -0
  270. package/lib-es/deposit/index.js.map +1 -0
  271. package/lib-es/deposit/mock.d.ts +75 -0
  272. package/lib-es/deposit/mock.d.ts.map +1 -0
  273. package/lib-es/deposit/mock.js +15108 -0
  274. package/lib-es/deposit/mock.js.map +1 -0
  275. package/lib-es/deposit/type.d.ts +17 -0
  276. package/lib-es/deposit/type.d.ts.map +1 -1
  277. package/lib-es/deposit/type.js.map +1 -1
  278. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.d.ts +3 -0
  279. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.d.ts.map +1 -0
  280. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.js +36 -0
  281. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.js.map +1 -0
  282. package/lib-es/deviceSDK/hooks/useBatteryStatuses.d.ts +1 -2
  283. package/lib-es/deviceSDK/hooks/useBatteryStatuses.d.ts.map +1 -1
  284. package/lib-es/deviceSDK/hooks/useBatteryStatuses.js +2 -4
  285. package/lib-es/deviceSDK/hooks/useBatteryStatuses.js.map +1 -1
  286. package/lib-es/deviceSDK/tasks/core.d.ts +1 -1
  287. package/lib-es/deviceSDK/tasks/core.d.ts.map +1 -1
  288. package/lib-es/deviceSDK/tasks/core.js +1 -1
  289. package/lib-es/deviceSDK/tasks/core.js.map +1 -1
  290. package/lib-es/deviceSDK/tasks/getDeviceInfo.d.ts.map +1 -1
  291. package/lib-es/deviceSDK/tasks/getDeviceInfo.js +0 -2
  292. package/lib-es/deviceSDK/tasks/getDeviceInfo.js.map +1 -1
  293. package/lib-es/deviceSDK/tasks/getLatestFirmware.d.ts.map +1 -1
  294. package/lib-es/deviceSDK/tasks/getLatestFirmware.js +2 -2
  295. package/lib-es/deviceSDK/tasks/getLatestFirmware.js.map +1 -1
  296. package/lib-es/deviceSDK/tasks/updateFirmware.d.ts.map +1 -1
  297. package/lib-es/deviceSDK/tasks/updateFirmware.js +1 -2
  298. package/lib-es/deviceSDK/tasks/updateFirmware.js.map +1 -1
  299. package/lib-es/e2e/deviceInteraction/ButtonDeviceSimulator.d.ts +3 -0
  300. package/lib-es/e2e/deviceInteraction/ButtonDeviceSimulator.d.ts.map +1 -0
  301. package/lib-es/e2e/deviceInteraction/ButtonDeviceSimulator.js +18 -0
  302. package/lib-es/e2e/deviceInteraction/ButtonDeviceSimulator.js.map +1 -0
  303. package/lib-es/e2e/enum/Account.d.ts +1 -0
  304. package/lib-es/e2e/enum/Account.d.ts.map +1 -1
  305. package/lib-es/e2e/enum/Account.js +1 -0
  306. package/lib-es/e2e/enum/Account.js.map +1 -1
  307. package/lib-es/e2e/enum/Currency.d.ts +1 -0
  308. package/lib-es/e2e/enum/Currency.d.ts.map +1 -1
  309. package/lib-es/e2e/enum/Currency.js +6 -2
  310. package/lib-es/e2e/enum/Currency.js.map +1 -1
  311. package/lib-es/e2e/families/algorand.d.ts +1 -1
  312. package/lib-es/e2e/families/algorand.d.ts.map +1 -1
  313. package/lib-es/e2e/families/algorand.js +4 -5
  314. package/lib-es/e2e/families/algorand.js.map +1 -1
  315. package/lib-es/e2e/families/aptos.d.ts +2 -2
  316. package/lib-es/e2e/families/aptos.d.ts.map +1 -1
  317. package/lib-es/e2e/families/aptos.js +7 -9
  318. package/lib-es/e2e/families/aptos.js.map +1 -1
  319. package/lib-es/e2e/families/bitcoin.d.ts +2 -2
  320. package/lib-es/e2e/families/bitcoin.d.ts.map +1 -1
  321. package/lib-es/e2e/families/bitcoin.js +9 -11
  322. package/lib-es/e2e/families/bitcoin.js.map +1 -1
  323. package/lib-es/e2e/families/cardano.d.ts +0 -6
  324. package/lib-es/e2e/families/cardano.d.ts.map +1 -1
  325. package/lib-es/e2e/families/cardano.js +21 -23
  326. package/lib-es/e2e/families/cardano.js.map +1 -1
  327. package/lib-es/e2e/families/celo.d.ts +1 -1
  328. package/lib-es/e2e/families/celo.d.ts.map +1 -1
  329. package/lib-es/e2e/families/celo.js +4 -5
  330. package/lib-es/e2e/families/celo.js.map +1 -1
  331. package/lib-es/e2e/families/cosmos.d.ts +2 -2
  332. package/lib-es/e2e/families/cosmos.d.ts.map +1 -1
  333. package/lib-es/e2e/families/cosmos.js +7 -9
  334. package/lib-es/e2e/families/cosmos.js.map +1 -1
  335. package/lib-es/e2e/families/evm.d.ts +0 -2
  336. package/lib-es/e2e/families/evm.d.ts.map +1 -1
  337. package/lib-es/e2e/families/evm.js +9 -10
  338. package/lib-es/e2e/families/evm.js.map +1 -1
  339. package/lib-es/e2e/families/hedera.d.ts +1 -1
  340. package/lib-es/e2e/families/hedera.d.ts.map +1 -1
  341. package/lib-es/e2e/families/hedera.js +4 -5
  342. package/lib-es/e2e/families/hedera.js.map +1 -1
  343. package/lib-es/e2e/families/kaspa.d.ts +2 -2
  344. package/lib-es/e2e/families/kaspa.d.ts.map +1 -1
  345. package/lib-es/e2e/families/kaspa.js +7 -9
  346. package/lib-es/e2e/families/kaspa.js.map +1 -1
  347. package/lib-es/e2e/families/multiversX.d.ts +1 -1
  348. package/lib-es/e2e/families/multiversX.d.ts.map +1 -1
  349. package/lib-es/e2e/families/multiversX.js +4 -5
  350. package/lib-es/e2e/families/multiversX.js.map +1 -1
  351. package/lib-es/e2e/families/near.d.ts +1 -1
  352. package/lib-es/e2e/families/near.d.ts.map +1 -1
  353. package/lib-es/e2e/families/near.js +5 -6
  354. package/lib-es/e2e/families/near.js.map +1 -1
  355. package/lib-es/e2e/families/osmosis.d.ts +1 -1
  356. package/lib-es/e2e/families/osmosis.d.ts.map +1 -1
  357. package/lib-es/e2e/families/osmosis.js +4 -5
  358. package/lib-es/e2e/families/osmosis.js.map +1 -1
  359. package/lib-es/e2e/families/polkadot.d.ts +1 -1
  360. package/lib-es/e2e/families/polkadot.d.ts.map +1 -1
  361. package/lib-es/e2e/families/polkadot.js +4 -5
  362. package/lib-es/e2e/families/polkadot.js.map +1 -1
  363. package/lib-es/e2e/families/solana.d.ts +2 -2
  364. package/lib-es/e2e/families/solana.d.ts.map +1 -1
  365. package/lib-es/e2e/families/solana.js +7 -9
  366. package/lib-es/e2e/families/solana.js.map +1 -1
  367. package/lib-es/e2e/families/stellar.d.ts +1 -1
  368. package/lib-es/e2e/families/stellar.d.ts.map +1 -1
  369. package/lib-es/e2e/families/stellar.js +4 -5
  370. package/lib-es/e2e/families/stellar.js.map +1 -1
  371. package/lib-es/e2e/families/sui.d.ts +1 -1
  372. package/lib-es/e2e/families/sui.d.ts.map +1 -1
  373. package/lib-es/e2e/families/sui.js +4 -5
  374. package/lib-es/e2e/families/sui.js.map +1 -1
  375. package/lib-es/e2e/families/tezos.d.ts +1 -1
  376. package/lib-es/e2e/families/tezos.d.ts.map +1 -1
  377. package/lib-es/e2e/families/tezos.js +8 -8
  378. package/lib-es/e2e/families/tezos.js.map +1 -1
  379. package/lib-es/e2e/families/tron.d.ts +1 -1
  380. package/lib-es/e2e/families/tron.d.ts.map +1 -1
  381. package/lib-es/e2e/families/tron.js +4 -5
  382. package/lib-es/e2e/families/tron.js.map +1 -1
  383. package/lib-es/e2e/families/xrp.d.ts +1 -1
  384. package/lib-es/e2e/families/xrp.d.ts.map +1 -1
  385. package/lib-es/e2e/families/xrp.js +4 -5
  386. package/lib-es/e2e/families/xrp.js.map +1 -1
  387. package/lib-es/e2e/index.d.ts +0 -15
  388. package/lib-es/e2e/index.d.ts.map +1 -1
  389. package/lib-es/e2e/speculos.d.ts +11 -11
  390. package/lib-es/e2e/speculos.d.ts.map +1 -1
  391. package/lib-es/e2e/speculos.js +43 -54
  392. package/lib-es/e2e/speculos.js.map +1 -1
  393. package/lib-es/exchange/providers/swap.d.ts +0 -1
  394. package/lib-es/exchange/providers/swap.d.ts.map +1 -1
  395. package/lib-es/exchange/providers/swap.js +0 -3
  396. package/lib-es/exchange/providers/swap.js.map +1 -1
  397. package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyAll.d.ts.map +1 -1
  398. package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyAll.js +3 -2
  399. package/lib-es/exchange/swap/hooks/v5/useFetchCurrencyAll.js.map +1 -1
  400. package/lib-es/exchange/swap/hooks/v5/useFilteredProviders.d.ts.map +1 -1
  401. package/lib-es/exchange/swap/hooks/v5/useFilteredProviders.js +12 -17
  402. package/lib-es/exchange/swap/hooks/v5/useFilteredProviders.js.map +1 -1
  403. package/lib-es/families/canton/bridge/mock.d.ts.map +1 -1
  404. package/lib-es/families/canton/bridge/mock.js +0 -1
  405. package/lib-es/families/canton/bridge/mock.js.map +1 -1
  406. package/lib-es/families/evm/config.d.ts.map +1 -1
  407. package/lib-es/families/evm/config.js +0 -49
  408. package/lib-es/families/evm/config.js.map +1 -1
  409. package/lib-es/featureFlags/defaultFeatures.d.ts +0 -3
  410. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
  411. package/lib-es/featureFlags/defaultFeatures.js +0 -6
  412. package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
  413. package/lib-es/featureFlags/useFeature.d.ts +1 -1
  414. package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
  415. package/lib-es/market/hooks/useMarketDataProvider.js +0 -1
  416. package/lib-es/market/hooks/useMarketDataProvider.js.map +1 -1
  417. package/lib-es/market/utils/types.d.ts +0 -1
  418. package/lib-es/market/utils/types.d.ts.map +1 -1
  419. package/lib-es/market/utils/types.js.map +1 -1
  420. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.d.ts +22 -0
  421. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.d.ts.map +1 -0
  422. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js +38 -0
  423. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js.map +1 -0
  424. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
  425. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +0 -11
  426. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
  427. package/lib-es/modularDrawer/hooks/useNetworkAccountCounts.d.ts +5 -1
  428. package/lib-es/modularDrawer/hooks/useNetworkAccountCounts.d.ts.map +1 -1
  429. package/lib-es/modularDrawer/hooks/useNetworkAccountCounts.js +2 -2
  430. package/lib-es/modularDrawer/hooks/useNetworkAccountCounts.js.map +1 -1
  431. package/lib-es/modularDrawer/modules/createNetworkConfiguration.d.ts +1 -1
  432. package/lib-es/modularDrawer/modules/createNetworkConfiguration.d.ts.map +1 -1
  433. package/lib-es/modularDrawer/modules/createNetworkConfiguration.js +2 -1
  434. package/lib-es/modularDrawer/modules/createNetworkConfiguration.js.map +1 -1
  435. package/lib-es/modularDrawer/utils/currencyUtils.d.ts +10 -0
  436. package/lib-es/modularDrawer/utils/currencyUtils.d.ts.map +1 -0
  437. package/lib-es/modularDrawer/utils/currencyUtils.js +65 -0
  438. package/lib-es/modularDrawer/utils/currencyUtils.js.map +1 -0
  439. package/lib-es/modularDrawer/utils/{groupCurrenciesByAsset.d.ts → groupCurrenciesByProvider.d.ts} +2 -2
  440. package/lib-es/modularDrawer/utils/groupCurrenciesByProvider.d.ts.map +1 -0
  441. package/lib-es/modularDrawer/utils/{groupCurrenciesByAsset.js → groupCurrenciesByProvider.js} +6 -6
  442. package/lib-es/modularDrawer/utils/groupCurrenciesByProvider.js.map +1 -0
  443. package/lib-es/modularDrawer/utils/index.d.ts +1 -1
  444. package/lib-es/modularDrawer/utils/index.d.ts.map +1 -1
  445. package/lib-es/modularDrawer/utils/index.js +1 -1
  446. package/lib-es/modularDrawer/utils/index.js.map +1 -1
  447. package/lib-es/modularDrawer/utils/type.d.ts +5 -0
  448. package/lib-es/modularDrawer/utils/type.d.ts.map +1 -1
  449. package/lib-es/platform/filters.d.ts +2 -1
  450. package/lib-es/platform/filters.d.ts.map +1 -1
  451. package/lib-es/platform/filters.js +15 -0
  452. package/lib-es/platform/filters.js.map +1 -1
  453. package/lib-es/platform/helpers.d.ts +5 -1
  454. package/lib-es/platform/helpers.d.ts.map +1 -1
  455. package/lib-es/platform/helpers.js +30 -1
  456. package/lib-es/platform/helpers.js.map +1 -1
  457. package/lib-es/platform/react.d.ts +3 -2
  458. package/lib-es/platform/react.d.ts.map +1 -1
  459. package/lib-es/platform/react.js +16 -67
  460. package/lib-es/platform/react.js.map +1 -1
  461. package/lib-es/platform/types.d.ts +3 -3
  462. package/lib-es/platform/types.d.ts.map +1 -1
  463. package/lib-es/postOnboarding/reducer.d.ts +0 -2
  464. package/lib-es/postOnboarding/reducer.d.ts.map +1 -1
  465. package/lib-es/utils/getAccountTuplesForCurrency.d.ts +1 -1
  466. package/lib-es/utils/getAccountTuplesForCurrency.d.ts.map +1 -1
  467. package/lib-es/utils/getAccountTuplesForCurrency.js +3 -2
  468. package/lib-es/utils/getAccountTuplesForCurrency.js.map +1 -1
  469. package/lib-es/wallet-api/Exchange/server.d.ts.map +1 -1
  470. package/lib-es/wallet-api/Exchange/server.js +4 -5
  471. package/lib-es/wallet-api/Exchange/server.js.map +1 -1
  472. package/lib-es/wallet-api/converters.d.ts +0 -1
  473. package/lib-es/wallet-api/converters.d.ts.map +1 -1
  474. package/lib-es/wallet-api/converters.js +1 -5
  475. package/lib-es/wallet-api/converters.js.map +1 -1
  476. package/lib-es/wallet-api/react.d.ts +11 -6
  477. package/lib-es/wallet-api/react.d.ts.map +1 -1
  478. package/lib-es/wallet-api/react.js +131 -291
  479. package/lib-es/wallet-api/react.js.map +1 -1
  480. package/lib-es/wallet-api/tracking.d.ts +0 -6
  481. package/lib-es/wallet-api/tracking.d.ts.map +1 -1
  482. package/lib-es/wallet-api/tracking.js +0 -20
  483. package/lib-es/wallet-api/tracking.js.map +1 -1
  484. package/lib-es/wallet-api/types.d.ts +0 -3
  485. package/lib-es/wallet-api/types.d.ts.map +1 -1
  486. package/lib-es/wallet-api/useDappLogic.d.ts.map +1 -1
  487. package/lib-es/wallet-api/useDappLogic.js +77 -62
  488. package/lib-es/wallet-api/useDappLogic.js.map +1 -1
  489. package/lib-es/wallet-api/utils/deriveAccountIdForManifest.d.ts +0 -6
  490. package/lib-es/wallet-api/utils/deriveAccountIdForManifest.d.ts.map +1 -1
  491. package/lib-es/wallet-api/utils/deriveAccountIdForManifest.js +2 -11
  492. package/lib-es/wallet-api/utils/deriveAccountIdForManifest.js.map +1 -1
  493. package/package.json +58 -59
  494. package/src/__tests__/migration/account-migration.ts +0 -3
  495. package/src/__tests__/test-helpers/bridge.ts +2 -0
  496. package/src/__tests__/test-helpers/environment.ts +0 -3
  497. package/src/bridge/generic-alpaca/getAccountShape.ts +12 -15
  498. package/src/bridge/generic-alpaca/tests/getAccountShape.test.ts +101 -142
  499. package/src/currencies/helpers.test.ts +20 -0
  500. package/src/currencies/helpers.ts +42 -1
  501. package/src/dada-client/hooks/useAssetsData.ts +0 -1
  502. package/src/deposit/deposit.integration.test.ts +88 -0
  503. package/src/deposit/deposit.test.ts +684 -0
  504. package/src/deposit/helper.ts +143 -0
  505. package/src/deposit/index.ts +3 -0
  506. package/src/deposit/mock.ts +15112 -0
  507. package/src/deposit/type.ts +21 -0
  508. package/src/deposit/useGroupedCurrenciesByProvider.hook.ts +46 -0
  509. package/src/deviceSDK/hooks/useBatteryStatuses.test.ts +1 -3
  510. package/src/deviceSDK/hooks/useBatteryStatuses.ts +1 -4
  511. package/src/deviceSDK/tasks/core.test.ts +0 -20
  512. package/src/deviceSDK/tasks/core.ts +1 -2
  513. package/src/deviceSDK/tasks/getDeviceInfo.ts +0 -2
  514. package/src/deviceSDK/tasks/getLatestFirmware.ts +4 -4
  515. package/src/deviceSDK/tasks/updateFirmware.ts +0 -2
  516. package/src/e2e/deviceInteraction/ButtonDeviceSimulator.ts +23 -0
  517. package/src/e2e/enum/Account.ts +6 -0
  518. package/src/e2e/enum/Currency.ts +6 -2
  519. package/src/e2e/families/algorand.ts +13 -20
  520. package/src/e2e/families/aptos.ts +16 -28
  521. package/src/e2e/families/bitcoin.ts +39 -53
  522. package/src/e2e/families/cardano.ts +36 -47
  523. package/src/e2e/families/celo.ts +12 -18
  524. package/src/e2e/families/cosmos.ts +23 -35
  525. package/src/e2e/families/evm.ts +13 -24
  526. package/src/e2e/families/hedera.ts +4 -6
  527. package/src/e2e/families/kaspa.ts +16 -28
  528. package/src/e2e/families/multiversX.ts +10 -16
  529. package/src/e2e/families/near.ts +17 -23
  530. package/src/e2e/families/osmosis.ts +13 -19
  531. package/src/e2e/families/polkadot.ts +13 -19
  532. package/src/e2e/families/solana.ts +23 -35
  533. package/src/e2e/families/stellar.ts +13 -18
  534. package/src/e2e/families/sui.ts +9 -15
  535. package/src/e2e/families/tezos.ts +18 -25
  536. package/src/e2e/families/tron.ts +13 -19
  537. package/src/e2e/families/xrp.ts +13 -19
  538. package/src/e2e/speculos.ts +140 -168
  539. package/src/exchange/providers/swap.ts +0 -4
  540. package/src/exchange/swap/hooks/v5/useFetchCurrencyAll.ts +3 -2
  541. package/src/exchange/swap/hooks/v5/useFilteredProviders.ts +12 -37
  542. package/src/families/canton/bridge/mock.ts +0 -1
  543. package/src/families/evm/config.ts +0 -49
  544. package/src/families/stellar/__snapshots__/bridge.integration.test.ts.snap +12 -84
  545. package/src/featureFlags/defaultFeatures.ts +0 -6
  546. package/src/market/hooks/useMarketDataProvider.ts +0 -1
  547. package/src/market/utils/types.ts +0 -1
  548. package/src/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.ts +49 -0
  549. package/src/modularDrawer/hooks/__test__/useAssetAccountCounts.test.ts +5 -0
  550. package/src/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.ts +0 -11
  551. package/src/modularDrawer/hooks/useNetworkAccountCounts.tsx +6 -1
  552. package/src/modularDrawer/modules/__test__/createAssetConfiguration.test.tsx +2 -2
  553. package/src/modularDrawer/modules/__test__/createNetworkConfiguration.test.ts +342 -0
  554. package/src/modularDrawer/modules/createNetworkConfiguration.ts +2 -1
  555. package/src/modularDrawer/utils/__tests__/currencyUtils.test.ts +126 -0
  556. package/src/modularDrawer/utils/currencyUtils.ts +95 -0
  557. package/src/modularDrawer/utils/{groupCurrenciesByAsset.ts → groupCurrenciesByProvider.ts} +5 -5
  558. package/src/modularDrawer/utils/index.ts +1 -1
  559. package/src/modularDrawer/utils/type.ts +5 -0
  560. package/src/platform/filters.ts +23 -1
  561. package/src/platform/helpers.ts +49 -2
  562. package/src/platform/react.ts +22 -86
  563. package/src/platform/types.ts +1 -1
  564. package/src/utils/__tests__/getAccountTuplesForCurrency.test.ts +30 -0
  565. package/src/utils/getAccountTuplesForCurrency.ts +6 -1
  566. package/src/wallet-api/Exchange/server.test.ts +5 -0
  567. package/src/wallet-api/Exchange/server.ts +6 -7
  568. package/src/wallet-api/converters.ts +1 -6
  569. package/src/wallet-api/react.ts +137 -312
  570. package/src/wallet-api/tracking.ts +0 -22
  571. package/src/wallet-api/types.ts +0 -5
  572. package/src/wallet-api/useDappLogic.ts +106 -91
  573. package/src/wallet-api/utils/deriveAccountIdForManifest.ts +2 -14
  574. package/lib/device/use-cases/getDeviceHasBattery.d.ts +0 -2
  575. package/lib/device/use-cases/getDeviceHasBattery.d.ts.map +0 -1
  576. package/lib/device/use-cases/getDeviceHasBattery.js +0 -6
  577. package/lib/device/use-cases/getDeviceHasBattery.js.map +0 -1
  578. package/lib/e2e/deviceInteraction/DeviceController.d.ts +0 -41
  579. package/lib/e2e/deviceInteraction/DeviceController.d.ts.map +0 -1
  580. package/lib/e2e/deviceInteraction/DeviceController.js +0 -68
  581. package/lib/e2e/deviceInteraction/DeviceController.js.map +0 -1
  582. package/lib/e2e/enum/ReceiveFundsOptions.d.ts +0 -6
  583. package/lib/e2e/enum/ReceiveFundsOptions.d.ts.map +0 -1
  584. package/lib/e2e/enum/ReceiveFundsOptions.js +0 -8
  585. package/lib/e2e/enum/ReceiveFundsOptions.js.map +0 -1
  586. package/lib/families/canton/react.d.ts +0 -15
  587. package/lib/families/canton/react.d.ts.map +0 -1
  588. package/lib/families/canton/react.js +0 -14
  589. package/lib/families/canton/react.js.map +0 -1
  590. package/lib/modularDrawer/utils/groupCurrenciesByAsset.d.ts.map +0 -1
  591. package/lib/modularDrawer/utils/groupCurrenciesByAsset.js +0 -21
  592. package/lib/modularDrawer/utils/groupCurrenciesByAsset.js.map +0 -1
  593. package/lib-es/device/use-cases/getDeviceHasBattery.d.ts +0 -2
  594. package/lib-es/device/use-cases/getDeviceHasBattery.d.ts.map +0 -1
  595. package/lib-es/device/use-cases/getDeviceHasBattery.js +0 -2
  596. package/lib-es/device/use-cases/getDeviceHasBattery.js.map +0 -1
  597. package/lib-es/e2e/deviceInteraction/DeviceController.d.ts +0 -41
  598. package/lib-es/e2e/deviceInteraction/DeviceController.d.ts.map +0 -1
  599. package/lib-es/e2e/deviceInteraction/DeviceController.js +0 -63
  600. package/lib-es/e2e/deviceInteraction/DeviceController.js.map +0 -1
  601. package/lib-es/e2e/enum/ReceiveFundsOptions.d.ts +0 -6
  602. package/lib-es/e2e/enum/ReceiveFundsOptions.d.ts.map +0 -1
  603. package/lib-es/e2e/enum/ReceiveFundsOptions.js +0 -5
  604. package/lib-es/e2e/enum/ReceiveFundsOptions.js.map +0 -1
  605. package/lib-es/families/canton/react.d.ts +0 -15
  606. package/lib-es/families/canton/react.d.ts.map +0 -1
  607. package/lib-es/families/canton/react.js +0 -10
  608. package/lib-es/families/canton/react.js.map +0 -1
  609. package/lib-es/modularDrawer/utils/groupCurrenciesByAsset.d.ts.map +0 -1
  610. package/lib-es/modularDrawer/utils/groupCurrenciesByAsset.js.map +0 -1
  611. package/src/device/use-cases/getDeviceHasBattery.ts +0 -1
  612. package/src/e2e/deviceInteraction/DeviceController.ts +0 -85
  613. package/src/e2e/enum/ReceiveFundsOptions.ts +0 -7
  614. package/src/families/canton/react.ts +0 -50
  615. package/src/modularDrawer/utils/__tests__/groupCurrenciesByAsset.test.ts +0 -88
@@ -1,38 +1,26 @@
1
1
  import { useMemo, useState, useEffect, useRef, useCallback, RefObject } from "react";
2
- import { useDispatch } from "react-redux";
3
2
  import semver from "semver";
4
3
  import { intervalToDuration } from "date-fns";
4
+
5
5
  import { Account, AccountLike, AnyMessage, Operation, SignedOperation } from "@ledgerhq/types-live";
6
- import {
7
- WalletHandlers,
8
- ServerConfig,
9
- WalletAPIServer,
10
- useWalletAPIServer as useWalletAPIServerRaw,
11
- } from "@ledgerhq/wallet-api-server";
6
+ import { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
7
+ import { WalletHandlers, ServerConfig, WalletAPIServer } from "@ledgerhq/wallet-api-server";
8
+ import { useWalletAPIServer as useWalletAPIServerRaw } from "@ledgerhq/wallet-api-server/lib/react";
12
9
  import { Transport, Permission } from "@ledgerhq/wallet-api-core";
13
- import { first } from "rxjs/operators";
14
- import { getEnv } from "@ledgerhq/live-env";
15
- import { UserRefusedOnDevice } from "@ledgerhq/errors";
16
- import { WalletState } from "@ledgerhq/live-wallet/store";
17
- import { endpoints as calEndpoints } from "@ledgerhq/cryptoassets/cal-client/state-manager/api";
18
- import { ThunkDispatch, UnknownAction } from "@reduxjs/toolkit";
19
- import { InfiniteData } from "@reduxjs/toolkit/query";
20
- import type {
21
- TokensDataWithPagination,
22
- PageParam,
23
- } from "@ledgerhq/cryptoassets/lib/cal-client/state-manager/types";
24
- import { Subject } from "rxjs";
25
10
  import { StateDB } from "../hooks/useDBRaw";
11
+ import { Observable, firstValueFrom, Subject } from "rxjs";
12
+ import { first } from "rxjs/operators";
26
13
  import {
27
14
  accountToWalletAPIAccount,
28
15
  currencyToWalletAPICurrency,
29
- setWalletApiIdForAccountId,
16
+ getAccountIdFromWalletAccountId,
30
17
  } from "./converters";
31
18
  import { isWalletAPISupportedCurrency } from "./helpers";
32
19
  import { WalletAPICurrency, AppManifest, WalletAPIAccount, WalletAPICustomHandlers } from "./types";
20
+
33
21
  import { getMainAccount, getParentAccount } from "../account";
34
- import { listSupportedCurrencies } from "../currencies";
35
- import { getCryptoAssetsStore } from "../bridge/crypto-assets";
22
+ import { listCurrencies, findCryptoCurrencyById, getCryptoCurrencyById } from "../currencies";
23
+ import { getCryptoAssetsStore } from "../bridge/crypto-assets/index";
36
24
  import { TrackingAPI } from "./tracking";
37
25
  import {
38
26
  bitcoinFamilyAccountGetXPubLogic,
@@ -49,8 +37,10 @@ import {
49
37
  signRawTransactionLogic,
50
38
  } from "./logic";
51
39
  import { getAccountBridge } from "../bridge";
40
+ import { getEnv } from "@ledgerhq/live-env";
52
41
  import openTransportAsSubject, { BidirectionalEvent } from "../hw/openTransportAsSubject";
53
42
  import { AppResult } from "../hw/actions/app";
43
+ import { UserRefusedOnDevice } from "@ledgerhq/errors";
54
44
  import { Transaction } from "../generated/types";
55
45
  import {
56
46
  DISCOVER_INITIAL_CATEGORY,
@@ -59,8 +49,8 @@ import {
59
49
  } from "./constants";
60
50
  import { DiscoverDB } from "./types";
61
51
  import { LiveAppManifest } from "../platform/types";
52
+ import { WalletState } from "@ledgerhq/live-wallet/store";
62
53
  import { ModularDrawerConfiguration } from "./ModularDrawer/types";
63
- import { useCurrenciesUnderFeatureFlag } from "../modularDrawer/hooks/useCurrenciesUnderFeatureFlag";
64
54
 
65
55
  export function safeGetRefValue<T>(ref: RefObject<T>): NonNullable<T> {
66
56
  if (!ref.current) {
@@ -69,27 +59,75 @@ export function safeGetRefValue<T>(ref: RefObject<T>): NonNullable<T> {
69
59
  return ref.current;
70
60
  }
71
61
 
72
- export function useSetWalletAPIAccounts(accounts: AccountLike[]): void {
73
- useEffect(() => {
74
- accounts.forEach(account => {
75
- setWalletApiIdForAccountId(account.id);
62
+ export function useWalletAPIAccounts(
63
+ walletState: WalletState,
64
+ accounts: AccountLike[],
65
+ ): WalletAPIAccount[] {
66
+ return useMemo(() => {
67
+ return accounts.map(account => {
68
+ const parentAccount = getParentAccount(account, accounts);
69
+
70
+ return accountToWalletAPIAccount(walletState, account, parentAccount);
76
71
  });
77
- }, [accounts]);
72
+ }, [walletState, accounts]);
78
73
  }
79
74
 
80
- export function useDAppManifestCurrencyIds(manifest: AppManifest) {
75
+ export function useWalletAPICurrencies(): WalletAPICurrency[] {
76
+ return useMemo(() => {
77
+ return listCurrencies(true).reduce<WalletAPICurrency[]>((filtered, currency) => {
78
+ if (isWalletAPISupportedCurrency(currency)) {
79
+ filtered.push(currencyToWalletAPICurrency(currency));
80
+ }
81
+ return filtered;
82
+ }, []);
83
+ }, []);
84
+ }
85
+
86
+ export function useManifestCurrencies(manifest: AppManifest) {
81
87
  return useMemo(() => {
82
88
  return (
83
89
  manifest.dapp?.networks.map(network => {
84
- return network.currency;
90
+ return getCryptoCurrencyById(network.currency);
85
91
  }) ?? []
86
92
  );
87
93
  }, [manifest.dapp?.networks]);
88
94
  }
89
95
 
96
+ export function useGetAccountIds(
97
+ accounts$: Observable<WalletAPIAccount[]> | undefined,
98
+ ): Map<string, boolean> | undefined {
99
+ const [accounts, setAccounts] = useState<WalletAPIAccount[]>([]);
100
+
101
+ useEffect(() => {
102
+ if (!accounts$) {
103
+ return undefined;
104
+ }
105
+
106
+ const subscription = accounts$.subscribe(walletAccounts => {
107
+ setAccounts(walletAccounts);
108
+ });
109
+
110
+ return () => {
111
+ subscription.unsubscribe();
112
+ };
113
+ }, [accounts$]);
114
+
115
+ return useMemo(() => {
116
+ if (!accounts$) {
117
+ return undefined;
118
+ }
119
+
120
+ return accounts.reduce((accountIds, account) => {
121
+ accountIds.set(getAccountIdFromWalletAccountId(account.id), true);
122
+ return accountIds;
123
+ }, new Map());
124
+ }, [accounts, accounts$]);
125
+ }
126
+
90
127
  export interface UiHook {
91
128
  "account.request": (params: {
92
- currencyIds?: string[];
129
+ accounts$?: Observable<WalletAPIAccount[]>;
130
+ currencies: CryptoOrTokenCurrency[];
93
131
  areCurrenciesFiltered?: boolean;
94
132
  useCase?: string;
95
133
  drawerConfiguration?: ModularDrawerConfiguration;
@@ -162,10 +200,11 @@ export interface UiHook {
162
200
  }) => void;
163
201
  }
164
202
 
165
- export function usePermission(manifest: AppManifest): Omit<Permission, "currencyIds"> {
203
+ export function usePermission(manifest: AppManifest): Permission {
166
204
  return useMemo(
167
205
  () => ({
168
- methodIds: manifest.permissions,
206
+ currencyIds: manifest.currencies === "*" ? ["**"] : manifest.currencies,
207
+ methodIds: manifest.permissions as unknown as string[], // TODO remove when using the correct manifest type
169
208
  }),
170
209
  [manifest],
171
210
  );
@@ -195,7 +234,7 @@ export function useConfig({
195
234
  wallet,
196
235
  mevProtected,
197
236
  }),
198
- [appId, mevProtected, tracking, userId, wallet],
237
+ [appId, tracking, userId, wallet],
199
238
  );
200
239
  }
201
240
 
@@ -303,19 +342,18 @@ export function useWalletAPIServer({
303
342
  onLoadError: () => void;
304
343
  widgetLoaded: boolean;
305
344
  } {
306
- const dispatch = useDispatch<ThunkDispatch<any, any, UnknownAction>>();
307
- const { deactivatedCurrencyIds } = useCurrenciesUnderFeatureFlag();
308
345
  const permission = usePermission(manifest);
309
346
  const transport = useTransport(webviewHook.postMessage);
310
347
  const [widgetLoaded, setWidgetLoaded] = useState(false);
311
348
 
312
- // We need to set the wallet API account IDs mapping upfront
313
- // If we don't want the map to be empty when requesting an account
314
- useSetWalletAPIAccounts(accounts);
349
+ const walletAPIAccounts = useWalletAPIAccounts(walletState, accounts);
350
+ const walletAPICurrencies = useWalletAPICurrencies();
315
351
 
316
352
  const { server, onMessage } = useWalletAPIServerRaw({
317
353
  transport,
318
354
  config,
355
+ accounts: walletAPIAccounts,
356
+ currencies: walletAPICurrencies,
319
357
  permission,
320
358
  customHandlers,
321
359
  });
@@ -324,259 +362,52 @@ export function useWalletAPIServer({
324
362
  tracking.load(manifest);
325
363
  }, [tracking, manifest]);
326
364
 
327
- // TODO: refactor each handler into its own logic function for clarity
328
- useEffect(() => {
329
- server.setHandler("currency.list", async ({ currencyIds }) => {
330
- tracking.currencyListRequested(manifest);
331
-
332
- try {
333
- // 1. Parse manifest currency patterns to determine what to include
334
- const manifestCurrencyIds = manifest.currencies === "*" ? ["**"] : manifest.currencies;
335
-
336
- // 2. Apply query filter early - intersect with manifest patterns
337
- const queryCurrencyIdsSet = currencyIds ? new Set(currencyIds) : undefined;
338
- let effectiveCurrencyIds = manifestCurrencyIds;
339
-
340
- if (queryCurrencyIdsSet) {
341
- // If we have a query filter, narrow down what we need to fetch
342
- effectiveCurrencyIds = manifestCurrencyIds.flatMap(manifestId => {
343
- if (manifestId === "**") {
344
- // Query can ask for anything, so use the query list
345
- return [...queryCurrencyIdsSet];
346
- } else if (manifestId.endsWith("/**")) {
347
- // Pattern like "ethereum/**" - keep tokens from query that match this family
348
- const family = manifestId.slice(0, -3);
349
- return [...queryCurrencyIdsSet].filter(qId => qId.startsWith(`${family}/`));
350
- } else if (queryCurrencyIdsSet.has(manifestId)) {
351
- // Specific currency/token that's in the query
352
- return [manifestId];
353
- }
354
- // Not in query, skip it
355
- return [];
356
- });
357
- }
358
-
359
- // 3. Parse effective currency IDs to determine what to fetch
360
- const includeAllCurrencies = effectiveCurrencyIds.includes("**");
361
- const specificCurrencies = new Set<string>();
362
- const tokenFamilies = new Set<string>();
363
- const specificTokenIds = new Set<string>();
364
-
365
- for (const id of effectiveCurrencyIds) {
366
- if (id === "**") {
367
- // Already handled above
368
- continue;
369
- } else if (id.endsWith("/**")) {
370
- // Pattern like "ethereum/**" or "solana/**" - include tokens for this family
371
- const family = id.slice(0, -3);
372
- tokenFamilies.add(family);
373
- // Additionally include the parent currency itself
374
- specificCurrencies.add(family);
375
- } else if (id.includes("/")) {
376
- // Specific token ID like "ethereum/erc20/usd__coin"
377
- specificTokenIds.add(id);
378
- } else {
379
- // Specific currency like "bitcoin" or "ethereum"
380
- specificCurrencies.add(id);
381
- }
382
- }
383
-
384
- // 4. Gather all supported parent currencies
385
- const allCurrencies = listSupportedCurrencies().reduce<WalletAPICurrency[]>((acc, c) => {
386
- if (isWalletAPISupportedCurrency(c) && !deactivatedCurrencyIds.has(c.id))
387
- acc.push(currencyToWalletAPICurrency(c));
388
- return acc;
389
- }, []);
390
-
391
- // 5. Determine which currencies to include based on patterns
392
- let includedCurrencies: WalletAPICurrency[] = [];
393
- if (includeAllCurrencies) {
394
- includedCurrencies = allCurrencies;
395
- } else {
396
- includedCurrencies = allCurrencies.filter(c => specificCurrencies.has(c.id));
397
- }
398
-
399
- // 6. Fetch specific tokens by ID if any
400
- const specificTokens: WalletAPICurrency[] = [];
401
- if (specificTokenIds.size > 0) {
402
- const tokenPromises = [...specificTokenIds].map(async tokenId => {
403
- const token = await getCryptoAssetsStore().findTokenById(tokenId);
404
- return token ? currencyToWalletAPICurrency(token) : null;
405
- });
406
- const resolvedTokens = await Promise.all(tokenPromises);
407
- specificTokens.push(...resolvedTokens.filter((t): t is WalletAPICurrency => t !== null));
408
- }
409
-
410
- // 7. Determine which token families to fetch (only if not already fetched as specific tokens)
411
- const familiesToFetch = new Set<string>();
412
- if (includeAllCurrencies) {
413
- // Fetch tokens for all currency families
414
- allCurrencies.forEach(c => {
415
- if (c.type === "CryptoCurrency") familiesToFetch.add(c.family);
416
- });
417
- } else if (tokenFamilies.size > 0) {
418
- // Only fetch tokens for families explicitly marked with /**
419
- tokenFamilies.forEach(family => familiesToFetch.add(family));
420
- }
421
-
422
- // 8. Fetch tokens for relevant families
423
- const fetchAllPagesForFamily = async (family: string) => {
424
- const args = { networkFamily: family, pageSize: 1000 };
425
- let hasNextPage = true;
426
- let data: InfiniteData<TokensDataWithPagination, PageParam> | undefined;
427
-
428
- while (hasNextPage) {
429
- const querySub = dispatch(
430
- calEndpoints.getTokensData.initiate(
431
- args,
432
- data ? { direction: "forward" } : undefined,
433
- ),
434
- );
435
-
436
- try {
437
- const result = await querySub;
438
- data = result.data;
439
- hasNextPage = result.hasNextPage;
440
- if (result.error) throw result.error;
441
- } finally {
442
- querySub.unsubscribe();
443
- }
444
- }
445
-
446
- return (data?.pages ?? []).flatMap(p => p.tokens);
447
- };
448
-
449
- const tokensByFamily = await Promise.all(
450
- [...familiesToFetch].map(f => fetchAllPagesForFamily(f)),
451
- );
452
-
453
- // 9. Combine all results (no additional filter needed since we pre-filtered)
454
- const result = tokensByFamily.reduce<WalletAPICurrency[]>(
455
- (acc, tokens) => [...acc, ...tokens.map(t => currencyToWalletAPICurrency(t))],
456
- [...includedCurrencies, ...specificTokens],
457
- );
458
-
459
- tracking.currencyListSuccess(manifest);
460
- return result;
461
- } catch (err) {
462
- tracking.currencyListFail(manifest);
463
- throw err;
464
- }
465
- });
466
- }, [walletState, manifest, server, tracking, dispatch, deactivatedCurrencyIds]);
467
-
468
- useEffect(() => {
469
- server.setHandler("account.list", ({ currencyIds }) => {
470
- tracking.accountListRequested(manifest);
471
-
472
- try {
473
- // 1. Parse manifest currency patterns to determine what to include
474
- const manifestCurrencyIds = manifest.currencies === "*" ? ["**"] : manifest.currencies;
475
-
476
- // 2. Apply query filter early - intersect with manifest patterns
477
- const queryCurrencyIdsSet = currencyIds ? new Set(currencyIds) : undefined;
478
- let effectiveCurrencyIds = manifestCurrencyIds;
479
-
480
- if (queryCurrencyIdsSet) {
481
- // If we have a query filter, narrow down what we need to check
482
- effectiveCurrencyIds = manifestCurrencyIds.flatMap(manifestId => {
483
- if (manifestId === "**") {
484
- // Query can ask for anything, so use the query list
485
- return [...queryCurrencyIdsSet];
486
- } else if (manifestId.endsWith("/**")) {
487
- // Pattern like "ethereum/**" - keep tokens from query that match this family
488
- const family = manifestId.slice(0, -3);
489
- return [...queryCurrencyIdsSet].filter(qId => qId.startsWith(`${family}/`));
490
- } else if (queryCurrencyIdsSet.has(manifestId)) {
491
- // Specific currency/token that's in the query
492
- return [manifestId];
493
- }
494
- // Not in query, skip it
495
- return [];
496
- });
497
- }
498
-
499
- // 3. Build a set of allowed currency IDs based on effective patterns
500
- const allowedCurrencyIds = new Set<string>();
501
- const includeAllCurrencies = effectiveCurrencyIds.includes("**");
502
- const tokenFamilyPrefixes = new Set<string>();
503
-
504
- for (const id of effectiveCurrencyIds) {
505
- if (id === "**") {
506
- // Will match all currencies
507
- continue;
508
- } else if (id.endsWith("/**")) {
509
- // Pattern like "ethereum/**" - store prefix for matching
510
- const family = id.slice(0, -3);
511
- tokenFamilyPrefixes.add(family);
512
- } else {
513
- // Specific currency/token ID
514
- allowedCurrencyIds.add(id);
515
- }
516
- }
517
-
518
- // 4. Filter accounts based on effective currency IDs
519
- const wapiAccounts = accounts.reduce<WalletAPIAccount[]>((acc, account) => {
520
- const parentAccount = getParentAccount(account, accounts);
521
- const accountCurrencyId =
522
- account.type === "TokenAccount" ? account.token.id : account.currency.id;
523
- const parentCurrencyId =
524
- account.type === "TokenAccount" ? account.token.parentCurrency.id : account.currency.id;
525
-
526
- // Check if account currency ID matches the effective patterns
527
- const isAllowed =
528
- includeAllCurrencies ||
529
- allowedCurrencyIds.has(accountCurrencyId) ||
530
- tokenFamilyPrefixes.has(parentCurrencyId);
531
-
532
- if (isAllowed) {
533
- acc.push(accountToWalletAPIAccount(walletState, account, parentAccount));
534
- }
535
-
536
- return acc;
537
- }, []);
538
-
539
- tracking.accountListSuccess(manifest);
540
- return wapiAccounts;
541
- } catch (err) {
542
- tracking.accountListFail(manifest);
543
- throw err;
544
- }
545
- });
546
- }, [walletState, manifest, server, tracking, uiAccountRequest, accounts]);
547
-
548
365
  useEffect(() => {
549
366
  if (!uiAccountRequest) return;
550
367
 
551
368
  server.setHandler(
552
369
  "account.request",
553
- async ({ currencyIds, drawerConfiguration, areCurrenciesFiltered, useCase }) => {
370
+ async ({ accounts$, currencies$, drawerConfiguration, areCurrenciesFiltered, useCase }) => {
554
371
  tracking.requestAccountRequested(manifest);
372
+ const currencies = await firstValueFrom(currencies$);
373
+
555
374
  return new Promise((resolve, reject) => {
556
- let done = false;
557
- try {
558
- uiAccountRequest({
559
- currencyIds,
560
- drawerConfiguration,
561
- areCurrenciesFiltered,
562
- useCase,
563
- onSuccess: (account: AccountLike, parentAccount: Account | undefined) => {
564
- if (done) return;
565
- done = true;
566
- tracking.requestAccountSuccess(manifest);
567
- resolve(accountToWalletAPIAccount(walletState, account, parentAccount));
568
- },
569
- onCancel: () => {
570
- if (done) return;
571
- done = true;
572
- tracking.requestAccountFail(manifest);
573
- reject(new Error("Canceled by user"));
574
- },
575
- });
576
- } catch (error) {
577
- tracking.requestAccountFail(manifest);
578
- reject(error);
579
- }
375
+ (async () => {
376
+ try {
377
+ // handle no curencies selected case
378
+ const currencyList: CryptoOrTokenCurrency[] = [];
379
+ for (const { id } of currencies) {
380
+ const currency =
381
+ findCryptoCurrencyById(id) || (await getCryptoAssetsStore().findTokenById(id));
382
+ if (currency) {
383
+ currencyList.push(currency);
384
+ }
385
+ }
386
+
387
+ let done = false;
388
+ uiAccountRequest({
389
+ accounts$,
390
+ currencies: currencyList,
391
+ drawerConfiguration,
392
+ areCurrenciesFiltered,
393
+ useCase,
394
+ onSuccess: (account: AccountLike, parentAccount: Account | undefined) => {
395
+ if (done) return;
396
+ done = true;
397
+ tracking.requestAccountSuccess(manifest);
398
+ resolve(accountToWalletAPIAccount(walletState, account, parentAccount));
399
+ },
400
+ onCancel: () => {
401
+ if (done) return;
402
+ done = true;
403
+ tracking.requestAccountFail(manifest);
404
+ reject(new Error("Canceled by user"));
405
+ },
406
+ });
407
+ } catch (error) {
408
+ reject(error);
409
+ }
410
+ })();
580
411
  });
581
412
  },
582
413
  );
@@ -585,11 +416,11 @@ export function useWalletAPIServer({
585
416
  useEffect(() => {
586
417
  if (!uiAccountReceive) return;
587
418
 
588
- server.setHandler("account.receive", ({ accountId, tokenCurrency }) =>
419
+ server.setHandler("account.receive", ({ account, tokenCurrency }) =>
589
420
  receiveOnAccountLogic(
590
421
  walletState,
591
422
  { manifest, accounts, tracking },
592
- accountId,
423
+ account.id,
593
424
  (account, parentAccount, accountAddress) =>
594
425
  new Promise((resolve, reject) => {
595
426
  let done = false;
@@ -625,10 +456,10 @@ export function useWalletAPIServer({
625
456
  useEffect(() => {
626
457
  if (!uiMessageSign) return;
627
458
 
628
- server.setHandler("message.sign", ({ accountId, message, options }) =>
459
+ server.setHandler("message.sign", ({ account, message, options }) =>
629
460
  signMessageLogic(
630
461
  { manifest, accounts, tracking },
631
- accountId,
462
+ account.id,
632
463
  message.toString("hex"),
633
464
  (account: AccountLike, message: AnyMessage) =>
634
465
  new Promise((resolve, reject) => {
@@ -682,18 +513,13 @@ export function useWalletAPIServer({
682
513
 
683
514
  server.setHandler(
684
515
  "transaction.sign",
685
- async ({ accountId, tokenCurrency, transaction, options }) => {
686
- let currency: string | undefined;
516
+ async ({ account, tokenCurrency, transaction, options }) => {
687
517
  const signedOperation = await signTransactionLogic(
688
518
  { manifest, accounts, tracking },
689
- accountId,
519
+ account.id,
690
520
  transaction,
691
- (account, parentAccount, signFlowInfos) => {
692
- currency =
693
- account.type === "TokenAccount"
694
- ? account.token.parentCurrency.id
695
- : account.currency.id;
696
- return new Promise((resolve, reject) => {
521
+ (account, parentAccount, signFlowInfos) =>
522
+ new Promise((resolve, reject) => {
697
523
  let done = false;
698
524
  return uiTxSign({
699
525
  account,
@@ -713,12 +539,11 @@ export function useWalletAPIServer({
713
539
  reject(error);
714
540
  },
715
541
  });
716
- });
717
- },
542
+ }),
718
543
  tokenCurrency,
719
544
  );
720
545
 
721
- return currency === "solana"
546
+ return account.currency === "solana"
722
547
  ? Buffer.from(signedOperation.signature, "hex")
723
548
  : Buffer.from(signedOperation.signature);
724
549
  },
@@ -730,10 +555,10 @@ export function useWalletAPIServer({
730
555
 
731
556
  server.setHandler(
732
557
  "transaction.signRaw",
733
- async ({ accountId, transaction, broadcast, options }) => {
558
+ async ({ account, transaction, broadcast, options }) => {
734
559
  const signedOperation = await signRawTransactionLogic(
735
560
  { manifest, accounts, tracking },
736
- accountId,
561
+ account.id,
737
562
  transaction,
738
563
  (account, parentAccount, tx) =>
739
564
  new Promise((resolve, reject) => {
@@ -763,7 +588,7 @@ export function useWalletAPIServer({
763
588
  if (broadcast) {
764
589
  hash = await broadcastTransactionLogic(
765
590
  { manifest, accounts, tracking },
766
- accountId,
591
+ account.id,
767
592
  signedOperation,
768
593
  async (account, parentAccount, signedOperation) => {
769
594
  const bridge = getAccountBridge(account, parentAccount);
@@ -806,12 +631,12 @@ export function useWalletAPIServer({
806
631
 
807
632
  server.setHandler(
808
633
  "transaction.signAndBroadcast",
809
- async ({ accountId, tokenCurrency, transaction, options }) => {
634
+ async ({ account, tokenCurrency, transaction, options }) => {
810
635
  const sponsored = transaction.family === "ethereum" && transaction.sponsored;
811
636
 
812
637
  const signedTransaction = await signTransactionLogic(
813
638
  { manifest, accounts, tracking },
814
- accountId,
639
+ account.id,
815
640
  transaction,
816
641
  (account, parentAccount, signFlowInfos) =>
817
642
  new Promise((resolve, reject) => {
@@ -840,7 +665,7 @@ export function useWalletAPIServer({
840
665
 
841
666
  return broadcastTransactionLogic(
842
667
  { manifest, accounts, tracking },
843
- accountId,
668
+ account.id,
844
669
  signedTransaction,
845
670
  async (account, parentAccount, signedOperation) => {
846
671
  const bridge = getAccountBridge(account, parentAccount);
@@ -1104,8 +929,8 @@ export function useWalletAPIServer({
1104
929
  // retrofit of the exchange params to fit the old platform spec
1105
930
  const request: CompleteExchangeRequest = {
1106
931
  provider: params.provider,
1107
- fromAccountId: params.fromAccountId,
1108
- toAccountId: params.exchangeType === "SWAP" ? params.toAccountId : undefined,
932
+ fromAccountId: params.fromAccount.id,
933
+ toAccountId: params.exchangeType === "SWAP" ? params.toAccount.id : undefined,
1109
934
  transaction: params.transaction,
1110
935
  binaryPayload: params.binaryPayload.toString("hex"),
1111
936
  signature: params.signature.toString("hex"),
@@ -1143,7 +968,7 @@ export function useWalletAPIServer({
1143
968
  }, [uiExchangeComplete, accounts, manifest, server, tracking]);
1144
969
 
1145
970
  return {
1146
- widgetLoaded: widgetLoaded,
971
+ widgetLoaded,
1147
972
  onMessage,
1148
973
  onLoad,
1149
974
  onReload,
@@ -1346,9 +1171,9 @@ export function useRecentlyUsed(
1346
1171
  ...res,
1347
1172
  usedAt: calculateTimeDiff(recentlyUsed.usedAt),
1348
1173
  }
1349
- : undefined;
1174
+ : res;
1350
1175
  })
1351
- .filter((manifest): manifest is RecentlyUsedManifest => manifest !== undefined),
1176
+ .filter(manifest => manifest !== undefined) as RecentlyUsedManifest[],
1352
1177
  [recentlyUsedManifestsDb, manifests],
1353
1178
  );
1354
1179
  const append = useCallback(
@@ -241,28 +241,6 @@ export default function trackingWrapper(trackCall: TrackWalletAPI) {
241
241
  track("WalletAPI bitcoin family account xpub success", getEventData(manifest));
242
242
  },
243
243
 
244
- // currency.list handler tracking
245
- currencyListRequested: (manifest: AppManifest) => {
246
- track("WalletAPI CurrencyList requested", getEventData(manifest));
247
- },
248
- currencyListSuccess: (manifest: AppManifest) => {
249
- track("WalletAPI CurrencyList success", getEventData(manifest));
250
- },
251
- currencyListFail: (manifest: AppManifest) => {
252
- track("WalletAPI CurrencyList fail", getEventData(manifest));
253
- },
254
-
255
- // account.list handler tracking
256
- accountListRequested: (manifest: AppManifest) => {
257
- track("WalletAPI AccountList requested", getEventData(manifest));
258
- },
259
- accountListSuccess: (manifest: AppManifest) => {
260
- track("WalletAPI AccountList success", getEventData(manifest));
261
- },
262
- accountListFail: (manifest: AppManifest) => {
263
- track("WalletAPI AccountList fail", getEventData(manifest));
264
- },
265
-
266
244
  dappSendTransactionRequested: (manifest: AppManifest, trackingData: DAppTrackingData) => {
267
245
  track("dApp SendTransaction requested", { ...getEventData(manifest), ...trackingData });
268
246
  },
@@ -83,8 +83,3 @@ export type DAppTrackingData = {
83
83
  currency: string;
84
84
  network: CryptoCurrency["id"];
85
85
  };
86
-
87
- export type AccountIdFormat = "uuid" | "encoded";
88
-
89
- /** @developer note uuid = wallet API id format, encoded = ledger wallet default format */
90
- export type AccountIdFormatsResponse = Record<string, AccountIdFormat>;