@ledgerhq/live-common 34.46.0-nightly.3 → 34.46.0-nightly.5

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 (282) hide show
  1. package/lib/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
  2. package/lib/bridge/generic-alpaca/estimateMaxSpendable.js +6 -4
  3. package/lib/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
  4. package/lib/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
  5. package/lib/bridge/generic-alpaca/getTransactionStatus.js +2 -2
  6. package/lib/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  7. package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  8. package/lib/bridge/generic-alpaca/prepareTransaction.js +12 -12
  9. package/lib/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  10. package/lib/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  11. package/lib/bridge/generic-alpaca/signOperation.js +3 -4
  12. package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
  13. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js +1 -1
  14. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  15. package/lib/bridge/generic-alpaca/utils.d.ts +0 -1
  16. package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
  17. package/lib/bridge/generic-alpaca/utils.js +0 -1
  18. package/lib/bridge/generic-alpaca/utils.js.map +1 -1
  19. package/lib/currencies/index.d.ts +1 -1
  20. package/lib/currencies/index.d.ts.map +1 -1
  21. package/lib/currencies/index.js +1 -2
  22. package/lib/currencies/index.js.map +1 -1
  23. package/lib/currencies/sortByMarketcap.test.js +2 -1
  24. package/lib/currencies/sortByMarketcap.test.js.map +1 -1
  25. package/lib/domain/getTokensWithFunds.test.js +1 -1
  26. package/lib/domain/getTokensWithFunds.test.js.map +1 -1
  27. package/lib/e2e/enum/AppInfos.d.ts +1 -1
  28. package/lib/e2e/enum/AppInfos.d.ts.map +1 -1
  29. package/lib/e2e/enum/Provider.d.ts.map +1 -1
  30. package/lib/e2e/enum/Provider.js +2 -2
  31. package/lib/e2e/enum/Provider.js.map +1 -1
  32. package/lib/e2e/index.d.ts +3 -0
  33. package/lib/e2e/index.d.ts.map +1 -1
  34. package/lib/e2e/speculos.d.ts.map +1 -1
  35. package/lib/e2e/speculos.js +3 -4
  36. package/lib/e2e/speculos.js.map +1 -1
  37. package/lib/e2e/speculosCI.d.ts +4 -0
  38. package/lib/e2e/speculosCI.d.ts.map +1 -1
  39. package/lib/e2e/speculosCI.js +16 -6
  40. package/lib/e2e/speculosCI.js.map +1 -1
  41. package/lib/env.react.d.ts +1 -1
  42. package/lib/env.react.d.ts.map +1 -1
  43. package/lib/families/evm/setup.d.ts.map +1 -1
  44. package/lib/families/evm/setup.js +9 -0
  45. package/lib/families/evm/setup.js.map +1 -1
  46. package/lib/families/hedera/constants.d.ts +2 -0
  47. package/lib/families/hedera/constants.d.ts.map +1 -0
  48. package/lib/families/hedera/constants.js +19 -0
  49. package/lib/families/hedera/constants.js.map +1 -0
  50. package/lib/families/hedera/setup.d.ts +5 -5
  51. package/lib/families/hedera/setup.d.ts.map +1 -1
  52. package/lib/families/hedera/setup.js.map +1 -1
  53. package/lib/families/solana/setup.d.ts.map +1 -1
  54. package/lib/families/solana/setup.js +2 -1
  55. package/lib/families/solana/setup.js.map +1 -1
  56. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
  57. package/lib/featureFlags/defaultFeatures.js +1 -0
  58. package/lib/featureFlags/defaultFeatures.js.map +1 -1
  59. package/lib/featureFlags/useFeature.d.ts +1 -1
  60. package/lib/featureFlags/useFeature.d.ts.map +1 -1
  61. package/lib/generated/bridge/js.d.ts +1 -1
  62. package/lib/market/utils/countervalueFormatter.d.ts.map +1 -1
  63. package/lib/market/utils/countervalueFormatter.js.map +1 -1
  64. package/lib/modularDrawer/__mocks__/currencies.mock.d.ts.map +1 -1
  65. package/lib/modularDrawer/__mocks__/currencies.mock.js +7 -7
  66. package/lib/modularDrawer/__mocks__/currencies.mock.js.map +1 -1
  67. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js +1 -1
  68. package/lib/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js.map +1 -1
  69. package/lib/modularDrawer/data/entities/index.d.ts +68 -0
  70. package/lib/modularDrawer/data/entities/index.d.ts.map +1 -0
  71. package/lib/modularDrawer/data/entities/index.js +3 -0
  72. package/lib/modularDrawer/data/entities/index.js.map +1 -0
  73. package/lib/modularDrawer/data/state-manager/api.d.ts +152 -0
  74. package/lib/modularDrawer/data/state-manager/api.d.ts.map +1 -0
  75. package/lib/modularDrawer/data/state-manager/api.js +45 -0
  76. package/lib/modularDrawer/data/state-manager/api.js.map +1 -0
  77. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.d.ts +5 -0
  78. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.d.ts.map +1 -0
  79. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.js +120 -0
  80. package/lib/modularDrawer/hooks/__test__/useAssetsData.test.js.map +1 -0
  81. package/lib/modularDrawer/hooks/useAssetsData.d.ts +13 -0
  82. package/lib/modularDrawer/hooks/useAssetsData.d.ts.map +1 -0
  83. package/lib/modularDrawer/hooks/useAssetsData.js +31 -0
  84. package/lib/modularDrawer/hooks/useAssetsData.js.map +1 -0
  85. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts +2 -0
  86. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts.map +1 -0
  87. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.js +496 -0
  88. package/lib/modularDrawer/utils/__tests__/counterValueFormatter.test.js.map +1 -0
  89. package/lib/modularDrawer/utils/__tests__/currencyUtils.test.js +1 -1
  90. package/lib/modularDrawer/utils/__tests__/currencyUtils.test.js.map +1 -1
  91. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js +1 -1
  92. package/lib/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js.map +1 -1
  93. package/lib/modularDrawer/utils/calculateProviderTotal.d.ts +9 -0
  94. package/lib/modularDrawer/utils/calculateProviderTotal.d.ts.map +1 -0
  95. package/lib/modularDrawer/utils/calculateProviderTotal.js +23 -0
  96. package/lib/modularDrawer/utils/calculateProviderTotal.js.map +1 -0
  97. package/lib/modularDrawer/utils/counterValueFormatter.d.ts +14 -0
  98. package/lib/modularDrawer/utils/counterValueFormatter.d.ts.map +1 -0
  99. package/lib/modularDrawer/utils/counterValueFormatter.js +107 -0
  100. package/lib/modularDrawer/utils/counterValueFormatter.js.map +1 -0
  101. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +11 -0
  102. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -0
  103. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +45 -0
  104. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -0
  105. package/lib/modularDrawer/utils/getProviderCurrency.d.ts +3 -0
  106. package/lib/modularDrawer/utils/getProviderCurrency.d.ts.map +1 -0
  107. package/lib/modularDrawer/utils/getProviderCurrency.js +14 -0
  108. package/lib/modularDrawer/utils/getProviderCurrency.js.map +1 -0
  109. package/lib/modularDrawer/utils/groupAccountsByAsset.d.ts +11 -0
  110. package/lib/modularDrawer/utils/groupAccountsByAsset.d.ts.map +1 -0
  111. package/lib/modularDrawer/utils/groupAccountsByAsset.js +32 -0
  112. package/lib/modularDrawer/utils/groupAccountsByAsset.js.map +1 -0
  113. package/lib/modularDrawer/utils/parseToBigNumber.d.ts +9 -0
  114. package/lib/modularDrawer/utils/parseToBigNumber.d.ts.map +1 -0
  115. package/lib/modularDrawer/utils/parseToBigNumber.js +24 -0
  116. package/lib/modularDrawer/utils/parseToBigNumber.js.map +1 -0
  117. package/lib/modularDrawer/utils/type.d.ts +21 -0
  118. package/lib/modularDrawer/utils/type.d.ts.map +1 -0
  119. package/lib/modularDrawer/utils/type.js +3 -0
  120. package/lib/modularDrawer/utils/type.js.map +1 -0
  121. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js +1 -1
  122. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -1
  123. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
  124. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js +6 -4
  125. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
  126. package/lib-es/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
  127. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js +2 -2
  128. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  129. package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  130. package/lib-es/bridge/generic-alpaca/prepareTransaction.js +12 -12
  131. package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  132. package/lib-es/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  133. package/lib-es/bridge/generic-alpaca/signOperation.js +3 -4
  134. package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
  135. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js +1 -1
  136. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  137. package/lib-es/bridge/generic-alpaca/utils.d.ts +0 -1
  138. package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
  139. package/lib-es/bridge/generic-alpaca/utils.js +0 -1
  140. package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
  141. package/lib-es/currencies/index.d.ts +1 -1
  142. package/lib-es/currencies/index.d.ts.map +1 -1
  143. package/lib-es/currencies/index.js +1 -1
  144. package/lib-es/currencies/index.js.map +1 -1
  145. package/lib-es/currencies/sortByMarketcap.test.js +2 -1
  146. package/lib-es/currencies/sortByMarketcap.test.js.map +1 -1
  147. package/lib-es/domain/getTokensWithFunds.test.js +1 -1
  148. package/lib-es/domain/getTokensWithFunds.test.js.map +1 -1
  149. package/lib-es/e2e/enum/AppInfos.d.ts +1 -1
  150. package/lib-es/e2e/enum/AppInfos.d.ts.map +1 -1
  151. package/lib-es/e2e/enum/Provider.d.ts.map +1 -1
  152. package/lib-es/e2e/enum/Provider.js +2 -2
  153. package/lib-es/e2e/enum/Provider.js.map +1 -1
  154. package/lib-es/e2e/index.d.ts +3 -0
  155. package/lib-es/e2e/index.d.ts.map +1 -1
  156. package/lib-es/e2e/speculos.d.ts.map +1 -1
  157. package/lib-es/e2e/speculos.js +3 -4
  158. package/lib-es/e2e/speculos.js.map +1 -1
  159. package/lib-es/e2e/speculosCI.d.ts +4 -0
  160. package/lib-es/e2e/speculosCI.d.ts.map +1 -1
  161. package/lib-es/e2e/speculosCI.js +14 -5
  162. package/lib-es/e2e/speculosCI.js.map +1 -1
  163. package/lib-es/env.react.d.ts +1 -1
  164. package/lib-es/env.react.d.ts.map +1 -1
  165. package/lib-es/families/evm/setup.d.ts.map +1 -1
  166. package/lib-es/families/evm/setup.js +9 -0
  167. package/lib-es/families/evm/setup.js.map +1 -1
  168. package/lib-es/families/hedera/constants.d.ts +2 -0
  169. package/lib-es/families/hedera/constants.d.ts.map +1 -0
  170. package/lib-es/families/hedera/constants.js +3 -0
  171. package/lib-es/families/hedera/constants.js.map +1 -0
  172. package/lib-es/families/hedera/setup.d.ts +5 -5
  173. package/lib-es/families/hedera/setup.d.ts.map +1 -1
  174. package/lib-es/families/hedera/setup.js.map +1 -1
  175. package/lib-es/families/solana/setup.d.ts.map +1 -1
  176. package/lib-es/families/solana/setup.js +2 -1
  177. package/lib-es/families/solana/setup.js.map +1 -1
  178. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
  179. package/lib-es/featureFlags/defaultFeatures.js +1 -0
  180. package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
  181. package/lib-es/featureFlags/useFeature.d.ts +1 -1
  182. package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
  183. package/lib-es/generated/bridge/js.d.ts +1 -1
  184. package/lib-es/market/utils/countervalueFormatter.d.ts.map +1 -1
  185. package/lib-es/market/utils/countervalueFormatter.js.map +1 -1
  186. package/lib-es/modularDrawer/__mocks__/currencies.mock.d.ts.map +1 -1
  187. package/lib-es/modularDrawer/__mocks__/currencies.mock.js +1 -1
  188. package/lib-es/modularDrawer/__mocks__/currencies.mock.js.map +1 -1
  189. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js +1 -1
  190. package/lib-es/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.js.map +1 -1
  191. package/lib-es/modularDrawer/data/entities/index.d.ts +68 -0
  192. package/lib-es/modularDrawer/data/entities/index.d.ts.map +1 -0
  193. package/lib-es/modularDrawer/data/entities/index.js +2 -0
  194. package/lib-es/modularDrawer/data/entities/index.js.map +1 -0
  195. package/lib-es/modularDrawer/data/state-manager/api.d.ts +152 -0
  196. package/lib-es/modularDrawer/data/state-manager/api.d.ts.map +1 -0
  197. package/lib-es/modularDrawer/data/state-manager/api.js +42 -0
  198. package/lib-es/modularDrawer/data/state-manager/api.js.map +1 -0
  199. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.d.ts +5 -0
  200. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.d.ts.map +1 -0
  201. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.js +118 -0
  202. package/lib-es/modularDrawer/hooks/__test__/useAssetsData.test.js.map +1 -0
  203. package/lib-es/modularDrawer/hooks/useAssetsData.d.ts +13 -0
  204. package/lib-es/modularDrawer/hooks/useAssetsData.d.ts.map +1 -0
  205. package/lib-es/modularDrawer/hooks/useAssetsData.js +27 -0
  206. package/lib-es/modularDrawer/hooks/useAssetsData.js.map +1 -0
  207. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts +2 -0
  208. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.d.ts.map +1 -0
  209. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.js +494 -0
  210. package/lib-es/modularDrawer/utils/__tests__/counterValueFormatter.test.js.map +1 -0
  211. package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js +1 -1
  212. package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js.map +1 -1
  213. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js +1 -1
  214. package/lib-es/modularDrawer/utils/__tests__/haveOneCommonProvider.test.js.map +1 -1
  215. package/lib-es/modularDrawer/utils/calculateProviderTotal.d.ts +9 -0
  216. package/lib-es/modularDrawer/utils/calculateProviderTotal.d.ts.map +1 -0
  217. package/lib-es/modularDrawer/utils/calculateProviderTotal.js +16 -0
  218. package/lib-es/modularDrawer/utils/calculateProviderTotal.js.map +1 -0
  219. package/lib-es/modularDrawer/utils/counterValueFormatter.d.ts +14 -0
  220. package/lib-es/modularDrawer/utils/counterValueFormatter.d.ts.map +1 -0
  221. package/lib-es/modularDrawer/utils/counterValueFormatter.js +103 -0
  222. package/lib-es/modularDrawer/utils/counterValueFormatter.js.map +1 -0
  223. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +11 -0
  224. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -0
  225. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +41 -0
  226. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -0
  227. package/lib-es/modularDrawer/utils/getProviderCurrency.d.ts +3 -0
  228. package/lib-es/modularDrawer/utils/getProviderCurrency.d.ts.map +1 -0
  229. package/lib-es/modularDrawer/utils/getProviderCurrency.js +10 -0
  230. package/lib-es/modularDrawer/utils/getProviderCurrency.js.map +1 -0
  231. package/lib-es/modularDrawer/utils/groupAccountsByAsset.d.ts +11 -0
  232. package/lib-es/modularDrawer/utils/groupAccountsByAsset.d.ts.map +1 -0
  233. package/lib-es/modularDrawer/utils/groupAccountsByAsset.js +25 -0
  234. package/lib-es/modularDrawer/utils/groupAccountsByAsset.js.map +1 -0
  235. package/lib-es/modularDrawer/utils/parseToBigNumber.d.ts +9 -0
  236. package/lib-es/modularDrawer/utils/parseToBigNumber.d.ts.map +1 -0
  237. package/lib-es/modularDrawer/utils/parseToBigNumber.js +17 -0
  238. package/lib-es/modularDrawer/utils/parseToBigNumber.js.map +1 -0
  239. package/lib-es/modularDrawer/utils/type.d.ts +21 -0
  240. package/lib-es/modularDrawer/utils/type.d.ts.map +1 -0
  241. package/lib-es/modularDrawer/utils/type.js +2 -0
  242. package/lib-es/modularDrawer/utils/type.js.map +1 -0
  243. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js +1 -1
  244. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -1
  245. package/package.json +72 -70
  246. package/src/bridge/generic-alpaca/estimateMaxSpendable.ts +11 -5
  247. package/src/bridge/generic-alpaca/getTransactionStatus.ts +2 -1
  248. package/src/bridge/generic-alpaca/prepareTransaction.ts +20 -16
  249. package/src/bridge/generic-alpaca/signOperation.ts +3 -2
  250. package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +1 -1
  251. package/src/bridge/generic-alpaca/utils.ts +0 -2
  252. package/src/currencies/index.ts +0 -1
  253. package/src/currencies/sortByMarketcap.test.ts +2 -1
  254. package/src/domain/getTokensWithFunds.test.ts +1 -1
  255. package/src/e2e/enum/AppInfos.ts +1 -1
  256. package/src/e2e/enum/Provider.ts +2 -2
  257. package/src/e2e/speculos.ts +3 -4
  258. package/src/e2e/speculosCI.ts +18 -6
  259. package/src/families/evm/setup.ts +9 -0
  260. package/src/families/hedera/__snapshots__/bridge.integration.test.ts.snap +464 -1135
  261. package/src/families/hedera/constants.ts +2 -0
  262. package/src/families/hedera/setup.ts +7 -3
  263. package/src/families/solana/setup.ts +2 -0
  264. package/src/featureFlags/defaultFeatures.ts +1 -0
  265. package/src/market/utils/countervalueFormatter.ts +0 -1
  266. package/src/modularDrawer/__mocks__/currencies.mock.ts +1 -1
  267. package/src/modularDrawer/__mocks__/useGroupedCurrenciesByProvider.mock.ts +1 -1
  268. package/src/modularDrawer/data/entities/index.ts +79 -0
  269. package/src/modularDrawer/data/state-manager/api.ts +62 -0
  270. package/src/modularDrawer/hooks/__test__/useAssetsData.test.ts +139 -0
  271. package/src/modularDrawer/hooks/useAssetsData.ts +36 -0
  272. package/src/modularDrawer/utils/__tests__/counterValueFormatter.test.ts +549 -0
  273. package/src/modularDrawer/utils/__tests__/currencyUtils.test.ts +1 -1
  274. package/src/modularDrawer/utils/__tests__/haveOneCommonProvider.test.ts +2 -2
  275. package/src/modularDrawer/utils/calculateProviderTotal.ts +23 -0
  276. package/src/modularDrawer/utils/counterValueFormatter.ts +165 -0
  277. package/src/modularDrawer/utils/getBalanceAndFiatValueByAssets.ts +76 -0
  278. package/src/modularDrawer/utils/getProviderCurrency.ts +13 -0
  279. package/src/modularDrawer/utils/groupAccountsByAsset.ts +51 -0
  280. package/src/modularDrawer/utils/parseToBigNumber.ts +17 -0
  281. package/src/modularDrawer/utils/type.ts +22 -0
  282. package/src/utils/__tests__/getAccountTuplesForCurrency.test.ts +1 -1
