@ledgerhq/live-common 34.50.0 → 34.51.0-nightly.1

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 (710) hide show
  1. package/lib/__tests__/test-helpers/bridge.js +1 -1
  2. package/lib/__tests__/test-helpers/bridge.js.map +1 -1
  3. package/lib/__tests__/test-helpers/environment.js +1 -1
  4. package/lib/__tests__/test-helpers/environment.js.map +1 -1
  5. package/lib/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
  6. package/lib/bridge/generic-alpaca/alpaca/index.js +3 -0
  7. package/lib/bridge/generic-alpaca/alpaca/index.js.map +1 -1
  8. package/lib/bridge/generic-alpaca/buildSubAccounts.d.ts +4 -4
  9. package/lib/bridge/generic-alpaca/buildSubAccounts.d.ts.map +1 -1
  10. package/lib/bridge/generic-alpaca/buildSubAccounts.js +7 -9
  11. package/lib/bridge/generic-alpaca/buildSubAccounts.js.map +1 -1
  12. package/lib/bridge/generic-alpaca/createTransaction.d.ts.map +1 -1
  13. package/lib/bridge/generic-alpaca/createTransaction.js +11 -0
  14. package/lib/bridge/generic-alpaca/createTransaction.js.map +1 -1
  15. package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  16. package/lib/bridge/generic-alpaca/getAccountShape.js +15 -9
  17. package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  18. package/lib/bridge/generic-alpaca/getTransactionStatus.js +1 -1
  19. package/lib/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  20. package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  21. package/lib/bridge/generic-alpaca/prepareTransaction.js +29 -4
  22. package/lib/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  23. package/lib/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
  24. package/lib/bridge/generic-alpaca/signer/index.js +37 -0
  25. package/lib/bridge/generic-alpaca/signer/index.js.map +1 -1
  26. package/lib/bridge/generic-alpaca/signer/signTransaction.d.ts +2 -0
  27. package/lib/bridge/generic-alpaca/signer/signTransaction.d.ts.map +1 -1
  28. package/lib/bridge/generic-alpaca/signer/signTransaction.js +8 -1
  29. package/lib/bridge/generic-alpaca/signer/signTransaction.js.map +1 -1
  30. package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js +15 -1
  31. package/lib/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js.map +1 -1
  32. package/lib/bridge/generic-alpaca/tests/getAccountShape.test.js +5 -3
  33. package/lib/bridge/generic-alpaca/tests/getAccountShape.test.js.map +1 -1
  34. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js +60 -0
  35. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  36. package/lib/bridge/generic-alpaca/tests/signOperation.test.js +1 -1
  37. package/lib/bridge/generic-alpaca/tests/signOperation.test.js.map +1 -1
  38. package/lib/bridge/generic-alpaca/types.d.ts +1 -2
  39. package/lib/bridge/generic-alpaca/types.d.ts.map +1 -1
  40. package/lib/bridge/generic-alpaca/utils.d.ts +2 -2
  41. package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
  42. package/lib/bridge/generic-alpaca/utils.js +23 -4
  43. package/lib/bridge/generic-alpaca/utils.js.map +1 -1
  44. package/lib/bridge/impl.d.ts.map +1 -1
  45. package/lib/bridge/impl.js +1 -0
  46. package/lib/bridge/impl.js.map +1 -1
  47. package/lib/dada-client/entities/index.d.ts.map +1 -0
  48. package/lib/dada-client/entities/index.js.map +1 -0
  49. package/lib/{modularDrawer/data → dada-client}/entities/interestRateSelectors.d.ts +1 -1
  50. package/lib/dada-client/entities/interestRateSelectors.d.ts.map +1 -0
  51. package/lib/dada-client/entities/interestRateSelectors.js.map +1 -0
  52. package/lib/{modularDrawer/data → dada-client}/entities/marketSelectors.d.ts +1 -1
  53. package/lib/dada-client/entities/marketSelectors.d.ts.map +1 -0
  54. package/lib/dada-client/entities/marketSelectors.js.map +1 -0
  55. package/lib/dada-client/entities/selectorUtils.d.ts.map +1 -0
  56. package/lib/dada-client/entities/selectorUtils.js.map +1 -0
  57. package/lib/dada-client/hooks/__tests__/useAssetsData.test.d.ts.map +1 -0
  58. package/lib/{modularDrawer/hooks/__test__ → dada-client/hooks/__tests__}/useAssetsData.test.js +2 -2
  59. package/lib/dada-client/hooks/__tests__/useAssetsData.test.js.map +1 -0
  60. package/lib/dada-client/hooks/useAssetData.d.ts +10 -0
  61. package/lib/dada-client/hooks/useAssetData.d.ts.map +1 -0
  62. package/lib/dada-client/hooks/useAssetData.js +23 -0
  63. package/lib/dada-client/hooks/useAssetData.js.map +1 -0
  64. package/lib/dada-client/hooks/useAssetsData.d.ts +19 -0
  65. package/lib/dada-client/hooks/useAssetsData.d.ts.map +1 -0
  66. package/lib/{modularDrawer → dada-client}/hooks/useAssetsData.js +1 -1
  67. package/lib/dada-client/hooks/useAssetsData.js.map +1 -0
  68. package/lib/dada-client/hooks/useInterestRatesByCurrencies.d.ts.map +1 -0
  69. package/lib/{modularDrawer → dada-client}/hooks/useInterestRatesByCurrencies.js +3 -3
  70. package/lib/dada-client/hooks/useInterestRatesByCurrencies.js.map +1 -0
  71. package/lib/dada-client/hooks/useMarketByCurrencies.d.ts.map +1 -0
  72. package/lib/{modularDrawer → dada-client}/hooks/useMarketByCurrencies.js +5 -6
  73. package/lib/dada-client/hooks/useMarketByCurrencies.js.map +1 -0
  74. package/lib/{modularDrawer/data → dada-client}/state-manager/api.d.ts +134 -1
  75. package/lib/{modularDrawer/data → dada-client}/state-manager/api.d.ts.map +1 -1
  76. package/lib/{modularDrawer/data → dada-client}/state-manager/api.js +21 -2
  77. package/lib/dada-client/state-manager/api.js.map +1 -0
  78. package/lib/dada-client/state-manager/types.d.ts.map +1 -0
  79. package/lib/dada-client/state-manager/types.js.map +1 -0
  80. package/lib/dada-client/types/trend.d.ts +2 -0
  81. package/lib/dada-client/types/trend.d.ts.map +1 -0
  82. package/lib/dada-client/types/trend.js +3 -0
  83. package/lib/dada-client/types/trend.js.map +1 -0
  84. package/lib/deposit/useGroupedCurrenciesByProvider.hook.d.ts.map +1 -1
  85. package/lib/deposit/useGroupedCurrenciesByProvider.hook.js +6 -1
  86. package/lib/deposit/useGroupedCurrenciesByProvider.hook.js.map +1 -1
  87. package/lib/e2e/enum/Account.d.ts +2 -0
  88. package/lib/e2e/enum/Account.d.ts.map +1 -1
  89. package/lib/e2e/enum/Account.js +4 -0
  90. package/lib/e2e/enum/Account.js.map +1 -1
  91. package/lib/e2e/enum/AppInfos.d.ts +1 -0
  92. package/lib/e2e/enum/AppInfos.d.ts.map +1 -1
  93. package/lib/e2e/enum/AppInfos.js +1 -0
  94. package/lib/e2e/enum/AppInfos.js.map +1 -1
  95. package/lib/e2e/enum/Currency.d.ts +2 -0
  96. package/lib/e2e/enum/Currency.d.ts.map +1 -1
  97. package/lib/e2e/enum/Currency.js +4 -0
  98. package/lib/e2e/enum/Currency.js.map +1 -1
  99. package/lib/e2e/enum/Network.d.ts +2 -1
  100. package/lib/e2e/enum/Network.d.ts.map +1 -1
  101. package/lib/e2e/enum/Network.js +1 -0
  102. package/lib/e2e/enum/Network.js.map +1 -1
  103. package/lib/e2e/enum/Provider.d.ts +1 -0
  104. package/lib/e2e/enum/Provider.d.ts.map +1 -1
  105. package/lib/e2e/enum/Provider.js +1 -0
  106. package/lib/e2e/enum/Provider.js.map +1 -1
  107. package/lib/e2e/families/hedera.d.ts +2 -0
  108. package/lib/e2e/families/hedera.d.ts.map +1 -0
  109. package/lib/e2e/families/hedera.js +11 -0
  110. package/lib/e2e/families/hedera.js.map +1 -0
  111. package/lib/e2e/speculos.d.ts.map +1 -1
  112. package/lib/e2e/speculos.js +12 -0
  113. package/lib/e2e/speculos.js.map +1 -1
  114. package/lib/e2e/swap.d.ts +1 -1
  115. package/lib/e2e/swap.d.ts.map +1 -1
  116. package/lib/e2e/swap.js +6 -5
  117. package/lib/e2e/swap.js.map +1 -1
  118. package/lib/exchange/platform/types.d.ts +2 -0
  119. package/lib/exchange/platform/types.d.ts.map +1 -1
  120. package/lib/exchange/swap/completeExchange.d.ts.map +1 -1
  121. package/lib/exchange/swap/completeExchange.js +22 -1
  122. package/lib/exchange/swap/completeExchange.js.map +1 -1
  123. package/lib/exchange/swap/getIncompatibleCurrencyKeys.d.ts.map +1 -1
  124. package/lib/exchange/swap/getIncompatibleCurrencyKeys.js +8 -0
  125. package/lib/exchange/swap/getIncompatibleCurrencyKeys.js.map +1 -1
  126. package/lib/exchange/swap/postSwapState.d.ts.map +1 -1
  127. package/lib/exchange/swap/postSwapState.js +19 -23
  128. package/lib/exchange/swap/postSwapState.js.map +1 -1
  129. package/lib/exchange/swap/setBroadcastTransaction.d.ts +4 -4
  130. package/lib/exchange/swap/setBroadcastTransaction.js +7 -7
  131. package/lib/exchange/swap/setBroadcastTransaction.js.map +1 -1
  132. package/lib/exchange/swap/types.d.ts +3 -3
  133. package/lib/exchange/swap/types.d.ts.map +1 -1
  134. package/lib/exchange/swap/updateAccountSwapStatus.d.ts.map +1 -1
  135. package/lib/exchange/swap/updateAccountSwapStatus.js +6 -4
  136. package/lib/exchange/swap/updateAccountSwapStatus.js.map +1 -1
  137. package/lib/families/canton/config.js +10 -10
  138. package/lib/families/canton/config.js.map +1 -1
  139. package/lib/families/evm/shouldUseReceiveOptions.d.ts +3 -0
  140. package/lib/families/evm/shouldUseReceiveOptions.d.ts.map +1 -0
  141. package/lib/families/evm/shouldUseReceiveOptions.js +5 -0
  142. package/lib/families/evm/shouldUseReceiveOptions.js.map +1 -0
  143. package/lib/families/evm/shouldUseReceiveOptions.test.d.ts +2 -0
  144. package/lib/families/evm/shouldUseReceiveOptions.test.d.ts.map +1 -0
  145. package/lib/families/evm/shouldUseReceiveOptions.test.js +26 -0
  146. package/lib/families/evm/shouldUseReceiveOptions.test.js.map +1 -0
  147. package/lib/families/hedera/exchange.d.ts +9 -0
  148. package/lib/families/hedera/exchange.d.ts.map +1 -0
  149. package/lib/families/hedera/exchange.js +36 -0
  150. package/lib/families/hedera/exchange.js.map +1 -0
  151. package/lib/families/tezos/config.js +2 -2
  152. package/lib/families/tezos/react.d.ts +2 -1
  153. package/lib/families/tezos/react.d.ts.map +1 -1
  154. package/lib/families/tezos/react.js +19 -1
  155. package/lib/families/tezos/react.js.map +1 -1
  156. package/lib/families/tezos/setup.d.ts +1 -4
  157. package/lib/families/tezos/setup.d.ts.map +1 -1
  158. package/lib/families/tezos/setup.js +3 -11
  159. package/lib/families/tezos/setup.js.map +1 -1
  160. package/lib/generated/bridge/js.d.ts +0 -1
  161. package/lib/generated/bridge/js.d.ts.map +1 -1
  162. package/lib/generated/bridge/js.js +10 -12
  163. package/lib/generated/bridge/js.js.map +1 -1
  164. package/lib/hw/actions/completeExchange.d.ts +2 -0
  165. package/lib/hw/actions/completeExchange.d.ts.map +1 -1
  166. package/lib/hw/actions/completeExchange.js +1 -0
  167. package/lib/hw/actions/completeExchange.js.map +1 -1
  168. package/lib/hw/signMessage/index.d.ts.map +1 -1
  169. package/lib/hw/signMessage/index.js +7 -0
  170. package/lib/hw/signMessage/index.js.map +1 -1
  171. package/lib/modularDrawer/hooks/modules/useLeftApyModule.d.ts +1 -1
  172. package/lib/modularDrawer/hooks/modules/useLeftApyModule.d.ts.map +1 -1
  173. package/lib/modularDrawer/hooks/modules/useLeftApyModule.js +1 -1
  174. package/lib/modularDrawer/hooks/modules/useLeftApyModule.js.map +1 -1
  175. package/lib/modularDrawer/hooks/modules/useLeftMarketTrendModule.js +1 -1
  176. package/lib/modularDrawer/hooks/modules/useLeftMarketTrendModule.js.map +1 -1
  177. package/lib/modularDrawer/hooks/modules/useRightMarketTrendModule.js +6 -3
  178. package/lib/modularDrawer/hooks/modules/useRightMarketTrendModule.js.map +1 -1
  179. package/lib/modularDrawer/hooks/useAssetAccountCounts.d.ts.map +1 -1
  180. package/lib/modularDrawer/hooks/useAssetAccountCounts.js +2 -4
  181. package/lib/modularDrawer/hooks/useAssetAccountCounts.js.map +1 -1
  182. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts +7 -0
  183. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -0
  184. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +224 -0
  185. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -0
  186. package/lib/modularDrawer/hooks/useLeftAccountsApy.js +1 -1
  187. package/lib/modularDrawer/hooks/useLeftAccountsApy.js.map +1 -1
  188. package/lib/modularDrawer/hooks/useRightBalanceAsset.d.ts +8 -10
  189. package/lib/modularDrawer/hooks/useRightBalanceAsset.d.ts.map +1 -1
  190. package/lib/modularDrawer/hooks/useRightBalanceAsset.js +21 -64
  191. package/lib/modularDrawer/hooks/useRightBalanceAsset.js.map +1 -1
  192. package/lib/modularDrawer/hooks/useRightBalanceNetwork.d.ts +7 -28
  193. package/lib/modularDrawer/hooks/useRightBalanceNetwork.d.ts.map +1 -1
  194. package/lib/modularDrawer/hooks/useRightBalanceNetwork.js +12 -56
  195. package/lib/modularDrawer/hooks/useRightBalanceNetwork.js.map +1 -1
  196. package/lib/modularDrawer/modules/createAssetConfiguration.d.ts.map +1 -1
  197. package/lib/modularDrawer/modules/createAssetConfiguration.js +2 -2
  198. package/lib/modularDrawer/modules/createAssetConfiguration.js.map +1 -1
  199. package/lib/modularDrawer/modules/createNetworkConfiguration.d.ts +1 -1
  200. package/lib/modularDrawer/modules/createNetworkConfiguration.d.ts.map +1 -1
  201. package/lib/modularDrawer/modules/createNetworkConfiguration.js +15 -4
  202. package/lib/modularDrawer/modules/createNetworkConfiguration.js.map +1 -1
  203. package/lib/modularDrawer/utils/__tests__/calculateProviderTotal.test.d.ts +2 -0
  204. package/lib/modularDrawer/utils/__tests__/calculateProviderTotal.test.d.ts.map +1 -0
  205. package/lib/modularDrawer/utils/__tests__/calculateProviderTotal.test.js +212 -0
  206. package/lib/modularDrawer/utils/__tests__/calculateProviderTotal.test.js.map +1 -0
  207. package/lib/modularDrawer/utils/__tests__/groupAccountsByAsset.test.d.ts +2 -0
  208. package/lib/modularDrawer/utils/__tests__/groupAccountsByAsset.test.d.ts.map +1 -0
  209. package/lib/modularDrawer/utils/__tests__/groupAccountsByAsset.test.js +202 -0
  210. package/lib/modularDrawer/utils/__tests__/groupAccountsByAsset.test.js.map +1 -0
  211. package/lib/modularDrawer/utils/calculateProviderTotal.d.ts +1 -0
  212. package/lib/modularDrawer/utils/calculateProviderTotal.d.ts.map +1 -1
  213. package/lib/modularDrawer/utils/calculateProviderTotal.js +10 -2
  214. package/lib/modularDrawer/utils/calculateProviderTotal.js.map +1 -1
  215. package/lib/modularDrawer/utils/currencyUtils.d.ts.map +1 -1
  216. package/lib/modularDrawer/utils/currencyUtils.js.map +1 -1
  217. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +6 -4
  218. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -1
  219. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +9 -22
  220. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -1
  221. package/lib/modularDrawer/utils/getInterestRateForAsset.d.ts +1 -1
  222. package/lib/modularDrawer/utils/getInterestRateForAsset.d.ts.map +1 -1
  223. package/lib/modularDrawer/utils/groupAccountsByAsset.d.ts +4 -3
  224. package/lib/modularDrawer/utils/groupAccountsByAsset.d.ts.map +1 -1
  225. package/lib/modularDrawer/utils/groupAccountsByAsset.js +27 -11
  226. package/lib/modularDrawer/utils/groupAccountsByAsset.js.map +1 -1
  227. package/lib/modularDrawer/utils/index.d.ts +2 -6
  228. package/lib/modularDrawer/utils/index.d.ts.map +1 -1
  229. package/lib/modularDrawer/utils/index.js +2 -13
  230. package/lib/modularDrawer/utils/index.js.map +1 -1
  231. package/lib/modularDrawer/utils/index.test.js +0 -26
  232. package/lib/modularDrawer/utils/index.test.js.map +1 -1
  233. package/lib/modularDrawer/utils/sortByBalance.d.ts +1 -3
  234. package/lib/modularDrawer/utils/sortByBalance.d.ts.map +1 -1
  235. package/lib/modularDrawer/utils/sortByBalance.js +6 -18
  236. package/lib/modularDrawer/utils/sortByBalance.js.map +1 -1
  237. package/lib/modularDrawer/utils/type.d.ts +15 -17
  238. package/lib/modularDrawer/utils/type.d.ts.map +1 -1
  239. package/lib/wallet-api/CustomDeeplink/server.d.ts +16 -0
  240. package/lib/wallet-api/CustomDeeplink/server.d.ts.map +1 -0
  241. package/lib/wallet-api/CustomDeeplink/server.js +10 -0
  242. package/lib/wallet-api/CustomDeeplink/server.js.map +1 -0
  243. package/lib/wallet-api/Exchange/server.js +6 -6
  244. package/lib/wallet-api/Exchange/server.js.map +1 -1
  245. package/lib/wallet-api/constants.d.ts +1 -1
  246. package/lib/wallet-api/constants.d.ts.map +1 -1
  247. package/lib-es/__tests__/test-helpers/bridge.js +1 -1
  248. package/lib-es/__tests__/test-helpers/bridge.js.map +1 -1
  249. package/lib-es/__tests__/test-helpers/environment.js +1 -1
  250. package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
  251. package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
  252. package/lib-es/bridge/generic-alpaca/alpaca/index.js +3 -0
  253. package/lib-es/bridge/generic-alpaca/alpaca/index.js.map +1 -1
  254. package/lib-es/bridge/generic-alpaca/buildSubAccounts.d.ts +4 -4
  255. package/lib-es/bridge/generic-alpaca/buildSubAccounts.d.ts.map +1 -1
  256. package/lib-es/bridge/generic-alpaca/buildSubAccounts.js +7 -9
  257. package/lib-es/bridge/generic-alpaca/buildSubAccounts.js.map +1 -1
  258. package/lib-es/bridge/generic-alpaca/createTransaction.d.ts.map +1 -1
  259. package/lib-es/bridge/generic-alpaca/createTransaction.js +11 -0
  260. package/lib-es/bridge/generic-alpaca/createTransaction.js.map +1 -1
  261. package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  262. package/lib-es/bridge/generic-alpaca/getAccountShape.js +15 -9
  263. package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  264. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js +1 -1
  265. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  266. package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  267. package/lib-es/bridge/generic-alpaca/prepareTransaction.js +29 -4
  268. package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  269. package/lib-es/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
  270. package/lib-es/bridge/generic-alpaca/signer/index.js +38 -1
  271. package/lib-es/bridge/generic-alpaca/signer/index.js.map +1 -1
  272. package/lib-es/bridge/generic-alpaca/signer/signTransaction.d.ts +2 -0
  273. package/lib-es/bridge/generic-alpaca/signer/signTransaction.d.ts.map +1 -1
  274. package/lib-es/bridge/generic-alpaca/signer/signTransaction.js +6 -0
  275. package/lib-es/bridge/generic-alpaca/signer/signTransaction.js.map +1 -1
  276. package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js +15 -1
  277. package/lib-es/bridge/generic-alpaca/tests/estimateMaxSpendable.test.js.map +1 -1
  278. package/lib-es/bridge/generic-alpaca/tests/getAccountShape.test.js +5 -3
  279. package/lib-es/bridge/generic-alpaca/tests/getAccountShape.test.js.map +1 -1
  280. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js +60 -0
  281. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  282. package/lib-es/bridge/generic-alpaca/tests/signOperation.test.js +1 -1
  283. package/lib-es/bridge/generic-alpaca/tests/signOperation.test.js.map +1 -1
  284. package/lib-es/bridge/generic-alpaca/types.d.ts +1 -2
  285. package/lib-es/bridge/generic-alpaca/types.d.ts.map +1 -1
  286. package/lib-es/bridge/generic-alpaca/utils.d.ts +2 -2
  287. package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
  288. package/lib-es/bridge/generic-alpaca/utils.js +23 -4
  289. package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
  290. package/lib-es/bridge/impl.d.ts.map +1 -1
  291. package/lib-es/bridge/impl.js +1 -0
  292. package/lib-es/bridge/impl.js.map +1 -1
  293. package/lib-es/dada-client/entities/index.d.ts.map +1 -0
  294. package/lib-es/dada-client/entities/index.js.map +1 -0
  295. package/lib-es/{modularDrawer/data → dada-client}/entities/interestRateSelectors.d.ts +1 -1
  296. package/lib-es/dada-client/entities/interestRateSelectors.d.ts.map +1 -0
  297. package/lib-es/dada-client/entities/interestRateSelectors.js.map +1 -0
  298. package/lib-es/{modularDrawer/data → dada-client}/entities/marketSelectors.d.ts +1 -1
  299. package/lib-es/dada-client/entities/marketSelectors.d.ts.map +1 -0
  300. package/lib-es/dada-client/entities/marketSelectors.js.map +1 -0
  301. package/lib-es/dada-client/entities/selectorUtils.d.ts.map +1 -0
  302. package/lib-es/dada-client/entities/selectorUtils.js.map +1 -0
  303. package/lib-es/dada-client/hooks/__tests__/useAssetsData.test.d.ts.map +1 -0
  304. package/lib-es/{modularDrawer/hooks/__test__ → dada-client/hooks/__tests__}/useAssetsData.test.js +2 -2
  305. package/lib-es/dada-client/hooks/__tests__/useAssetsData.test.js.map +1 -0
  306. package/lib-es/dada-client/hooks/useAssetData.d.ts +10 -0
  307. package/lib-es/dada-client/hooks/useAssetData.d.ts.map +1 -0
  308. package/lib-es/dada-client/hooks/useAssetData.js +19 -0
  309. package/lib-es/dada-client/hooks/useAssetData.js.map +1 -0
  310. package/lib-es/dada-client/hooks/useAssetsData.d.ts +19 -0
  311. package/lib-es/dada-client/hooks/useAssetsData.d.ts.map +1 -0
  312. package/lib-es/{modularDrawer → dada-client}/hooks/useAssetsData.js +1 -1
  313. package/lib-es/dada-client/hooks/useAssetsData.js.map +1 -0
  314. package/lib-es/dada-client/hooks/useInterestRatesByCurrencies.d.ts.map +1 -0
  315. package/lib-es/{modularDrawer → dada-client}/hooks/useInterestRatesByCurrencies.js +3 -3
  316. package/lib-es/dada-client/hooks/useInterestRatesByCurrencies.js.map +1 -0
  317. package/lib-es/dada-client/hooks/useMarketByCurrencies.d.ts.map +1 -0
  318. package/lib-es/{modularDrawer → dada-client}/hooks/useMarketByCurrencies.js +5 -6
  319. package/lib-es/dada-client/hooks/useMarketByCurrencies.js.map +1 -0
  320. package/lib-es/{modularDrawer/data → dada-client}/state-manager/api.d.ts +134 -1
  321. package/lib-es/{modularDrawer/data → dada-client}/state-manager/api.d.ts.map +1 -1
  322. package/lib-es/{modularDrawer/data → dada-client}/state-manager/api.js +20 -1
  323. package/lib-es/dada-client/state-manager/api.js.map +1 -0
  324. package/lib-es/dada-client/state-manager/types.d.ts.map +1 -0
  325. package/lib-es/dada-client/state-manager/types.js.map +1 -0
  326. package/lib-es/dada-client/types/trend.d.ts +2 -0
  327. package/lib-es/dada-client/types/trend.d.ts.map +1 -0
  328. package/lib-es/dada-client/types/trend.js +2 -0
  329. package/lib-es/dada-client/types/trend.js.map +1 -0
  330. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.d.ts.map +1 -1
  331. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.js +6 -1
  332. package/lib-es/deposit/useGroupedCurrenciesByProvider.hook.js.map +1 -1
  333. package/lib-es/e2e/enum/Account.d.ts +2 -0
  334. package/lib-es/e2e/enum/Account.d.ts.map +1 -1
  335. package/lib-es/e2e/enum/Account.js +4 -0
  336. package/lib-es/e2e/enum/Account.js.map +1 -1
  337. package/lib-es/e2e/enum/AppInfos.d.ts +1 -0
  338. package/lib-es/e2e/enum/AppInfos.d.ts.map +1 -1
  339. package/lib-es/e2e/enum/AppInfos.js +1 -0
  340. package/lib-es/e2e/enum/AppInfos.js.map +1 -1
  341. package/lib-es/e2e/enum/Currency.d.ts +2 -0
  342. package/lib-es/e2e/enum/Currency.d.ts.map +1 -1
  343. package/lib-es/e2e/enum/Currency.js +4 -0
  344. package/lib-es/e2e/enum/Currency.js.map +1 -1
  345. package/lib-es/e2e/enum/Network.d.ts +2 -1
  346. package/lib-es/e2e/enum/Network.d.ts.map +1 -1
  347. package/lib-es/e2e/enum/Network.js +1 -0
  348. package/lib-es/e2e/enum/Network.js.map +1 -1
  349. package/lib-es/e2e/enum/Provider.d.ts +1 -0
  350. package/lib-es/e2e/enum/Provider.d.ts.map +1 -1
  351. package/lib-es/e2e/enum/Provider.js +1 -0
  352. package/lib-es/e2e/enum/Provider.js.map +1 -1
  353. package/lib-es/e2e/families/hedera.d.ts +2 -0
  354. package/lib-es/e2e/families/hedera.d.ts.map +1 -0
  355. package/lib-es/e2e/families/hedera.js +7 -0
  356. package/lib-es/e2e/families/hedera.js.map +1 -0
  357. package/lib-es/e2e/speculos.d.ts.map +1 -1
  358. package/lib-es/e2e/speculos.js +12 -0
  359. package/lib-es/e2e/speculos.js.map +1 -1
  360. package/lib-es/e2e/swap.d.ts +1 -1
  361. package/lib-es/e2e/swap.d.ts.map +1 -1
  362. package/lib-es/e2e/swap.js +6 -5
  363. package/lib-es/e2e/swap.js.map +1 -1
  364. package/lib-es/exchange/platform/types.d.ts +2 -0
  365. package/lib-es/exchange/platform/types.d.ts.map +1 -1
  366. package/lib-es/exchange/swap/completeExchange.d.ts.map +1 -1
  367. package/lib-es/exchange/swap/completeExchange.js +22 -1
  368. package/lib-es/exchange/swap/completeExchange.js.map +1 -1
  369. package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.d.ts.map +1 -1
  370. package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.js +8 -0
  371. package/lib-es/exchange/swap/getIncompatibleCurrencyKeys.js.map +1 -1
  372. package/lib-es/exchange/swap/postSwapState.d.ts.map +1 -1
  373. package/lib-es/exchange/swap/postSwapState.js +19 -23
  374. package/lib-es/exchange/swap/postSwapState.js.map +1 -1
  375. package/lib-es/exchange/swap/setBroadcastTransaction.d.ts +4 -4
  376. package/lib-es/exchange/swap/setBroadcastTransaction.js +7 -7
  377. package/lib-es/exchange/swap/setBroadcastTransaction.js.map +1 -1
  378. package/lib-es/exchange/swap/types.d.ts +3 -3
  379. package/lib-es/exchange/swap/types.d.ts.map +1 -1
  380. package/lib-es/exchange/swap/updateAccountSwapStatus.d.ts.map +1 -1
  381. package/lib-es/exchange/swap/updateAccountSwapStatus.js +6 -4
  382. package/lib-es/exchange/swap/updateAccountSwapStatus.js.map +1 -1
  383. package/lib-es/families/canton/config.js +10 -10
  384. package/lib-es/families/canton/config.js.map +1 -1
  385. package/lib-es/families/evm/shouldUseReceiveOptions.d.ts +3 -0
  386. package/lib-es/families/evm/shouldUseReceiveOptions.d.ts.map +1 -0
  387. package/lib-es/families/evm/shouldUseReceiveOptions.js +3 -0
  388. package/lib-es/families/evm/shouldUseReceiveOptions.js.map +1 -0
  389. package/lib-es/families/evm/shouldUseReceiveOptions.test.d.ts +2 -0
  390. package/lib-es/families/evm/shouldUseReceiveOptions.test.d.ts.map +1 -0
  391. package/lib-es/families/evm/shouldUseReceiveOptions.test.js +21 -0
  392. package/lib-es/families/evm/shouldUseReceiveOptions.test.js.map +1 -0
  393. package/lib-es/families/hedera/exchange.d.ts +9 -0
  394. package/lib-es/families/hedera/exchange.d.ts.map +1 -0
  395. package/lib-es/families/hedera/exchange.js +29 -0
  396. package/lib-es/families/hedera/exchange.js.map +1 -0
  397. package/lib-es/families/tezos/config.js +2 -2
  398. package/lib-es/families/tezos/react.d.ts +2 -1
  399. package/lib-es/families/tezos/react.d.ts.map +1 -1
  400. package/lib-es/families/tezos/react.js +17 -0
  401. package/lib-es/families/tezos/react.js.map +1 -1
  402. package/lib-es/families/tezos/setup.d.ts +1 -4
  403. package/lib-es/families/tezos/setup.d.ts.map +1 -1
  404. package/lib-es/families/tezos/setup.js +2 -9
  405. package/lib-es/families/tezos/setup.js.map +1 -1
  406. package/lib-es/generated/bridge/js.d.ts +0 -1
  407. package/lib-es/generated/bridge/js.d.ts.map +1 -1
  408. package/lib-es/generated/bridge/js.js +0 -2
  409. package/lib-es/generated/bridge/js.js.map +1 -1
  410. package/lib-es/hw/actions/completeExchange.d.ts +2 -0
  411. package/lib-es/hw/actions/completeExchange.d.ts.map +1 -1
  412. package/lib-es/hw/actions/completeExchange.js +1 -0
  413. package/lib-es/hw/actions/completeExchange.js.map +1 -1
  414. package/lib-es/hw/signMessage/index.d.ts.map +1 -1
  415. package/lib-es/hw/signMessage/index.js +7 -0
  416. package/lib-es/hw/signMessage/index.js.map +1 -1
  417. package/lib-es/modularDrawer/hooks/modules/useLeftApyModule.d.ts +1 -1
  418. package/lib-es/modularDrawer/hooks/modules/useLeftApyModule.d.ts.map +1 -1
  419. package/lib-es/modularDrawer/hooks/modules/useLeftApyModule.js +1 -1
  420. package/lib-es/modularDrawer/hooks/modules/useLeftApyModule.js.map +1 -1
  421. package/lib-es/modularDrawer/hooks/modules/useLeftMarketTrendModule.js +1 -1
  422. package/lib-es/modularDrawer/hooks/modules/useLeftMarketTrendModule.js.map +1 -1
  423. package/lib-es/modularDrawer/hooks/modules/useRightMarketTrendModule.js +2 -2
  424. package/lib-es/modularDrawer/hooks/modules/useRightMarketTrendModule.js.map +1 -1
  425. package/lib-es/modularDrawer/hooks/useAssetAccountCounts.d.ts.map +1 -1
  426. package/lib-es/modularDrawer/hooks/useAssetAccountCounts.js +2 -4
  427. package/lib-es/modularDrawer/hooks/useAssetAccountCounts.js.map +1 -1
  428. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts +7 -0
  429. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -0
  430. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +217 -0
  431. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -0
  432. package/lib-es/modularDrawer/hooks/useLeftAccountsApy.js +1 -1
  433. package/lib-es/modularDrawer/hooks/useLeftAccountsApy.js.map +1 -1
  434. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.d.ts +8 -10
  435. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.d.ts.map +1 -1
  436. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.js +21 -64
  437. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.js.map +1 -1
  438. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.d.ts +7 -28
  439. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.d.ts.map +1 -1
  440. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.js +12 -56
  441. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.js.map +1 -1
  442. package/lib-es/modularDrawer/modules/createAssetConfiguration.d.ts.map +1 -1
  443. package/lib-es/modularDrawer/modules/createAssetConfiguration.js +2 -2
  444. package/lib-es/modularDrawer/modules/createAssetConfiguration.js.map +1 -1
  445. package/lib-es/modularDrawer/modules/createNetworkConfiguration.d.ts +1 -1
  446. package/lib-es/modularDrawer/modules/createNetworkConfiguration.d.ts.map +1 -1
  447. package/lib-es/modularDrawer/modules/createNetworkConfiguration.js +15 -4
  448. package/lib-es/modularDrawer/modules/createNetworkConfiguration.js.map +1 -1
  449. package/lib-es/modularDrawer/utils/__tests__/calculateProviderTotal.test.d.ts +2 -0
  450. package/lib-es/modularDrawer/utils/__tests__/calculateProviderTotal.test.d.ts.map +1 -0
  451. package/lib-es/modularDrawer/utils/__tests__/calculateProviderTotal.test.js +207 -0
  452. package/lib-es/modularDrawer/utils/__tests__/calculateProviderTotal.test.js.map +1 -0
  453. package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js +1 -1
  454. package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js.map +1 -1
  455. package/lib-es/modularDrawer/utils/__tests__/groupAccountsByAsset.test.d.ts +2 -0
  456. package/lib-es/modularDrawer/utils/__tests__/groupAccountsByAsset.test.d.ts.map +1 -0
  457. package/lib-es/modularDrawer/utils/__tests__/groupAccountsByAsset.test.js +197 -0
  458. package/lib-es/modularDrawer/utils/__tests__/groupAccountsByAsset.test.js.map +1 -0
  459. package/lib-es/modularDrawer/utils/calculateProviderTotal.d.ts +1 -0
  460. package/lib-es/modularDrawer/utils/calculateProviderTotal.d.ts.map +1 -1
  461. package/lib-es/modularDrawer/utils/calculateProviderTotal.js +10 -2
  462. package/lib-es/modularDrawer/utils/calculateProviderTotal.js.map +1 -1
  463. package/lib-es/modularDrawer/utils/currencyUtils.d.ts.map +1 -1
  464. package/lib-es/modularDrawer/utils/currencyUtils.js.map +1 -1
  465. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +6 -4
  466. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -1
  467. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +9 -22
  468. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -1
  469. package/lib-es/modularDrawer/utils/getInterestRateForAsset.d.ts +1 -1
  470. package/lib-es/modularDrawer/utils/getInterestRateForAsset.d.ts.map +1 -1
  471. package/lib-es/modularDrawer/utils/groupAccountsByAsset.d.ts +4 -3
  472. package/lib-es/modularDrawer/utils/groupAccountsByAsset.d.ts.map +1 -1
  473. package/lib-es/modularDrawer/utils/groupAccountsByAsset.js +27 -11
  474. package/lib-es/modularDrawer/utils/groupAccountsByAsset.js.map +1 -1
  475. package/lib-es/modularDrawer/utils/index.d.ts +2 -6
  476. package/lib-es/modularDrawer/utils/index.d.ts.map +1 -1
  477. package/lib-es/modularDrawer/utils/index.js +2 -10
  478. package/lib-es/modularDrawer/utils/index.js.map +1 -1
  479. package/lib-es/modularDrawer/utils/index.test.js +1 -27
  480. package/lib-es/modularDrawer/utils/index.test.js.map +1 -1
  481. package/lib-es/modularDrawer/utils/sortByBalance.d.ts +1 -3
  482. package/lib-es/modularDrawer/utils/sortByBalance.d.ts.map +1 -1
  483. package/lib-es/modularDrawer/utils/sortByBalance.js +5 -15
  484. package/lib-es/modularDrawer/utils/sortByBalance.js.map +1 -1
  485. package/lib-es/modularDrawer/utils/type.d.ts +15 -17
  486. package/lib-es/modularDrawer/utils/type.d.ts.map +1 -1
  487. package/lib-es/wallet-api/CustomDeeplink/server.d.ts +16 -0
  488. package/lib-es/wallet-api/CustomDeeplink/server.d.ts.map +1 -0
  489. package/lib-es/wallet-api/CustomDeeplink/server.js +6 -0
  490. package/lib-es/wallet-api/CustomDeeplink/server.js.map +1 -0
  491. package/lib-es/wallet-api/Exchange/server.js +6 -6
  492. package/lib-es/wallet-api/Exchange/server.js.map +1 -1
  493. package/lib-es/wallet-api/constants.d.ts +1 -1
  494. package/lib-es/wallet-api/constants.d.ts.map +1 -1
  495. package/package.json +9 -7
  496. package/src/__tests__/test-helpers/bridge.ts +1 -1
  497. package/src/__tests__/test-helpers/environment.ts +1 -1
  498. package/src/bridge/generic-alpaca/alpaca/index.ts +4 -0
  499. package/src/bridge/generic-alpaca/buildSubAccounts.ts +28 -28
  500. package/src/bridge/generic-alpaca/createTransaction.ts +11 -0
  501. package/src/bridge/generic-alpaca/getAccountShape.ts +22 -15
  502. package/src/bridge/generic-alpaca/getTransactionStatus.ts +1 -1
  503. package/src/bridge/generic-alpaca/prepareTransaction.ts +47 -5
  504. package/src/bridge/generic-alpaca/signer/index.ts +44 -1
  505. package/src/bridge/generic-alpaca/signer/signTransaction.ts +10 -0
  506. package/src/bridge/generic-alpaca/tests/estimateMaxSpendable.test.ts +15 -1
  507. package/src/bridge/generic-alpaca/tests/getAccountShape.test.ts +5 -3
  508. package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +78 -0
  509. package/src/bridge/generic-alpaca/tests/signOperation.test.ts +1 -1
  510. package/src/bridge/generic-alpaca/types.ts +10 -2
  511. package/src/bridge/generic-alpaca/utils.ts +25 -6
  512. package/src/bridge/impl.ts +1 -0
  513. package/src/dada-client/README.md +93 -0
  514. package/src/{modularDrawer/data → dada-client}/entities/interestRateSelectors.ts +1 -1
  515. package/src/{modularDrawer/data → dada-client}/entities/marketSelectors.ts +1 -1
  516. package/src/{modularDrawer/hooks/__test__ → dada-client/hooks/__tests__}/useAssetsData.test.ts +2 -2
  517. package/src/dada-client/hooks/useAssetData.ts +22 -0
  518. package/src/{modularDrawer → dada-client}/hooks/useAssetsData.ts +2 -2
  519. package/src/{modularDrawer → dada-client}/hooks/useInterestRatesByCurrencies.ts +4 -4
  520. package/src/{modularDrawer → dada-client}/hooks/useMarketByCurrencies.ts +5 -6
  521. package/src/{modularDrawer/data → dada-client}/state-manager/api.ts +22 -1
  522. package/src/dada-client/types/trend.ts +1 -0
  523. package/src/deposit/useGroupedCurrenciesByProvider.hook.ts +8 -2
  524. package/src/e2e/enum/Account.ts +10 -0
  525. package/src/e2e/enum/AppInfos.ts +2 -0
  526. package/src/e2e/enum/Currency.ts +11 -0
  527. package/src/e2e/enum/Network.ts +1 -0
  528. package/src/e2e/enum/Provider.ts +1 -0
  529. package/src/e2e/families/hedera.ts +7 -0
  530. package/src/e2e/speculos.ts +12 -0
  531. package/src/e2e/swap.ts +6 -6
  532. package/src/exchange/platform/types.ts +2 -0
  533. package/src/exchange/swap/completeExchange.ts +32 -2
  534. package/src/exchange/swap/getIncompatibleCurrencyKeys.ts +8 -0
  535. package/src/exchange/swap/postSwapState.ts +28 -32
  536. package/src/exchange/swap/setBroadcastTransaction.ts +12 -12
  537. package/src/exchange/swap/types.ts +3 -3
  538. package/src/exchange/swap/updateAccountSwapStatus.ts +8 -6
  539. package/src/families/canton/config.ts +10 -10
  540. package/src/families/evm/shouldUseReceiveOptions.test.ts +25 -0
  541. package/src/families/evm/shouldUseReceiveOptions.ts +4 -0
  542. package/src/families/hedera/exchange.ts +48 -0
  543. package/src/families/tezos/config.ts +2 -2
  544. package/src/families/tezos/react.ts +20 -1
  545. package/src/families/tezos/setup.ts +3 -22
  546. package/src/generated/bridge/js.ts +0 -2
  547. package/src/hw/actions/completeExchange.ts +3 -0
  548. package/src/hw/signMessage/index.ts +10 -0
  549. package/src/modularDrawer/hooks/modules/useLeftApyModule.tsx +2 -2
  550. package/src/modularDrawer/hooks/modules/useLeftMarketTrendModule.tsx +1 -1
  551. package/src/modularDrawer/hooks/modules/useRightMarketTrendModule.tsx +2 -2
  552. package/src/modularDrawer/hooks/useAssetAccountCounts.tsx +8 -10
  553. package/src/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.ts +231 -0
  554. package/src/modularDrawer/hooks/useLeftAccountsApy.tsx +1 -1
  555. package/src/modularDrawer/hooks/useRightBalanceAsset.tsx +26 -102
  556. package/src/modularDrawer/hooks/useRightBalanceNetwork.tsx +19 -100
  557. package/src/modularDrawer/modules/createAssetConfiguration.ts +3 -11
  558. package/src/modularDrawer/modules/createNetworkConfiguration.ts +26 -10
  559. package/src/modularDrawer/utils/__tests__/calculateProviderTotal.test.ts +237 -0
  560. package/src/modularDrawer/utils/__tests__/currencyUtils.test.ts +1 -1
  561. package/src/modularDrawer/utils/__tests__/getInterestRateForAsset.test.ts +1 -1
  562. package/src/modularDrawer/utils/__tests__/groupAccountsByAsset.test.ts +228 -0
  563. package/src/modularDrawer/utils/calculateProviderTotal.ts +13 -2
  564. package/src/modularDrawer/utils/currencyUtils.ts +0 -1
  565. package/src/modularDrawer/utils/getBalanceAndFiatValueByAssets.ts +13 -37
  566. package/src/modularDrawer/utils/getInterestRateForAsset.ts +1 -1
  567. package/src/modularDrawer/utils/groupAccountsByAsset.ts +38 -19
  568. package/src/modularDrawer/utils/index.test.ts +1 -32
  569. package/src/modularDrawer/utils/index.ts +2 -23
  570. package/src/modularDrawer/utils/sortByBalance.tsx +5 -18
  571. package/src/modularDrawer/utils/type.ts +18 -14
  572. package/src/wallet-api/CustomDeeplink/server.ts +23 -0
  573. package/src/wallet-api/Exchange/server.ts +6 -6
  574. package/lib/modularDrawer/data/entities/index.d.ts.map +0 -1
  575. package/lib/modularDrawer/data/entities/index.js.map +0 -1
  576. package/lib/modularDrawer/data/entities/interestRateSelectors.d.ts.map +0 -1
  577. package/lib/modularDrawer/data/entities/interestRateSelectors.js.map +0 -1
  578. package/lib/modularDrawer/data/entities/marketSelectors.d.ts.map +0 -1
  579. package/lib/modularDrawer/data/entities/marketSelectors.js.map +0 -1
  580. package/lib/modularDrawer/data/entities/selectorUtils.d.ts.map +0 -1
  581. package/lib/modularDrawer/data/entities/selectorUtils.js.map +0 -1
  582. package/lib/modularDrawer/data/state-manager/api.js.map +0 -1
  583. package/lib/modularDrawer/data/state-manager/types.d.ts.map +0 -1
  584. package/lib/modularDrawer/data/state-manager/types.js.map +0 -1
  585. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.d.ts.map +0 -1
  586. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.js.map +0 -1
  587. package/lib/modularDrawer/hooks/useAssetsData.d.ts +0 -19
  588. package/lib/modularDrawer/hooks/useAssetsData.d.ts.map +0 -1
  589. package/lib/modularDrawer/hooks/useAssetsData.js.map +0 -1
  590. package/lib/modularDrawer/hooks/useInterestRatesByCurrencies.d.ts.map +0 -1
  591. package/lib/modularDrawer/hooks/useInterestRatesByCurrencies.js.map +0 -1
  592. package/lib/modularDrawer/hooks/useMarketByCurrencies.d.ts.map +0 -1
  593. package/lib/modularDrawer/hooks/useMarketByCurrencies.js.map +0 -1
  594. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts +0 -2
  595. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts.map +0 -1
  596. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.js +0 -496
  597. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.js.map +0 -1
  598. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.d.ts +0 -2
  599. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.d.ts.map +0 -1
  600. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js +0 -28
  601. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js.map +0 -1
  602. package/lib/modularDrawer/utils/buildProviderCurrenciesMap.d.ts +0 -9
  603. package/lib/modularDrawer/utils/buildProviderCurrenciesMap.d.ts.map +0 -1
  604. package/lib/modularDrawer/utils/buildProviderCurrenciesMap.js +0 -17
  605. package/lib/modularDrawer/utils/buildProviderCurrenciesMap.js.map +0 -1
  606. package/lib/modularDrawer/utils/counterValueFormatter.d.ts +0 -14
  607. package/lib/modularDrawer/utils/counterValueFormatter.d.ts.map +0 -1
  608. package/lib/modularDrawer/utils/counterValueFormatter.js +0 -107
  609. package/lib/modularDrawer/utils/counterValueFormatter.js.map +0 -1
  610. package/lib/modularDrawer/utils/getBalanceAndFiatValue.d.ts +0 -20
  611. package/lib/modularDrawer/utils/getBalanceAndFiatValue.d.ts.map +0 -1
  612. package/lib/modularDrawer/utils/getBalanceAndFiatValue.js +0 -39
  613. package/lib/modularDrawer/utils/getBalanceAndFiatValue.js.map +0 -1
  614. package/lib/modularDrawer/utils/getProviderCurrency.d.ts +0 -3
  615. package/lib/modularDrawer/utils/getProviderCurrency.d.ts.map +0 -1
  616. package/lib/modularDrawer/utils/getProviderCurrency.js +0 -14
  617. package/lib/modularDrawer/utils/getProviderCurrency.js.map +0 -1
  618. package/lib/modularDrawer/utils/haveOneCommonProvider.d.ts +0 -11
  619. package/lib/modularDrawer/utils/haveOneCommonProvider.d.ts.map +0 -1
  620. package/lib/modularDrawer/utils/haveOneCommonProvider.js +0 -29
  621. package/lib/modularDrawer/utils/haveOneCommonProvider.js.map +0 -1
  622. package/lib/modularDrawer/utils/parseToBigNumber.d.ts +0 -9
  623. package/lib/modularDrawer/utils/parseToBigNumber.d.ts.map +0 -1
  624. package/lib/modularDrawer/utils/parseToBigNumber.js +0 -24
  625. package/lib/modularDrawer/utils/parseToBigNumber.js.map +0 -1
  626. package/lib-es/modularDrawer/data/entities/index.d.ts.map +0 -1
  627. package/lib-es/modularDrawer/data/entities/index.js.map +0 -1
  628. package/lib-es/modularDrawer/data/entities/interestRateSelectors.d.ts.map +0 -1
  629. package/lib-es/modularDrawer/data/entities/interestRateSelectors.js.map +0 -1
  630. package/lib-es/modularDrawer/data/entities/marketSelectors.d.ts.map +0 -1
  631. package/lib-es/modularDrawer/data/entities/marketSelectors.js.map +0 -1
  632. package/lib-es/modularDrawer/data/entities/selectorUtils.d.ts.map +0 -1
  633. package/lib-es/modularDrawer/data/entities/selectorUtils.js.map +0 -1
  634. package/lib-es/modularDrawer/data/state-manager/api.js.map +0 -1
  635. package/lib-es/modularDrawer/data/state-manager/types.d.ts.map +0 -1
  636. package/lib-es/modularDrawer/data/state-manager/types.js.map +0 -1
  637. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.d.ts.map +0 -1
  638. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.js.map +0 -1
  639. package/lib-es/modularDrawer/hooks/useAssetsData.d.ts +0 -19
  640. package/lib-es/modularDrawer/hooks/useAssetsData.d.ts.map +0 -1
  641. package/lib-es/modularDrawer/hooks/useAssetsData.js.map +0 -1
  642. package/lib-es/modularDrawer/hooks/useInterestRatesByCurrencies.d.ts.map +0 -1
  643. package/lib-es/modularDrawer/hooks/useInterestRatesByCurrencies.js.map +0 -1
  644. package/lib-es/modularDrawer/hooks/useMarketByCurrencies.d.ts.map +0 -1
  645. package/lib-es/modularDrawer/hooks/useMarketByCurrencies.js.map +0 -1
  646. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts +0 -2
  647. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts.map +0 -1
  648. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.js +0 -494
  649. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.js.map +0 -1
  650. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.d.ts +0 -2
  651. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.d.ts.map +0 -1
  652. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js +0 -26
  653. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js.map +0 -1
  654. package/lib-es/modularDrawer/utils/buildProviderCurrenciesMap.d.ts +0 -9
  655. package/lib-es/modularDrawer/utils/buildProviderCurrenciesMap.d.ts.map +0 -1
  656. package/lib-es/modularDrawer/utils/buildProviderCurrenciesMap.js +0 -13
  657. package/lib-es/modularDrawer/utils/buildProviderCurrenciesMap.js.map +0 -1
  658. package/lib-es/modularDrawer/utils/counterValueFormatter.d.ts +0 -14
  659. package/lib-es/modularDrawer/utils/counterValueFormatter.d.ts.map +0 -1
  660. package/lib-es/modularDrawer/utils/counterValueFormatter.js +0 -103
  661. package/lib-es/modularDrawer/utils/counterValueFormatter.js.map +0 -1
  662. package/lib-es/modularDrawer/utils/getBalanceAndFiatValue.d.ts +0 -20
  663. package/lib-es/modularDrawer/utils/getBalanceAndFiatValue.d.ts.map +0 -1
  664. package/lib-es/modularDrawer/utils/getBalanceAndFiatValue.js +0 -32
  665. package/lib-es/modularDrawer/utils/getBalanceAndFiatValue.js.map +0 -1
  666. package/lib-es/modularDrawer/utils/getProviderCurrency.d.ts +0 -3
  667. package/lib-es/modularDrawer/utils/getProviderCurrency.d.ts.map +0 -1
  668. package/lib-es/modularDrawer/utils/getProviderCurrency.js +0 -10
  669. package/lib-es/modularDrawer/utils/getProviderCurrency.js.map +0 -1
  670. package/lib-es/modularDrawer/utils/haveOneCommonProvider.d.ts +0 -11
  671. package/lib-es/modularDrawer/utils/haveOneCommonProvider.d.ts.map +0 -1
  672. package/lib-es/modularDrawer/utils/haveOneCommonProvider.js +0 -25
  673. package/lib-es/modularDrawer/utils/haveOneCommonProvider.js.map +0 -1
  674. package/lib-es/modularDrawer/utils/parseToBigNumber.d.ts +0 -9
  675. package/lib-es/modularDrawer/utils/parseToBigNumber.d.ts.map +0 -1
  676. package/lib-es/modularDrawer/utils/parseToBigNumber.js +0 -17
  677. package/lib-es/modularDrawer/utils/parseToBigNumber.js.map +0 -1
  678. package/src/modularDrawer/utils/__tests__/counterValueFormatter.test.ts +0 -549
  679. package/src/modularDrawer/utils/__tests__/haveOneCommonProvider.test.ts +0 -34
  680. package/src/modularDrawer/utils/buildProviderCurrenciesMap.tsx +0 -25
  681. package/src/modularDrawer/utils/counterValueFormatter.ts +0 -165
  682. package/src/modularDrawer/utils/getBalanceAndFiatValue.ts +0 -53
  683. package/src/modularDrawer/utils/getProviderCurrency.ts +0 -13
  684. package/src/modularDrawer/utils/haveOneCommonProvider.ts +0 -31
  685. package/src/modularDrawer/utils/parseToBigNumber.ts +0 -17
  686. /package/lib/{modularDrawer/data → dada-client}/entities/index.d.ts +0 -0
  687. /package/lib/{modularDrawer/data → dada-client}/entities/index.js +0 -0
  688. /package/lib/{modularDrawer/data → dada-client}/entities/interestRateSelectors.js +0 -0
  689. /package/lib/{modularDrawer/data → dada-client}/entities/marketSelectors.js +0 -0
  690. /package/lib/{modularDrawer/data → dada-client}/entities/selectorUtils.d.ts +0 -0
  691. /package/lib/{modularDrawer/data → dada-client}/entities/selectorUtils.js +0 -0
  692. /package/lib/{modularDrawer/hooks/__test__ → dada-client/hooks/__tests__}/useAssetsData.test.d.ts +0 -0
  693. /package/lib/{modularDrawer → dada-client}/hooks/useInterestRatesByCurrencies.d.ts +0 -0
  694. /package/lib/{modularDrawer → dada-client}/hooks/useMarketByCurrencies.d.ts +0 -0
  695. /package/lib/{modularDrawer/data → dada-client}/state-manager/types.d.ts +0 -0
  696. /package/lib/{modularDrawer/data → dada-client}/state-manager/types.js +0 -0
  697. /package/lib-es/{modularDrawer/data → dada-client}/entities/index.d.ts +0 -0
  698. /package/lib-es/{modularDrawer/data → dada-client}/entities/index.js +0 -0
  699. /package/lib-es/{modularDrawer/data → dada-client}/entities/interestRateSelectors.js +0 -0
  700. /package/lib-es/{modularDrawer/data → dada-client}/entities/marketSelectors.js +0 -0
  701. /package/lib-es/{modularDrawer/data → dada-client}/entities/selectorUtils.d.ts +0 -0
  702. /package/lib-es/{modularDrawer/data → dada-client}/entities/selectorUtils.js +0 -0
  703. /package/lib-es/{modularDrawer/hooks/__test__ → dada-client/hooks/__tests__}/useAssetsData.test.d.ts +0 -0
  704. /package/lib-es/{modularDrawer → dada-client}/hooks/useInterestRatesByCurrencies.d.ts +0 -0
  705. /package/lib-es/{modularDrawer → dada-client}/hooks/useMarketByCurrencies.d.ts +0 -0
  706. /package/lib-es/{modularDrawer/data → dada-client}/state-manager/types.d.ts +0 -0
  707. /package/lib-es/{modularDrawer/data → dada-client}/state-manager/types.js +0 -0
  708. /package/src/{modularDrawer/data → dada-client}/entities/index.ts +0 -0
  709. /package/src/{modularDrawer/data → dada-client}/entities/selectorUtils.ts +0 -0
  710. /package/src/{modularDrawer/data → dada-client}/state-manager/types.ts +0 -0