@@ -0,0 +1,2 @@
1
+ // Encapsulate for LLD & LLM
2
+ export * from "@ledgerhq/coin-hedera/constants";
@@ -4,17 +4,21 @@ import { createBridges } from "@ledgerhq/coin-hedera/bridge/index";
4
4
  import Transport from "@ledgerhq/hw-transport";
5
5
  import Hedera from "@ledgerhq/hw-app-hedera";
6
6
  import hederaResolver from "@ledgerhq/coin-hedera/signer/index";
7
- import type { Account, Bridge } from "@ledgerhq/types-live";
7
+ import type {
8
+ TransactionStatus,
9
+ Transaction,
10
+ HederaAccount,
11
+ } from "@ledgerhq/coin-hedera/types/index";
12
+ import type { Bridge } from "@ledgerhq/types-live";
8
13
  import makeCliTools from "@ledgerhq/coin-hedera/test/cli";
9
14
  import { CreateSigner, createResolver, executeWithSigner } from "../../bridge/setup";
10
15
  import { Resolver } from "../../hw/getAddress/types";
11
- import { TransactionStatus, Transaction } from "@ledgerhq/coin-hedera/types/index";
12
16
 
13
17
  const createSigner: CreateSigner<Hedera> = (transport: Transport) => {
14
18
  return new Hedera(transport);
15
19
  };
16
20
 
17
- const bridge: Bridge<Transaction, Account, TransactionStatus> = createBridges(
21
+ const bridge: Bridge<Transaction, HederaAccount, TransactionStatus> = createBridges(
18
22
  executeWithSigner(createSigner),
19
23
  );
20
24
 
@@ -19,6 +19,7 @@ import { SolanaCoinConfig } from "@ledgerhq/coin-solana/config";
19
19
  import { getCryptoCurrencyById } from "../../currencies";
20
20
  import { signMessage } from "@ledgerhq/coin-solana/hw-signMessage";
21
21
  import { LegacySignerSolana } from "@ledgerhq/live-signer-solana";
22
+ import { getCryptoAssetsStore } from "../../bridge/crypto-assets";
22
23
 
23
24
  const createSigner: CreateSigner<SolanaSigner> = (transport: Transport) =>
24
25
  new LegacySignerSolana(transport);
@@ -30,6 +31,7 @@ const getCurrencyConfig = () => {
30
31
  const bridge: Bridge<Transaction, SolanaAccount, TransactionStatus> = createBridges(
31
32
  executeWithSigner(createSigner),
32
33
  getCurrencyConfig,
34
+ getCryptoAssetsStore,
33
35
  );
34
36
 
35
37
  const messageSigner = {
@@ -625,6 +625,7 @@ export const DEFAULT_FEATURES: Features = {
625
625
  },
626
626
  },
627
627
  lldModularDrawerBackendData: DEFAULT_FEATURE,
628
+ llmModularDrawerBackendData: DEFAULT_FEATURE,
628
629
  llmModularDrawer: {
629
630
  ...DEFAULT_FEATURE,
630
631
  params: {
@@ -12,7 +12,6 @@ export const counterValueFormatter = ({
12
12
  if (!value) {
13
13
  return "-";
14
14
  }
15
-
16
15
  return new Intl.NumberFormat(locale, {
17
16
  style: currency ? "currency" : "decimal",
18
17
  currency,
@@ -1,5 +1,5 @@
1
- import { getCryptoCurrencyById } from "@ledgerhq/live-common/currencies/index";
2
1
  import { TokenCurrency } from "@ledgerhq/types-cryptoassets";
2
+ import { getCryptoCurrencyById } from "../../currencies";
3
3
 
4
4
  export const mockBtcCryptoCurrency = getCryptoCurrencyById("bitcoin");
5
5
  export const mockEthCryptoCurrency = getCryptoCurrencyById("ethereum");
@@ -1,4 +1,4 @@
1
- import { LoadingStatus } from "@ledgerhq/live-common/deposit/type";
1
+ import { LoadingStatus } from "../../deposit/type";
2
2
  import {
3
3
  arbitrumToken,
4
4
  mockArbitrumCryptoCurrency,
@@ -0,0 +1,79 @@
1
+ import type { CryptoOrTokenCurrency } from "@ledgerhq/types-cryptoassets";
2
+ import type { ApiAsset } from "@ledgerhq/cryptoassets";
3
+ import { PartialMarketItemResponse } from "@ledgerhq/live-common/market/utils/types";
4
+
5
+ // Types for crypto asset metadata
6
+ export interface CryptoAssetMeta {
7
+ /** Asset identifier */
8
+ id: string;
9
+ /** Asset ticker symbol */
10
+ ticker: string;
11
+ /** Asset display name */
12
+ name: string;
13
+ /** Map of network IDs to their corresponding asset IDs */
14
+ assetsIds: Record<string, string>;
15
+ }
16
+
17
+ // Types for network information
18
+ export interface NetworkInfo {
19
+ /** Network identifier */
20
+ id: string;
21
+ /** Network display name */
22
+ name: string;
23
+ }
24
+
25
+ // Types for interest rate data
26
+ export interface InterestRate {
27
+ /** Currency identifier */
28
+ currencyId: string;
29
+ /** Interest rate value */
30
+ rate: number;
31
+ /** Type of rate (NRR, APR, APY, etc.) */
32
+ type: string;
33
+ /** Timestamp when the rate was fetched */
34
+ fetchAt: string;
35
+ }
36
+
37
+ // Types for currency ordering
38
+ export interface CurrenciesOrder {
39
+ /** Sorting key (e.g., "marketCap") */
40
+ key: string;
41
+ /** Sort order (e.g., "desc") */
42
+ order: string;
43
+ /** Ordered list of currency IDs */
44
+ currenciesIds: string[];
45
+ /** Ordered list of meta-currency IDs */
46
+ metaCurrencyIds: string[];
47
+ }
48
+
49
+ // Types for raw API response (before transformation)
50
+ export interface RawApiResponse {
51
+ /** Grouped crypto assets by meta-currency */
52
+ cryptoAssets: Record<string, CryptoAssetMeta>;
53
+ /** Network information */
54
+ networks: Record<string, NetworkInfo>;
55
+ /** Raw crypto currencies and token currencies from API */
56
+ cryptoOrTokenCurrencies: Record<string, ApiAsset>;
57
+ /** Interest rates for various currencies */
58
+ interestRates: Record<string, InterestRate>;
59
+ /** Market data for currencies */
60
+ markets: Record<string, PartialMarketItemResponse>;
61
+ /** Currency ordering information */
62
+ currenciesOrder: CurrenciesOrder;
63
+ }
64
+
65
+ // Types for transformed API response (after transformation)
66
+ export interface AssetsData {
67
+ /** Grouped crypto assets by meta-currency */
68
+ cryptoAssets: Record<string, CryptoAssetMeta>;
69
+ /** Network information */
70
+ networks: Record<string, NetworkInfo>;
71
+ /** Transformed crypto currencies and token currencies compatible with Ledger Live */
72
+ cryptoOrTokenCurrencies: Record<string, CryptoOrTokenCurrency>;
73
+ /** Interest rates for various currencies */
74
+ interestRates: Record<string, InterestRate>;
75
+ /** Market data for currencies */
76
+ markets: Record<string, PartialMarketItemResponse>;
77
+ /** Currency ordering information */
78
+ currenciesOrder: CurrenciesOrder;
79
+ }
@@ -0,0 +1,62 @@
1
+ import { createApi, fetchBaseQuery, FetchBaseQueryMeta } from "@reduxjs/toolkit/query/react";
2
+ import { convertApiAssets } from "@ledgerhq/cryptoassets";
3
+ import { AssetsData, RawApiResponse } from "../entities";
4
+ import { getEnv } from "@ledgerhq/live-env";
5
+
6
+ export enum AssetsDataTags {
7
+ Assets = "Assets",
8
+ }
9
+
10
+ export interface GetAssetsDataParams {
11
+ cursor?: string;
12
+ search?: string;
13
+ currencyIds?: string[];
14
+ }
15
+
16
+ export interface AssetsDataWithPagination extends AssetsData {
17
+ pagination: {
18
+ nextCursor?: string;
19
+ };
20
+ }
21
+
22
+ function transformAssetsResponse(
23
+ response: RawApiResponse,
24
+ meta?: FetchBaseQueryMeta,
25
+ ): AssetsDataWithPagination {
26
+ const enrichedCryptoOrTokenCurrencies = convertApiAssets(response.cryptoOrTokenCurrencies);
27
+
28
+ const nextCursor = meta?.response?.headers.get("x-ledger-next") || undefined;
29
+
30
+ return {
31
+ ...response,
32
+ cryptoOrTokenCurrencies: enrichedCryptoOrTokenCurrencies,
33
+ pagination: {
34
+ nextCursor,
35
+ },
36
+ };
37
+ }
38
+
39
+ export const assetsDataApi = createApi({
40
+ reducerPath: "assetsDataApi",
41
+ baseQuery: fetchBaseQuery({
42
+ baseUrl: __DEV__ ? getEnv("DADA_API_STAGING") : getEnv("DADA_API_PROD"),
43
+ }),
44
+ tagTypes: [AssetsDataTags.Assets],
45
+ endpoints: build => ({
46
+ getAssetsData: build.query<AssetsDataWithPagination, GetAssetsDataParams>({
47
+ query: ({ cursor, search, currencyIds: _currencyIds }) => ({
48
+ url: "assets",
49
+ params: {
50
+ ...(cursor && { cursor }),
51
+ ...(search && { search }),
52
+ // ...(currencyIds && currencyIds.length > 0 && { currencyIds }),
53
+ pageSize: 100,
54
+ },
55
+ }),
56
+ providesTags: [AssetsDataTags.Assets],
57
+ transformResponse: transformAssetsResponse,
58
+ }),
59
+ }),
60
+ });
61
+
62
+ export const { useGetAssetsDataQuery } = assetsDataApi;
@@ -0,0 +1,139 @@
1
+ /**
2
+ * @jest-environment jsdom
3
+ */
4
+
5
+ import { renderHook } from "@testing-library/react";
6
+ import { useAssetsData } from "../useAssetsData";
7
+ import { useGetAssetsDataQuery } from "../../data/state-manager/api";
8
+
9
+ jest.mock("../../data/state-manager/api", () => ({
10
+ useGetAssetsDataQuery: jest.fn(),
11
+ }));
12
+
13
+ const mockSetCursor = jest.fn();
14
+ jest.mock("react", () => ({
15
+ ...jest.requireActual("react"),
16
+ useState: jest.fn(() => [undefined, mockSetCursor]),
17
+ useCallback: jest.fn(fn => fn),
18
+ useMemo: jest.fn(fn => fn()),
19
+ }));
20
+
21
+ const mockUseGetAssetsDataQuery = jest.mocked(useGetAssetsDataQuery);
22
+
23
+ describe("useAssetsData", () => {
24
+ beforeEach(() => {
25
+ jest.clearAllMocks();
26
+ });
27
+
28
+ it("should return loading state when API is loading", () => {
29
+ mockUseGetAssetsDataQuery.mockReturnValue({
30
+ data: undefined,
31
+ isLoading: true,
32
+ error: undefined,
33
+ refetch: jest.fn(),
34
+ isFetching: false,
35
+ isSuccess: false,
36
+ isError: false,
37
+ currentData: undefined,
38
+ });
39
+
40
+ const { result } = renderHook(() => useAssetsData({}));
41
+
42
+ expect(result.current.isLoading).toBe(true);
43
+ expect(result.current.data).toBe(undefined);
44
+ expect(result.current.hasMore).toBe(false);
45
+ });
46
+
47
+ it("should return data and hasMore when API returns data", () => {
48
+ const mockData = {
49
+ assetsData: [],
50
+ pagination: { nextCursor: "test-cursor" },
51
+ };
52
+ mockUseGetAssetsDataQuery.mockReturnValue({
53
+ data: mockData,
54
+ isLoading: false,
55
+ error: undefined,
56
+ refetch: jest.fn(),
57
+ isFetching: false,
58
+ isSuccess: true,
59
+ isError: false,
60
+ currentData: mockData,
61
+ });
62
+
63
+ const { result } = renderHook(() => useAssetsData({}));
64
+
65
+ expect(result.current.data).toBe(mockData);
66
+ expect(result.current.isLoading).toBe(false);
67
+ expect(result.current.hasMore).toBe(true);
68
+ });
69
+
70
+ it("should return error when API has error", () => {
71
+ const mockError = new Error("API Error");
72
+ mockUseGetAssetsDataQuery.mockReturnValue({
73
+ data: undefined,
74
+ isLoading: false,
75
+ error: mockError,
76
+ refetch: jest.fn(),
77
+ isFetching: false,
78
+ isSuccess: false,
79
+ isError: true,
80
+ currentData: undefined,
81
+ });
82
+
83
+ const { result } = renderHook(() => useAssetsData({}));
84
+
85
+ expect(result.current.error).toBe(mockError);
86
+ expect(result.current.isLoading).toBe(false);
87
+ });
88
+
89
+ it("should call setCursor when loadNext is called and there's a nextCursor", () => {
90
+ const nextCursor = "next-cursor-456";
91
+ mockUseGetAssetsDataQuery.mockReturnValue({
92
+ data: {
93
+ assetsData: [],
94
+ pagination: { nextCursor },
95
+ },
96
+ isLoading: false,
97
+ error: undefined,
98
+ refetch: jest.fn(),
99
+ isFetching: false,
100
+ isSuccess: true,
101
+ isError: false,
102
+ currentData: {
103
+ assetsData: [],
104
+ pagination: { nextCursor },
105
+ },
106
+ });
107
+
108
+ const { result } = renderHook(() => useAssetsData({}));
109
+
110
+ result.current.loadNext();
111
+
112
+ expect(mockSetCursor).toHaveBeenCalledWith(nextCursor);
113
+ });
114
+
115
+ it("should not call setCursor when there's no nextCursor", () => {
116
+ mockUseGetAssetsDataQuery.mockReturnValue({
117
+ data: {
118
+ assetsData: [],
119
+ pagination: { nextCursor: undefined },
120
+ },
121
+ isLoading: false,
122
+ error: undefined,
123
+ refetch: jest.fn(),
124
+ isFetching: false,
125
+ isSuccess: true,
126
+ isError: false,
127
+ currentData: {
128
+ assetsData: [],
129
+ pagination: { nextCursor: undefined },
130
+ },
131
+ });
132
+
133
+ const { result } = renderHook(() => useAssetsData({}));
134
+
135
+ result.current.loadNext();
136
+
137
+ expect(mockSetCursor).not.toHaveBeenCalled();
138
+ });
139
+ });
@@ -0,0 +1,36 @@
1
+ import { useState, useCallback } from "react";
2
+ import { useGetAssetsDataQuery } from "../data/state-manager/api";
3
+
4
+ export function useAssetsData({
5
+ search,
6
+ currencyIds,
7
+ }: {
8
+ search?: string;
9
+ currencyIds?: string[];
10
+ }) {
11
+ const [cursor, setCursor] = useState<string | undefined>(undefined);
12
+ const { data, error, isLoading, isSuccess } = useGetAssetsDataQuery({
13
+ cursor,
14
+ search,
15
+ currencyIds,
16
+ });
17
+
18
+ const loadNext = useCallback(() => {
19
+ const nextCursor = data?.pagination?.nextCursor;
20
+ if (nextCursor) {
21
+ setCursor(nextCursor);
22
+ }
23
+ }, [data?.pagination?.nextCursor]);
24
+
25
+ const hasMore = Boolean(data?.pagination?.nextCursor);
26
+
27
+ return {
28
+ data,
29
+ error,
30
+ isLoading,
31
+ isSuccess,
32
+ hasMore,
33
+ cursor,
34
+ loadNext,
35
+ };
36
+ }