@@ -0,0 +1,228 @@
1
+ import { groupAccountsByAsset } from "../groupAccountsByAsset";
2
+ import { createFixtureCryptoCurrency } from "../../../mock/fixtures/cryptoCurrencies";
3
+ import BigNumber from "bignumber.js";
4
+ import type { Account, TokenAccount } from "@ledgerhq/types-live";
5
+ import type { CounterValuesState } from "@ledgerhq/live-countervalues/types";
6
+
7
+ // Mock calculate function
8
+ jest.mock("@ledgerhq/live-countervalues/logic", () => ({
9
+ calculate: jest.fn((state, { value }) => {
10
+ // Mock: return the balance directly as fiat value for simple testing
11
+ return value;
12
+ }),
13
+ }));
14
+
15
+ describe("groupAccountsByAsset", () => {
16
+ const mockCurrency = createFixtureCryptoCurrency("bitcoin");
17
+ const mockEthCurrency = createFixtureCryptoCurrency("ethereum");
18
+
19
+ const mockCounterValuesState = {} as CounterValuesState;
20
+ const mockTargetCurrency = createFixtureCryptoCurrency("usd");
21
+
22
+ const mockUSDCToken = {
23
+ type: "TokenCurrency" as const,
24
+ id: "ethereum/erc20/usdc",
25
+ contractAddress: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
26
+ parentCurrency: mockEthCurrency,
27
+ tokenType: "erc20" as const,
28
+ name: "USD Coin",
29
+ ticker: "USDC",
30
+ units: [{ name: "USD Coin", code: "USDC", magnitude: 6 }],
31
+ };
32
+
33
+ const mockBTCAccount: Account = {
34
+ type: "Account",
35
+ id: "btc-account-1",
36
+ seedIdentifier: "seed-id",
37
+ derivationMode: "",
38
+ currency: mockCurrency,
39
+ balance: new BigNumber(100000000), // 1 BTC
40
+ spendableBalance: new BigNumber(100000000),
41
+ blockHeight: 0,
42
+ operations: [],
43
+ operationsCount: 0,
44
+ pendingOperations: [],
45
+ index: 0,
46
+ freshAddress: "btc-address",
47
+ freshAddressPath: "44'/0'/0'/0/0",
48
+ used: true,
49
+ swapHistory: [],
50
+ nfts: [],
51
+ lastSyncDate: new Date(),
52
+ creationDate: new Date(),
53
+ balanceHistoryCache: {
54
+ HOUR: { balances: [], latestDate: null },
55
+ DAY: { balances: [], latestDate: null },
56
+ WEEK: { balances: [], latestDate: null },
57
+ },
58
+ };
59
+
60
+ const mockUSDCAccount: TokenAccount = {
61
+ type: "TokenAccount",
62
+ id: "usdc-account-1",
63
+ token: mockUSDCToken,
64
+ parentId: "eth-account-1",
65
+ balance: new BigNumber(1000000), // 1 USDC
66
+ spendableBalance: new BigNumber(1000000),
67
+ operations: [],
68
+ operationsCount: 0,
69
+ pendingOperations: [],
70
+ swapHistory: [],
71
+ creationDate: new Date(),
72
+ balanceHistoryCache: {
73
+ HOUR: { balances: [], latestDate: null },
74
+ DAY: { balances: [], latestDate: null },
75
+ WEEK: { balances: [], latestDate: null },
76
+ },
77
+ };
78
+
79
+ it("should group accounts by asset ID and aggregate balances", () => {
80
+ const accounts = [mockBTCAccount, mockUSDCAccount];
81
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
82
+
83
+ expect(result).toEqual({
84
+ [mockCurrency.id]: {
85
+ totalBalance: new BigNumber(100000000), // 1 BTC in satoshis
86
+ totalFiatValue: new BigNumber(100000000), // Mock returns balance as fiat value
87
+ accounts: [mockBTCAccount],
88
+ referenceCurrency: mockCurrency,
89
+ },
90
+ [mockUSDCToken.id]: {
91
+ totalBalance: new BigNumber(1000000), // 1 USDC in micro-USDC
92
+ totalFiatValue: new BigNumber(1000000), // Mock returns balance as fiat value
93
+ accounts: [mockUSDCAccount],
94
+ referenceCurrency: mockUSDCToken,
95
+ },
96
+ });
97
+ });
98
+
99
+ it("should aggregate multiple accounts with the same asset", () => {
100
+ const secondBTCAccount: Account = {
101
+ ...mockBTCAccount,
102
+ id: "btc-account-2",
103
+ balance: new BigNumber(50000000), // 0.5 BTC
104
+ };
105
+
106
+ const accounts = [mockBTCAccount, secondBTCAccount];
107
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
108
+
109
+ expect(result[mockCurrency.id]).toEqual({
110
+ totalBalance: new BigNumber(150000000), // 1.5 BTC total
111
+ totalFiatValue: new BigNumber(150000000), // Mock returns balance as fiat value
112
+ accounts: [mockBTCAccount, secondBTCAccount],
113
+ referenceCurrency: mockCurrency,
114
+ });
115
+ });
116
+
117
+ it("should handle empty accounts array", () => {
118
+ const result = groupAccountsByAsset([], mockCounterValuesState, mockTargetCurrency);
119
+ expect(result).toEqual({});
120
+ });
121
+
122
+ it("should handle accounts with zero balance", () => {
123
+ const zeroBalanceAccount: Account = {
124
+ ...mockBTCAccount,
125
+ balance: new BigNumber(0),
126
+ };
127
+
128
+ const accounts = [zeroBalanceAccount];
129
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
130
+
131
+ expect(result[mockCurrency.id]).toEqual({
132
+ totalBalance: new BigNumber(0),
133
+ totalFiatValue: new BigNumber(0), // Mock returns balance (0) as fiat value
134
+ accounts: [zeroBalanceAccount],
135
+ referenceCurrency: mockCurrency,
136
+ });
137
+ });
138
+
139
+ it("should set referenceCurrency to the first currency encountered for each asset group", () => {
140
+ const accounts = [mockBTCAccount, mockUSDCAccount];
141
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
142
+
143
+ expect(result[mockCurrency.id].referenceCurrency).toEqual(mockCurrency);
144
+ expect(result[mockUSDCToken.id].referenceCurrency).toEqual(mockUSDCToken);
145
+ });
146
+
147
+ it("should normalize balances when tokens have different magnitudes", () => {
148
+ // Create BSC USDC with different magnitude (18 decimals instead of 6)
149
+ const mockBscUSDCToken = {
150
+ ...mockUSDCToken,
151
+ id: "bsc/bep20/usdc",
152
+ name: "USD Coin (BSC)",
153
+ ticker: "USDC",
154
+ units: [{ name: "USD Coin", code: "USDC", magnitude: 18 }], // 18 decimals
155
+ };
156
+
157
+ const mockEthUSDCAccount: TokenAccount = {
158
+ ...mockUSDCAccount,
159
+ id: "eth-usdc-account",
160
+ token: mockUSDCToken, // 6 decimals
161
+ balance: new BigNumber(1000000), // 1 USDC with 6 decimals
162
+ };
163
+
164
+ const mockBscUSDCAccount: TokenAccount = {
165
+ ...mockUSDCAccount,
166
+ id: "bsc-usdc-account",
167
+ token: mockBscUSDCToken, // 18 decimals
168
+ balance: new BigNumber("1000000000000000000"), // 1 USDC with 18 decimals
169
+ };
170
+
171
+ // Both should be grouped under the same token ID for this test
172
+ // First account (ETH USDC) becomes reference currency with 6 decimals
173
+ const accounts = [mockEthUSDCAccount, mockBscUSDCAccount];
174
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
175
+
176
+ const ethGroup = result[mockUSDCToken.id];
177
+ expect(ethGroup.referenceCurrency).toEqual(mockUSDCToken); // First currency is reference
178
+ expect(ethGroup.accounts).toHaveLength(1);
179
+ expect(ethGroup.totalBalance).toEqual(new BigNumber(1000000)); // 1 USDC normalized to 6 decimals
180
+
181
+ const bscGroup = result[mockBscUSDCToken.id];
182
+ expect(bscGroup.referenceCurrency).toEqual(mockBscUSDCToken);
183
+ expect(bscGroup.accounts).toHaveLength(1);
184
+ expect(bscGroup.totalBalance).toEqual(new BigNumber("1000000000000000000")); // 1 USDC with 18 decimals
185
+ });
186
+
187
+ it("should normalize balances correctly when adding accounts with different magnitudes to same asset group", () => {
188
+ // Create two USDC tokens with same ID but different magnitudes
189
+ const ethUSDCToken = {
190
+ ...mockUSDCToken,
191
+ units: [{ name: "USD Coin", code: "USDC", magnitude: 6 }], // 6 decimals
192
+ };
193
+
194
+ const bscUSDCToken = {
195
+ ...mockUSDCToken,
196
+ units: [{ name: "USD Coin", code: "USDC", magnitude: 18 }], // 18 decimals
197
+ };
198
+
199
+ const ethAccount: TokenAccount = {
200
+ ...mockUSDCAccount,
201
+ id: "eth-usdc",
202
+ token: ethUSDCToken,
203
+ balance: new BigNumber(1000000), // 1 USDC with 6 decimals
204
+ };
205
+
206
+ const bscAccount: TokenAccount = {
207
+ ...mockUSDCAccount,
208
+ id: "bsc-usdc",
209
+ token: bscUSDCToken,
210
+ balance: new BigNumber("1000000000000000000"), // 1 USDC with 18 decimals
211
+ };
212
+
213
+ // Process ETH account first to make it the reference currency
214
+ const accounts = [ethAccount, bscAccount];
215
+ const result = groupAccountsByAsset(accounts, mockCounterValuesState, mockTargetCurrency);
216
+
217
+ const group = result[mockUSDCToken.id];
218
+ expect(group.referenceCurrency).toEqual(ethUSDCToken); // First currency is reference (6 decimals)
219
+ expect(group.accounts).toHaveLength(2);
220
+
221
+ // BSC balance should be normalized from 18 decimals to 6 decimals
222
+ // 1000000000000000000 (18 decimals) -> 1000000 (6 decimals)
223
+ // magnitudeDiff = 6 - 18 = -12
224
+ // normalized = 1000000000000000000 * 10^(-12) = 1000000
225
+ const expectedTotal = new BigNumber(1000000).plus(new BigNumber(1000000)); // 2 USDC total
226
+ expect(group.totalBalance).toEqual(expectedTotal);
227
+ });
228
+ });
@@ -9,15 +9,26 @@ export const calculateProviderTotals = (
9
9
  let totalBalance = new BigNumber(0);
10
10
  let totalFiatValue = new BigNumber(0);
11
11
  let hasAccounts = false;
12
+ let referenceCurrency: CryptoOrTokenCurrency | null = null;
12
13
 
13
14
  for (const currency of currencies) {
14
15
  const assetGroup = groupedAccountsByAsset[currency.id];
15
16
  if (assetGroup?.accounts.length > 0) {
16
- totalBalance = totalBalance.plus(assetGroup.totalBalance);
17
+ const refCurrency = referenceCurrency ?? assetGroup.referenceCurrency;
18
+ const magnitudeDiff =
19
+ refCurrency.units[0].magnitude - assetGroup.referenceCurrency.units[0].magnitude;
20
+ const normalizedBalance = assetGroup.totalBalance.shiftedBy(magnitudeDiff);
21
+
22
+ totalBalance = totalBalance.plus(normalizedBalance);
17
23
  totalFiatValue = totalFiatValue.plus(assetGroup.totalFiatValue);
18
24
  hasAccounts = true;
25
+
26
+ // Use the referenceCurrency from the first asset group with accounts
27
+ if (!referenceCurrency) {
28
+ referenceCurrency = assetGroup.referenceCurrency;
29
+ }
19
30
  }
20
31
  }
21
32
 
22
- return { totalBalance, totalFiatValue, hasAccounts };
33
+ return { totalBalance, totalFiatValue, hasAccounts, referenceCurrency };
23
34
  };
@@ -4,7 +4,6 @@ import { isTokenCurrency } from "../../currencies";
4
4
  import { CurrenciesByProviderId } from "../../deposit/type";
5
5
 
6
6
  export type ProviderCoverageMap = Map<string, Set<string>>;
7
-
8
7
  export const safeCurrencyLookup = (id: string): CryptoOrTokenCurrency | null => {
9
8
  try {
10
9
  return getTokenOrCryptoCurrencyById(id);
@@ -1,14 +1,14 @@
1
- import { formatCurrencyUnit } from "@ledgerhq/coin-framework/lib-es/currencies/formatCurrencyUnit";
2
- import type { CounterValuesState } from "@ledgerhq/live-countervalues/types";
3
1
  import type { CryptoOrTokenCurrency, Currency } from "@ledgerhq/types-cryptoassets";
4
2
  import { groupAccountsByAsset, type GroupedAccount } from "./groupAccountsByAsset";
5
3
  import { AssetType } from "./type";
6
4
  import { AccountLike } from "@ledgerhq/types-live";
7
- import { counterValueFormatter } from "./counterValueFormatter";
5
+ import BigNumber from "bignumber.js";
6
+ import type { CounterValuesState } from "@ledgerhq/live-countervalues/types";
8
7
 
9
8
  interface ExtendedAssetType extends AssetType {
10
- balance?: string;
11
- fiatValue?: string;
9
+ currency?: CryptoOrTokenCurrency;
10
+ balance?: BigNumber;
11
+ fiatValue?: number;
12
12
  }
13
13
 
14
14
  export const getBalanceAndFiatValueByAssets = (
@@ -16,21 +16,14 @@ export const getBalanceAndFiatValueByAssets = (
16
16
  assets: CryptoOrTokenCurrency[],
17
17
  counterValuesState: CounterValuesState,
18
18
  targetCurrency: Currency,
19
- isDiscreetMode: boolean = false,
20
- userLocale: string,
21
19
  ): ExtendedAssetType[] => {
22
- const groupedAccountsByAsset = groupAccountsByAsset(
23
- accounts,
24
- counterValuesState,
25
- targetCurrency,
26
- isDiscreetMode,
27
- );
20
+ const groupedAccountsByAsset = groupAccountsByAsset(accounts, counterValuesState, targetCurrency);
28
21
 
29
22
  return assets.map(asset => {
30
23
  const assetGroup = groupedAccountsByAsset[asset.id];
31
24
 
32
25
  if (assetGroup) {
33
- return formatAssetDetails(assetGroup, asset, targetCurrency, isDiscreetMode, userLocale);
26
+ return yieldAssetDetails(assetGroup, asset);
34
27
  }
35
28
 
36
29
  return {
@@ -41,36 +34,19 @@ export const getBalanceAndFiatValueByAssets = (
41
34
  });
42
35
  };
43
36
 
44
- const formatAssetDetails = (
37
+ const yieldAssetDetails = (
45
38
  assetGroup: GroupedAccount,
46
39
  asset: CryptoOrTokenCurrency,
47
- targetCurrency: Currency,
48
- isDiscreetMode: boolean,
49
- userLocale: string,
50
40
  ): ExtendedAssetType => {
51
- const assetDetails =
52
- assetGroup.accounts[0].type === "Account"
53
- ? assetGroup.accounts[0].currency
54
- : assetGroup.accounts[0].token;
55
-
56
- const formattedBalance = formatCurrencyUnit(assetDetails.units[0], assetGroup.totalBalance, {
57
- showCode: true,
58
- discreet: isDiscreetMode,
59
- });
60
-
61
- const formattedFiatValue = counterValueFormatter({
62
- currency: targetCurrency.ticker,
63
- value: assetGroup.totalFiatValue.toNumber(),
64
- locale: userLocale,
65
- allowZeroValue: true,
66
- discreetMode: isDiscreetMode,
67
- });
41
+ // Use the reference currency for consistent magnitude
42
+ const assetDetails = assetGroup.referenceCurrency;
68
43
 
69
44
  return {
70
45
  id: asset.id,
71
46
  name: asset.name,
72
47
  ticker: asset.ticker,
73
- balance: formattedBalance,
74
- fiatValue: formattedFiatValue,
48
+ currency: assetDetails,
49
+ balance: assetGroup.totalBalance,
50
+ fiatValue: assetGroup.totalFiatValue.toNumber(),
75
51
  };
76
52
  };
@@ -1,5 +1,5 @@
1
1
  import { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
2
- import { ApyType } from "./type";
2
+ import { ApyType } from "../../dada-client/types/trend";
3
3
 
4
4
  type InterestRate = { value: number; type: ApyType };
5
5
  type InterestRateResult = {
@@ -1,51 +1,70 @@
1
- import { getBalanceAndFiatValue } from "./getBalanceAndFiatValue";
2
- import type { CounterValuesState } from "@ledgerhq/live-countervalues/types";
3
- import { Currency } from "@ledgerhq/types-cryptoassets";
4
1
  import { AccountLike } from "@ledgerhq/types-live";
5
2
  import BigNumber from "bignumber.js";
6
- import { parseToBigNumber } from "./parseToBigNumber";
3
+ import type { CounterValuesState } from "@ledgerhq/live-countervalues/types";
4
+ import { CryptoOrTokenCurrency, Currency } from "@ledgerhq/types-cryptoassets";
5
+ import { calculate } from "@ledgerhq/live-countervalues/logic";
7
6
 
8
7
  export type GroupedAccount = {
9
8
  totalBalance: BigNumber;
10
9
  totalFiatValue: BigNumber;
11
10
  accounts: AccountLike[];
11
+ referenceCurrency: CryptoOrTokenCurrency; // Reference currency for magnitude normalization
12
12
  };
13
13
 
14
14
  export const groupAccountsByAsset = (
15
15
  accounts: AccountLike[],
16
16
  counterValuesState: CounterValuesState,
17
17
  targetCurrency: Currency,
18
- isDiscreetMode: boolean,
19
18
  ): Record<string, GroupedAccount> => {
20
19
  const initialGroupedAccounts: Record<string, GroupedAccount> = {};
21
20
 
22
21
  return accounts.reduce((groupedAccounts, account) => {
23
22
  const assetId = account.type === "Account" ? account.currency.id : account.token.id;
24
23
 
25
- if (!groupedAccounts[assetId]) {
26
- groupedAccounts[assetId] = {
24
+ let assetGroup = groupedAccounts[assetId];
25
+ if (!assetGroup) {
26
+ const currency = account.type === "Account" ? account.currency : account.token;
27
+ assetGroup = groupedAccounts[assetId] = {
27
28
  totalBalance: new BigNumber(0),
28
29
  totalFiatValue: new BigNumber(0),
29
30
  accounts: [],
31
+ referenceCurrency: currency, // First currency becomes the reference
30
32
  };
31
33
  }
32
34
 
33
- const { fiatValue } = getBalanceAndFiatValue(
34
- account,
35
- counterValuesState,
36
- targetCurrency,
37
- isDiscreetMode,
38
- false,
39
- );
35
+ const currency = account.type === "Account" ? account.currency : account.token;
40
36
  const balance = account.balance;
41
37
 
42
- const parsedFiatValue = parseToBigNumber(fiatValue ?? "0");
38
+ // Convert balance to reference currency magnitude before summing
39
+ const referenceMagnitude = assetGroup.referenceCurrency.units[0].magnitude || 0;
40
+ const currentMagnitude = currency.units[0].magnitude || 0;
41
+ const magnitudeDiff = referenceMagnitude - currentMagnitude;
42
+ const normalizedBalance = balance.shiftedBy(magnitudeDiff);
43
43
 
44
- groupedAccounts[assetId].totalBalance = groupedAccounts[assetId].totalBalance.plus(balance);
45
- groupedAccounts[assetId].totalFiatValue =
46
- groupedAccounts[assetId].totalFiatValue.plus(parsedFiatValue);
47
- groupedAccounts[assetId].accounts.push(account);
44
+ const fiatValue = calculateFiatValue(account, counterValuesState, targetCurrency);
45
+
46
+ assetGroup.totalBalance = assetGroup.totalBalance.plus(normalizedBalance);
47
+ assetGroup.totalFiatValue = assetGroup.totalFiatValue.plus(fiatValue || 0);
48
+ assetGroup.accounts.push(account);
48
49
 
49
50
  return groupedAccounts;
50
51
  }, initialGroupedAccounts);
51
52
  };
53
+
54
+ function calculateFiatValue(
55
+ account: AccountLike,
56
+ state: CounterValuesState,
57
+ toCurrency: Currency,
58
+ ): number {
59
+ const currency = account.type === "Account" ? account.currency : account.token;
60
+
61
+ const balanceNumber = account.balance.toNumber();
62
+
63
+ const fiatValue = calculate(state, {
64
+ from: currency,
65
+ to: toCurrency,
66
+ value: balanceNumber,
67
+ });
68
+
69
+ return fiatValue || 0;
70
+ }
@@ -1,9 +1,8 @@
1
- import { isCorrespondingCurrency, getEffectiveCurrency } from "./index";
1
+ import { isCorrespondingCurrency } from "./index";
2
2
 
3
3
  import { createFixtureCryptoCurrency } from "../../mock/fixtures/cryptoCurrencies";
4
4
  import { cryptocurrenciesById } from "@ledgerhq/cryptoassets";
5
5
  import type { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
6
- import type { CurrenciesByProviderId } from "../../deposit/type";
7
6
 
8
7
  describe("isCorrespondingCurrency", () => {
9
8
  const evmCurrency = createFixtureCryptoCurrency("evm");
@@ -42,33 +41,3 @@ describe("isCorrespondingCurrency", () => {
42
41
  expect(isCorrespondingCurrency(bitcoinCurrency, evmCurrency)).toBe(false);
43
42
  });
44
43
  });
45
-
46
- describe("getEffectiveCurrency", () => {
47
- const parent = createFixtureCryptoCurrency("evm");
48
- const token: CryptoOrTokenCurrency = {
49
- type: "TokenCurrency",
50
- id: "ethereum/erc20/usdc",
51
- contractAddress: "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",
52
- parentCurrency: parent,
53
- tokenType: "erc20",
54
- name: "USD Coin",
55
- ticker: "USDC",
56
- units: [{ name: "USD Coin", code: "USDC", magnitude: 6 }],
57
- };
58
- const provider: CurrenciesByProviderId = {
59
- providerId: "provider1",
60
- currenciesByNetwork: [parent, token],
61
- };
62
-
63
- it("returns currency if id is in currencyIds", () => {
64
- expect(getEffectiveCurrency(token, provider, [token.id])).toBe(token);
65
- });
66
-
67
- it("returns first matching currency from provider if id not in currencyIds", () => {
68
- expect(getEffectiveCurrency(token, provider, [parent.id])).toBe(parent);
69
- });
70
-
71
- it("returns currency if no match in provider", () => {
72
- expect(getEffectiveCurrency(token, provider, ["notfound"])).toBe(token);
73
- });
74
- });
@@ -1,8 +1,5 @@
1
1
  import { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
2
- import { CurrenciesByProviderId } from "../../deposit/type";
3
- import { haveOneCommonProvider } from "./haveOneCommonProvider";
4
- import { getBalanceAndFiatValue } from "./getBalanceAndFiatValue";
5
- import { groupCurrenciesByProvider } from "./groupCurrenciesByProvider";
2
+ export { groupCurrenciesByProvider } from "./groupCurrenciesByProvider";
6
3
 
7
4
  function isCorrespondingCurrency(
8
5
  elem: CryptoOrTokenCurrency,
@@ -17,22 +14,4 @@ function isCorrespondingCurrency(
17
14
  return false;
18
15
  }
19
16
 
20
- const getEffectiveCurrency = (
21
- currency: CryptoOrTokenCurrency,
22
- provider: CurrenciesByProviderId,
23
- currencyIds: string[],
24
- ) => {
25
- const isCurrencyFiltered = currencyIds.includes(currency.id);
26
-
27
- if (isCurrencyFiltered) return currency;
28
-
29
- return provider.currenciesByNetwork.find(elem => currencyIds.includes(elem.id)) ?? currency;
30
- };
31
-
32
- export {
33
- isCorrespondingCurrency,
34
- getEffectiveCurrency,
35
- haveOneCommonProvider,
36
- getBalanceAndFiatValue,
37
- groupCurrenciesByProvider,
38
- };
17
+ export { isCorrespondingCurrency };
@@ -1,32 +1,19 @@
1
1
  import { BalanceUI } from "./type";
2
2
 
3
- export const parseFiatValue = (value?: string, discreet?: boolean) => {
4
- if (!value || discreet) return -1;
5
- return parseFloat(value.replace(/[^0-9.-]+/g, "")) || -1;
6
- };
7
-
8
- export function toFiatString(x?: BalanceUI): string | undefined {
9
- return x && "fiatValue" in x ? String(x.fiatValue) : undefined;
10
- }
11
-
12
3
  export function hasBalance(balanceData?: BalanceUI): boolean {
13
- return (
14
- !!balanceData &&
15
- (("fiatValue" in balanceData && !!balanceData.fiatValue) ||
16
- ("balance" in balanceData && !!balanceData.balance))
17
- );
4
+ return !!balanceData && balanceData.balance !== undefined && balanceData.balance.gt(0);
18
5
  }
19
6
 
20
7
  export function compareByBalanceThenFiat(
21
8
  a: BalanceUI | undefined,
22
9
  b: BalanceUI | undefined,
23
- discreet: boolean,
24
10
  ): number {
25
11
  const ah = hasBalance(a);
26
12
  const bh = hasBalance(b);
27
13
  if (ah && !bh) return -1;
28
14
  if (!ah && bh) return 1;
29
- const af = parseFiatValue(toFiatString(a), discreet);
30
- const bf = parseFiatValue(toFiatString(b), discreet);
31
- return bf - af;
15
+
16
+ const aFiat = a?.fiatValue ?? 0;
17
+ const bFiat = b?.fiatValue ?? 0;
18
+ return bFiat - aFiat;
32
19
  }
@@ -1,15 +1,14 @@
1
1
  import { CounterValuesState } from "@ledgerhq/live-countervalues/lib/types";
2
- import { CryptoOrTokenCurrency, Currency } from "@ledgerhq/types-cryptoassets";
2
+ import { CryptoOrTokenCurrency, Currency, Unit } from "@ledgerhq/types-cryptoassets";
3
3
  import { AccountLike } from "@ledgerhq/types-live";
4
4
  import { ReactNode } from "react";
5
5
  import { Observable } from "rxjs";
6
6
  import { WalletAPIAccount } from "../../wallet-api/types";
7
- import { CurrenciesByProviderId } from "../../deposit/type";
8
7
  import { EnhancedModularDrawerConfiguration } from "../../wallet-api/ModularDrawer/types";
9
- import { InterestRate } from "../data/entities";
8
+ import { InterestRate } from "../../dada-client/entities";
10
9
  import { MarketItemResponse } from "../../market/utils/types";
11
-
12
- export type ApyType = "NRR" | "APY" | "APR";
10
+ import BigNumber from "bignumber.js";
11
+ import { ApyType } from "../../dada-client/types/trend";
13
12
 
14
13
  export type AssetType = {
15
14
  name: string;
@@ -36,13 +35,21 @@ export type AssetWithBalance = AssetType & {
36
35
 
37
36
  export type UseBalanceDeps = () => {
38
37
  flattenedAccounts: AccountLike[];
39
- discreet: boolean;
40
38
  state: CounterValuesState;
41
39
  counterValueCurrency: Currency;
42
40
  locale: string;
43
41
  };
44
42
 
45
- export type BalanceUI = { balance?: string; fiatValue?: string };
43
+ export type BalanceUI = {
44
+ // Raw values
45
+ balance?: BigNumber;
46
+ fiatValue?: number;
47
+ fiatUnit?: Unit;
48
+ currency?: CryptoOrTokenCurrency;
49
+ // Formatting parameters
50
+ locale?: string;
51
+ discreet?: boolean;
52
+ };
46
53
  export type CreateBalanceItem = (x: BalanceUI) => React.ReactNode;
47
54
 
48
55
  export type CreateAccountsCountAndApy = (args: {
@@ -74,11 +81,11 @@ export type UseAccountData = (params: AccountModuleParams) => AccountDataItem[];
74
81
  export type NetworkHookParams = {
75
82
  assets: CryptoOrTokenCurrency[];
76
83
  networks: CryptoOrTokenCurrency[];
77
- selectedAssetId: string;
78
- currenciesByProvider: CurrenciesByProviderId[];
79
84
  accounts$?: Observable<WalletAPIAccount[]>;
80
85
  };
81
- export type NetworkHook = (params: NetworkHookParams) => Array<CryptoOrTokenCurrency & Network>;
86
+ export type NetworkHook = (
87
+ params: NetworkHookParams,
88
+ ) => Array<CryptoOrTokenCurrency & Network & { balanceData?: BalanceUI; count?: number }>;
82
89
 
83
90
  export type NetworkConfigurationDeps = {
84
91
  useAccountData: UseAccountData;
@@ -101,14 +108,11 @@ export type Network = {
101
108
 
102
109
  export type CreateNetworkConfigurationHookProps = {
103
110
  networksConfig: EnhancedModularDrawerConfiguration["networks"];
104
- currenciesByProvider?: CurrenciesByProviderId[];
105
- selectedAssetId: string;
106
111
  accounts$?: Observable<WalletAPIAccount[]>;
107
112
  };
108
113
 
109
114
  type Props = {
110
115
  assetsConfiguration: EnhancedModularDrawerConfiguration["assets"];
111
- currenciesByProvider?: CurrenciesByProviderId[];
112
116
  };
113
117
 
114
118
  export type AssetConfigurationDeps = {
@@ -116,7 +120,7 @@ export type AssetConfigurationDeps = {
116
120
  MarketPercentIndicator: (args: { percent: number }) => ReactNode;
117
121
  MarketPriceIndicator: (args: { price: string; percent: number }) => ReactNode;
118
122
  useBalanceDeps: UseBalanceDeps;
119
- balanceItem: (asset: { fiatValue?: string; balance?: string }) => ReactNode;
123
+ balanceItem: CreateBalanceItem;
120
124
  assetsMap: Map<
121
125
  string,
122
126
  { mainCurrency: CryptoOrTokenCurrency; currencies: CryptoOrTokenCurrency[] }
@@ -0,0 +1,23 @@
1
+ /* eslint-disable no-console */
2
+ import { RPCHandler, customWrapper } from "@ledgerhq/wallet-api-server";
3
+
4
+ export type DeeplinkOpenParams = {
5
+ url: string;
6
+ };
7
+
8
+ type Handlers = Record<"custom.deeplink.open", RPCHandler<void, DeeplinkOpenParams>>;
9
+
10
+ type DeeplinkUiHooks = {
11
+ "custom.deeplink.open": (params?: { url: string }) => void;
12
+ };
13
+
14
+ export const handlers = ({
15
+ uiHooks: { "custom.deeplink.open": uiDeeplinkOpen },
16
+ }: {
17
+ uiHooks: DeeplinkUiHooks;
18
+ }) =>
19
+ ({
20
+ "custom.deeplink.open": customWrapper<DeeplinkOpenParams, void>(params =>
21
+ uiDeeplinkOpen(params),
22
+ ),
23
+ }) as const satisfies Handlers;