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

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 (531) hide show
  1. package/lib/bridge/crypto-assets/index.d.ts.map +1 -1
  2. package/lib/bridge/crypto-assets/index.js +0 -2
  3. package/lib/bridge/crypto-assets/index.js.map +1 -1
  4. package/lib/bridge/crypto-assets/index.test.js +0 -4
  5. package/lib/bridge/crypto-assets/index.test.js.map +1 -1
  6. package/lib/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
  7. package/lib/bridge/generic-alpaca/accountBridge.js +2 -0
  8. package/lib/bridge/generic-alpaca/accountBridge.js.map +1 -1
  9. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +1 -0
  10. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
  11. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js +3 -0
  12. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
  13. package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  14. package/lib/bridge/generic-alpaca/prepareTransaction.js +37 -45
  15. package/lib/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  16. package/lib/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  17. package/lib/bridge/generic-alpaca/signOperation.js +0 -20
  18. package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
  19. package/lib/bridge/generic-alpaca/signRawOperation.d.ts +8 -0
  20. package/lib/bridge/generic-alpaca/signRawOperation.d.ts.map +1 -0
  21. package/lib/bridge/generic-alpaca/signRawOperation.js +55 -0
  22. package/lib/bridge/generic-alpaca/signRawOperation.js.map +1 -0
  23. package/lib/bridge/generic-alpaca/tests/getAccountShape.test.js +1 -0
  24. package/lib/bridge/generic-alpaca/tests/getAccountShape.test.js.map +1 -1
  25. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js +186 -88
  26. package/lib/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  27. package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
  28. package/lib/bridge/generic-alpaca/utils.js +1 -0
  29. package/lib/bridge/generic-alpaca/utils.js.map +1 -1
  30. package/lib/bridge/mockHelpers.d.ts +1 -0
  31. package/lib/bridge/mockHelpers.d.ts.map +1 -1
  32. package/lib/bridge/mockHelpers.js +53 -1
  33. package/lib/bridge/mockHelpers.js.map +1 -1
  34. package/lib/bridge/react/BridgeSync.d.ts +1 -0
  35. package/lib/bridge/react/BridgeSync.d.ts.map +1 -1
  36. package/lib/bridge/react/BridgeSync.js +19 -16
  37. package/lib/bridge/react/BridgeSync.js.map +1 -1
  38. package/lib/bridge/react/BridgeSync.test.js +403 -66
  39. package/lib/bridge/react/BridgeSync.test.js.map +1 -1
  40. package/lib/currencies/index.d.ts +1 -1
  41. package/lib/currencies/index.d.ts.map +1 -1
  42. package/lib/currencies/index.js +2 -3
  43. package/lib/currencies/index.js.map +1 -1
  44. package/lib/currencies/sortByMarketcap.test.js +1 -3
  45. package/lib/currencies/sortByMarketcap.test.js.map +1 -1
  46. package/lib/dada-client/entities/index.d.ts +1 -1
  47. package/lib/dada-client/entities/index.d.ts.map +1 -1
  48. package/lib/e2e/enum/Account.d.ts +4 -0
  49. package/lib/e2e/enum/Account.d.ts.map +1 -1
  50. package/lib/e2e/enum/Account.js +4 -0
  51. package/lib/e2e/enum/Account.js.map +1 -1
  52. package/lib/e2e/enum/AppInfos.d.ts +1 -0
  53. package/lib/e2e/enum/AppInfos.d.ts.map +1 -1
  54. package/lib/e2e/enum/AppInfos.js +1 -0
  55. package/lib/e2e/enum/AppInfos.js.map +1 -1
  56. package/lib/e2e/enum/Currency.d.ts +2 -0
  57. package/lib/e2e/enum/Currency.d.ts.map +1 -1
  58. package/lib/e2e/enum/Currency.js +2 -0
  59. package/lib/e2e/enum/Currency.js.map +1 -1
  60. package/lib/e2e/enum/Network.d.ts +2 -1
  61. package/lib/e2e/enum/Network.d.ts.map +1 -1
  62. package/lib/e2e/enum/Network.js +1 -0
  63. package/lib/e2e/enum/Network.js.map +1 -1
  64. package/lib/e2e/enum/TokenType.d.ts +2 -1
  65. package/lib/e2e/enum/TokenType.d.ts.map +1 -1
  66. package/lib/e2e/enum/TokenType.js +1 -0
  67. package/lib/e2e/enum/TokenType.js.map +1 -1
  68. package/lib/e2e/enum/TransactionStatus.d.ts +4 -1
  69. package/lib/e2e/enum/TransactionStatus.d.ts.map +1 -1
  70. package/lib/e2e/enum/TransactionStatus.js +3 -0
  71. package/lib/e2e/enum/TransactionStatus.js.map +1 -1
  72. package/lib/e2e/families/sui.d.ts +2 -0
  73. package/lib/e2e/families/sui.d.ts.map +1 -0
  74. package/lib/e2e/families/sui.js +11 -0
  75. package/lib/e2e/families/sui.js.map +1 -0
  76. package/lib/e2e/index.d.ts +11 -0
  77. package/lib/e2e/index.d.ts.map +1 -1
  78. package/lib/e2e/speculos.d.ts +1 -0
  79. package/lib/e2e/speculos.d.ts.map +1 -1
  80. package/lib/e2e/speculos.js +23 -1
  81. package/lib/e2e/speculos.js.map +1 -1
  82. package/lib/env.react.d.ts +1 -1
  83. package/lib/env.react.d.ts.map +1 -1
  84. package/lib/exchange/providers/swap.js +4 -4
  85. package/lib/exchange/providers/swap.js.map +1 -1
  86. package/lib/exchange/swap/api/v5/__mocks__/fetchRates.mocks.d.ts.map +1 -1
  87. package/lib/exchange/swap/api/v5/__mocks__/fetchRates.mocks.js +1 -1
  88. package/lib/exchange/swap/api/v5/__mocks__/fetchRates.mocks.js.map +1 -1
  89. package/lib/exchange/swap/mock.js +1 -1
  90. package/lib/exchange/swap/mock.js.map +1 -1
  91. package/lib/families/algorand/bridge/mock.d.ts.map +1 -1
  92. package/lib/families/algorand/bridge/mock.js +1 -0
  93. package/lib/families/algorand/bridge/mock.js.map +1 -1
  94. package/lib/families/bitcoin/bridge/mock.d.ts.map +1 -1
  95. package/lib/families/bitcoin/bridge/mock.js +1 -0
  96. package/lib/families/bitcoin/bridge/mock.js.map +1 -1
  97. package/lib/families/canton/bridge/mock.d.ts.map +1 -1
  98. package/lib/families/canton/bridge/mock.js +3 -0
  99. package/lib/families/canton/bridge/mock.js.map +1 -1
  100. package/lib/families/cardano/bridge/mock.d.ts.map +1 -1
  101. package/lib/families/cardano/bridge/mock.js +1 -0
  102. package/lib/families/cardano/bridge/mock.js.map +1 -1
  103. package/lib/families/casper/bridge/mock.d.ts.map +1 -1
  104. package/lib/families/casper/bridge/mock.js +1 -0
  105. package/lib/families/casper/bridge/mock.js.map +1 -1
  106. package/lib/families/cosmos/bridge/mock.d.ts.map +1 -1
  107. package/lib/families/cosmos/bridge/mock.js +1 -0
  108. package/lib/families/cosmos/bridge/mock.js.map +1 -1
  109. package/lib/families/evm/bridge/mock.d.ts.map +1 -1
  110. package/lib/families/evm/bridge/mock.js +1 -0
  111. package/lib/families/evm/bridge/mock.js.map +1 -1
  112. package/lib/families/icon/bridge/mock.d.ts.map +1 -1
  113. package/lib/families/icon/bridge/mock.js +1 -0
  114. package/lib/families/icon/bridge/mock.js.map +1 -1
  115. package/lib/families/multiversx/bridge/mock.d.ts.map +1 -1
  116. package/lib/families/multiversx/bridge/mock.js +1 -0
  117. package/lib/families/multiversx/bridge/mock.js.map +1 -1
  118. package/lib/families/polkadot/bridge/mock.d.ts.map +1 -1
  119. package/lib/families/polkadot/bridge/mock.js +1 -0
  120. package/lib/families/polkadot/bridge/mock.js.map +1 -1
  121. package/lib/families/polkadot/config.d.ts.map +1 -1
  122. package/lib/families/polkadot/config.js +84 -0
  123. package/lib/families/polkadot/config.js.map +1 -1
  124. package/lib/families/polkadot/setup.d.ts.map +1 -1
  125. package/lib/families/polkadot/setup.js +5 -4
  126. package/lib/families/polkadot/setup.js.map +1 -1
  127. package/lib/families/solana/bridge/mock.d.ts +1 -0
  128. package/lib/families/solana/bridge/mock.d.ts.map +1 -1
  129. package/lib/families/stellar/bridge/mock.d.ts.map +1 -1
  130. package/lib/families/stellar/bridge/mock.js +1 -0
  131. package/lib/families/stellar/bridge/mock.js.map +1 -1
  132. package/lib/families/tezos/bridge/mock.d.ts.map +1 -1
  133. package/lib/families/tezos/bridge/mock.js +1 -0
  134. package/lib/families/tezos/bridge/mock.js.map +1 -1
  135. package/lib/families/tron/bridge/mock.d.ts.map +1 -1
  136. package/lib/families/tron/bridge/mock.js +1 -0
  137. package/lib/families/tron/bridge/mock.js.map +1 -1
  138. package/lib/families/xrp/bridge/mock.d.ts.map +1 -1
  139. package/lib/families/xrp/bridge/mock.js +1 -0
  140. package/lib/families/xrp/bridge/mock.js.map +1 -1
  141. package/lib/featureFlags/defaultFeatures.d.ts +3 -0
  142. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
  143. package/lib/featureFlags/defaultFeatures.js +14 -1
  144. package/lib/featureFlags/defaultFeatures.js.map +1 -1
  145. package/lib/featureFlags/useFeature.d.ts +1 -1
  146. package/lib/featureFlags/useFeature.d.ts.map +1 -1
  147. package/lib/generated/bridge/mock.d.ts +1 -0
  148. package/lib/generated/bridge/mock.d.ts.map +1 -1
  149. package/lib/hooks/useManifestWithSessionId.d.ts +12 -0
  150. package/lib/hooks/useManifestWithSessionId.d.ts.map +1 -0
  151. package/lib/hooks/useManifestWithSessionId.js +67 -0
  152. package/lib/hooks/useManifestWithSessionId.js.map +1 -0
  153. package/lib/hooks/useManifestWithSessionId.test.d.ts +2 -0
  154. package/lib/hooks/useManifestWithSessionId.test.d.ts.map +1 -0
  155. package/lib/hooks/useManifestWithSessionId.test.js +71 -0
  156. package/lib/hooks/useManifestWithSessionId.test.js.map +1 -0
  157. package/lib/hw/actions/rawTransaction.d.ts +37 -0
  158. package/lib/hw/actions/rawTransaction.d.ts.map +1 -0
  159. package/lib/hw/actions/rawTransaction.js +107 -0
  160. package/lib/hw/actions/rawTransaction.js.map +1 -0
  161. package/lib/market/utils/index.d.ts +1 -0
  162. package/lib/market/utils/index.d.ts.map +1 -1
  163. package/lib/market/utils/index.js +16 -0
  164. package/lib/market/utils/index.js.map +1 -1
  165. package/lib/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.d.ts +2 -0
  166. package/lib/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.d.ts.map +1 -0
  167. package/lib/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.js +350 -0
  168. package/lib/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.js.map +1 -0
  169. package/lib/modularDrawer/hooks/index.d.ts +2 -0
  170. package/lib/modularDrawer/hooks/index.d.ts.map +1 -0
  171. package/lib/modularDrawer/hooks/index.js +6 -0
  172. package/lib/modularDrawer/hooks/index.js.map +1 -0
  173. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
  174. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +9 -0
  175. package/lib/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
  176. package/lib/modularDrawer/hooks/useDetailedAccountsCore.d.ts +14 -0
  177. package/lib/modularDrawer/hooks/useDetailedAccountsCore.d.ts.map +1 -0
  178. package/lib/modularDrawer/hooks/useDetailedAccountsCore.js +119 -0
  179. package/lib/modularDrawer/hooks/useDetailedAccountsCore.js.map +1 -0
  180. package/lib/modularDrawer/hooks/useRightBalanceAsset.d.ts.map +1 -1
  181. package/lib/modularDrawer/hooks/useRightBalanceAsset.js +9 -1
  182. package/lib/modularDrawer/hooks/useRightBalanceAsset.js.map +1 -1
  183. package/lib/modularDrawer/hooks/useRightBalanceNetwork.d.ts +6 -1
  184. package/lib/modularDrawer/hooks/useRightBalanceNetwork.d.ts.map +1 -1
  185. package/lib/modularDrawer/hooks/useRightBalanceNetwork.js +12 -4
  186. package/lib/modularDrawer/hooks/useRightBalanceNetwork.js.map +1 -1
  187. package/lib/modularDrawer/index.d.ts +4 -0
  188. package/lib/modularDrawer/index.d.ts.map +1 -0
  189. package/lib/modularDrawer/index.js +20 -0
  190. package/lib/modularDrawer/index.js.map +1 -0
  191. package/lib/modularDrawer/types/detailedAccount.d.ts +46 -0
  192. package/lib/modularDrawer/types/detailedAccount.d.ts.map +1 -0
  193. package/lib/modularDrawer/types/detailedAccount.js +3 -0
  194. package/lib/modularDrawer/types/detailedAccount.js.map +1 -0
  195. package/lib/modularDrawer/types/index.d.ts +2 -0
  196. package/lib/modularDrawer/types/index.d.ts.map +1 -0
  197. package/lib/modularDrawer/types/index.js +18 -0
  198. package/lib/modularDrawer/types/index.js.map +1 -0
  199. package/lib/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.d.ts +2 -0
  200. package/lib/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.d.ts.map +1 -0
  201. package/lib/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.js +106 -0
  202. package/lib/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.js.map +1 -0
  203. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +3 -4
  204. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -1
  205. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +7 -0
  206. package/lib/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -1
  207. package/lib/modularDrawer/utils/index.d.ts +1 -0
  208. package/lib/modularDrawer/utils/index.d.ts.map +1 -1
  209. package/lib/modularDrawer/utils/index.js +3 -1
  210. package/lib/modularDrawer/utils/index.js.map +1 -1
  211. package/lib/modularDrawer/utils/sortAccountsByFiatValue.d.ts +8 -0
  212. package/lib/modularDrawer/utils/sortAccountsByFiatValue.d.ts.map +1 -0
  213. package/lib/modularDrawer/utils/sortAccountsByFiatValue.js +17 -0
  214. package/lib/modularDrawer/utils/sortAccountsByFiatValue.js.map +1 -0
  215. package/lib/modularDrawer/utils/type.d.ts +2 -2
  216. package/lib/modularDrawer/utils/type.d.ts.map +1 -1
  217. package/lib/platform/providers/RemoteLiveAppProvider/api/mock.json +3 -3
  218. package/lib/wallet-api/logic.d.ts +1 -0
  219. package/lib/wallet-api/logic.d.ts.map +1 -1
  220. package/lib/wallet-api/logic.js +21 -1
  221. package/lib/wallet-api/logic.js.map +1 -1
  222. package/lib/wallet-api/react.d.ts +9 -1
  223. package/lib/wallet-api/react.d.ts.map +1 -1
  224. package/lib/wallet-api/react.js +60 -2
  225. package/lib/wallet-api/react.js.map +1 -1
  226. package/lib/wallet-api/tracking.d.ts +3 -0
  227. package/lib/wallet-api/tracking.d.ts.map +1 -1
  228. package/lib/wallet-api/tracking.js +12 -0
  229. package/lib/wallet-api/tracking.js.map +1 -1
  230. package/lib/wallet-api/useDappLogic.js +1 -1
  231. package/lib/wallet-api/useDappLogic.js.map +1 -1
  232. package/lib-es/bridge/crypto-assets/index.d.ts.map +1 -1
  233. package/lib-es/bridge/crypto-assets/index.js +0 -2
  234. package/lib-es/bridge/crypto-assets/index.js.map +1 -1
  235. package/lib-es/bridge/crypto-assets/index.test.js +0 -4
  236. package/lib-es/bridge/crypto-assets/index.test.js.map +1 -1
  237. package/lib-es/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
  238. package/lib-es/bridge/generic-alpaca/accountBridge.js +2 -0
  239. package/lib-es/bridge/generic-alpaca/accountBridge.js.map +1 -1
  240. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +1 -0
  241. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
  242. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js +3 -0
  243. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
  244. package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  245. package/lib-es/bridge/generic-alpaca/prepareTransaction.js +37 -45
  246. package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  247. package/lib-es/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  248. package/lib-es/bridge/generic-alpaca/signOperation.js +0 -17
  249. package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
  250. package/lib-es/bridge/generic-alpaca/signRawOperation.d.ts +8 -0
  251. package/lib-es/bridge/generic-alpaca/signRawOperation.d.ts.map +1 -0
  252. package/lib-es/bridge/generic-alpaca/signRawOperation.js +48 -0
  253. package/lib-es/bridge/generic-alpaca/signRawOperation.js.map +1 -0
  254. package/lib-es/bridge/generic-alpaca/tests/getAccountShape.test.js +1 -0
  255. package/lib-es/bridge/generic-alpaca/tests/getAccountShape.test.js.map +1 -1
  256. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js +163 -88
  257. package/lib-es/bridge/generic-alpaca/tests/prepareTransaction.test.js.map +1 -1
  258. package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
  259. package/lib-es/bridge/generic-alpaca/utils.js +1 -0
  260. package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
  261. package/lib-es/bridge/mockHelpers.d.ts +1 -0
  262. package/lib-es/bridge/mockHelpers.d.ts.map +1 -1
  263. package/lib-es/bridge/mockHelpers.js +51 -0
  264. package/lib-es/bridge/mockHelpers.js.map +1 -1
  265. package/lib-es/bridge/react/BridgeSync.d.ts +1 -0
  266. package/lib-es/bridge/react/BridgeSync.d.ts.map +1 -1
  267. package/lib-es/bridge/react/BridgeSync.js +17 -15
  268. package/lib-es/bridge/react/BridgeSync.js.map +1 -1
  269. package/lib-es/bridge/react/BridgeSync.test.js +382 -65
  270. package/lib-es/bridge/react/BridgeSync.test.js.map +1 -1
  271. package/lib-es/currencies/index.d.ts +1 -1
  272. package/lib-es/currencies/index.d.ts.map +1 -1
  273. package/lib-es/currencies/index.js +1 -1
  274. package/lib-es/currencies/index.js.map +1 -1
  275. package/lib-es/currencies/sortByMarketcap.test.js +1 -3
  276. package/lib-es/currencies/sortByMarketcap.test.js.map +1 -1
  277. package/lib-es/dada-client/entities/index.d.ts +1 -1
  278. package/lib-es/dada-client/entities/index.d.ts.map +1 -1
  279. package/lib-es/e2e/enum/Account.d.ts +4 -0
  280. package/lib-es/e2e/enum/Account.d.ts.map +1 -1
  281. package/lib-es/e2e/enum/Account.js +4 -0
  282. package/lib-es/e2e/enum/Account.js.map +1 -1
  283. package/lib-es/e2e/enum/AppInfos.d.ts +1 -0
  284. package/lib-es/e2e/enum/AppInfos.d.ts.map +1 -1
  285. package/lib-es/e2e/enum/AppInfos.js +1 -0
  286. package/lib-es/e2e/enum/AppInfos.js.map +1 -1
  287. package/lib-es/e2e/enum/Currency.d.ts +2 -0
  288. package/lib-es/e2e/enum/Currency.d.ts.map +1 -1
  289. package/lib-es/e2e/enum/Currency.js +2 -0
  290. package/lib-es/e2e/enum/Currency.js.map +1 -1
  291. package/lib-es/e2e/enum/Network.d.ts +2 -1
  292. package/lib-es/e2e/enum/Network.d.ts.map +1 -1
  293. package/lib-es/e2e/enum/Network.js +1 -0
  294. package/lib-es/e2e/enum/Network.js.map +1 -1
  295. package/lib-es/e2e/enum/TokenType.d.ts +2 -1
  296. package/lib-es/e2e/enum/TokenType.d.ts.map +1 -1
  297. package/lib-es/e2e/enum/TokenType.js +1 -0
  298. package/lib-es/e2e/enum/TokenType.js.map +1 -1
  299. package/lib-es/e2e/enum/TransactionStatus.d.ts +4 -1
  300. package/lib-es/e2e/enum/TransactionStatus.d.ts.map +1 -1
  301. package/lib-es/e2e/enum/TransactionStatus.js +3 -0
  302. package/lib-es/e2e/enum/TransactionStatus.js.map +1 -1
  303. package/lib-es/e2e/families/sui.d.ts +2 -0
  304. package/lib-es/e2e/families/sui.d.ts.map +1 -0
  305. package/lib-es/e2e/families/sui.js +7 -0
  306. package/lib-es/e2e/families/sui.js.map +1 -0
  307. package/lib-es/e2e/index.d.ts +11 -0
  308. package/lib-es/e2e/index.d.ts.map +1 -1
  309. package/lib-es/e2e/speculos.d.ts +1 -0
  310. package/lib-es/e2e/speculos.d.ts.map +1 -1
  311. package/lib-es/e2e/speculos.js +21 -0
  312. package/lib-es/e2e/speculos.js.map +1 -1
  313. package/lib-es/env.react.d.ts +1 -1
  314. package/lib-es/env.react.d.ts.map +1 -1
  315. package/lib-es/exchange/providers/swap.js +4 -4
  316. package/lib-es/exchange/providers/swap.js.map +1 -1
  317. package/lib-es/exchange/swap/api/v5/__mocks__/fetchRates.mocks.d.ts.map +1 -1
  318. package/lib-es/exchange/swap/api/v5/__mocks__/fetchRates.mocks.js +1 -1
  319. package/lib-es/exchange/swap/api/v5/__mocks__/fetchRates.mocks.js.map +1 -1
  320. package/lib-es/exchange/swap/mock.js +1 -1
  321. package/lib-es/exchange/swap/mock.js.map +1 -1
  322. package/lib-es/families/algorand/bridge/mock.d.ts.map +1 -1
  323. package/lib-es/families/algorand/bridge/mock.js +2 -1
  324. package/lib-es/families/algorand/bridge/mock.js.map +1 -1
  325. package/lib-es/families/bitcoin/bridge/mock.d.ts.map +1 -1
  326. package/lib-es/families/bitcoin/bridge/mock.js +2 -1
  327. package/lib-es/families/bitcoin/bridge/mock.js.map +1 -1
  328. package/lib-es/families/canton/bridge/mock.d.ts.map +1 -1
  329. package/lib-es/families/canton/bridge/mock.js +3 -0
  330. package/lib-es/families/canton/bridge/mock.js.map +1 -1
  331. package/lib-es/families/cardano/bridge/mock.d.ts.map +1 -1
  332. package/lib-es/families/cardano/bridge/mock.js +2 -1
  333. package/lib-es/families/cardano/bridge/mock.js.map +1 -1
  334. package/lib-es/families/casper/bridge/mock.d.ts.map +1 -1
  335. package/lib-es/families/casper/bridge/mock.js +2 -1
  336. package/lib-es/families/casper/bridge/mock.js.map +1 -1
  337. package/lib-es/families/cosmos/bridge/mock.d.ts.map +1 -1
  338. package/lib-es/families/cosmos/bridge/mock.js +2 -1
  339. package/lib-es/families/cosmos/bridge/mock.js.map +1 -1
  340. package/lib-es/families/evm/bridge/mock.d.ts.map +1 -1
  341. package/lib-es/families/evm/bridge/mock.js +2 -1
  342. package/lib-es/families/evm/bridge/mock.js.map +1 -1
  343. package/lib-es/families/icon/bridge/mock.d.ts.map +1 -1
  344. package/lib-es/families/icon/bridge/mock.js +2 -1
  345. package/lib-es/families/icon/bridge/mock.js.map +1 -1
  346. package/lib-es/families/multiversx/bridge/mock.d.ts.map +1 -1
  347. package/lib-es/families/multiversx/bridge/mock.js +2 -1
  348. package/lib-es/families/multiversx/bridge/mock.js.map +1 -1
  349. package/lib-es/families/polkadot/bridge/mock.d.ts.map +1 -1
  350. package/lib-es/families/polkadot/bridge/mock.js +2 -1
  351. package/lib-es/families/polkadot/bridge/mock.js.map +1 -1
  352. package/lib-es/families/polkadot/config.d.ts.map +1 -1
  353. package/lib-es/families/polkadot/config.js +84 -0
  354. package/lib-es/families/polkadot/config.js.map +1 -1
  355. package/lib-es/families/polkadot/setup.d.ts.map +1 -1
  356. package/lib-es/families/polkadot/setup.js +5 -4
  357. package/lib-es/families/polkadot/setup.js.map +1 -1
  358. package/lib-es/families/solana/bridge/mock.d.ts +1 -0
  359. package/lib-es/families/solana/bridge/mock.d.ts.map +1 -1
  360. package/lib-es/families/stellar/bridge/mock.d.ts.map +1 -1
  361. package/lib-es/families/stellar/bridge/mock.js +2 -1
  362. package/lib-es/families/stellar/bridge/mock.js.map +1 -1
  363. package/lib-es/families/tezos/bridge/mock.d.ts.map +1 -1
  364. package/lib-es/families/tezos/bridge/mock.js +2 -1
  365. package/lib-es/families/tezos/bridge/mock.js.map +1 -1
  366. package/lib-es/families/tron/bridge/mock.d.ts.map +1 -1
  367. package/lib-es/families/tron/bridge/mock.js +2 -1
  368. package/lib-es/families/tron/bridge/mock.js.map +1 -1
  369. package/lib-es/families/xrp/bridge/mock.d.ts.map +1 -1
  370. package/lib-es/families/xrp/bridge/mock.js +2 -1
  371. package/lib-es/families/xrp/bridge/mock.js.map +1 -1
  372. package/lib-es/featureFlags/defaultFeatures.d.ts +3 -0
  373. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
  374. package/lib-es/featureFlags/defaultFeatures.js +14 -1
  375. package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
  376. package/lib-es/featureFlags/useFeature.d.ts +1 -1
  377. package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
  378. package/lib-es/generated/bridge/mock.d.ts +1 -0
  379. package/lib-es/generated/bridge/mock.d.ts.map +1 -1
  380. package/lib-es/hooks/useManifestWithSessionId.d.ts +12 -0
  381. package/lib-es/hooks/useManifestWithSessionId.d.ts.map +1 -0
  382. package/lib-es/hooks/useManifestWithSessionId.js +60 -0
  383. package/lib-es/hooks/useManifestWithSessionId.js.map +1 -0
  384. package/lib-es/hooks/useManifestWithSessionId.test.d.ts +2 -0
  385. package/lib-es/hooks/useManifestWithSessionId.test.d.ts.map +1 -0
  386. package/lib-es/hooks/useManifestWithSessionId.test.js +69 -0
  387. package/lib-es/hooks/useManifestWithSessionId.test.js.map +1 -0
  388. package/lib-es/hw/actions/rawTransaction.d.ts +37 -0
  389. package/lib-es/hw/actions/rawTransaction.d.ts.map +1 -0
  390. package/lib-es/hw/actions/rawTransaction.js +103 -0
  391. package/lib-es/hw/actions/rawTransaction.js.map +1 -0
  392. package/lib-es/market/utils/index.d.ts +1 -0
  393. package/lib-es/market/utils/index.d.ts.map +1 -1
  394. package/lib-es/market/utils/index.js +2 -0
  395. package/lib-es/market/utils/index.js.map +1 -1
  396. package/lib-es/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.d.ts +2 -0
  397. package/lib-es/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.d.ts.map +1 -0
  398. package/lib-es/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.js +345 -0
  399. package/lib-es/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.js.map +1 -0
  400. package/lib-es/modularDrawer/hooks/index.d.ts +2 -0
  401. package/lib-es/modularDrawer/hooks/index.d.ts.map +1 -0
  402. package/lib-es/modularDrawer/hooks/index.js +2 -0
  403. package/lib-es/modularDrawer/hooks/index.js.map +1 -0
  404. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.d.ts.map +1 -1
  405. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js +9 -0
  406. package/lib-es/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.js.map +1 -1
  407. package/lib-es/modularDrawer/hooks/useDetailedAccountsCore.d.ts +14 -0
  408. package/lib-es/modularDrawer/hooks/useDetailedAccountsCore.d.ts.map +1 -0
  409. package/lib-es/modularDrawer/hooks/useDetailedAccountsCore.js +115 -0
  410. package/lib-es/modularDrawer/hooks/useDetailedAccountsCore.js.map +1 -0
  411. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.d.ts.map +1 -1
  412. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.js +6 -1
  413. package/lib-es/modularDrawer/hooks/useRightBalanceAsset.js.map +1 -1
  414. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.d.ts +6 -1
  415. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.d.ts.map +1 -1
  416. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.js +9 -4
  417. package/lib-es/modularDrawer/hooks/useRightBalanceNetwork.js.map +1 -1
  418. package/lib-es/modularDrawer/index.d.ts +4 -0
  419. package/lib-es/modularDrawer/index.d.ts.map +1 -0
  420. package/lib-es/modularDrawer/index.js +4 -0
  421. package/lib-es/modularDrawer/index.js.map +1 -0
  422. package/lib-es/modularDrawer/types/detailedAccount.d.ts +46 -0
  423. package/lib-es/modularDrawer/types/detailedAccount.d.ts.map +1 -0
  424. package/lib-es/modularDrawer/types/detailedAccount.js +2 -0
  425. package/lib-es/modularDrawer/types/detailedAccount.js.map +1 -0
  426. package/lib-es/modularDrawer/types/index.d.ts +2 -0
  427. package/lib-es/modularDrawer/types/index.d.ts.map +1 -0
  428. package/lib-es/modularDrawer/types/index.js +2 -0
  429. package/lib-es/modularDrawer/types/index.js.map +1 -0
  430. package/lib-es/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.d.ts +2 -0
  431. package/lib-es/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.d.ts.map +1 -0
  432. package/lib-es/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.js +101 -0
  433. package/lib-es/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.js.map +1 -0
  434. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts +3 -4
  435. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.d.ts.map +1 -1
  436. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js +4 -0
  437. package/lib-es/modularDrawer/utils/getBalanceAndFiatValueByAssets.js.map +1 -1
  438. package/lib-es/modularDrawer/utils/index.d.ts +1 -0
  439. package/lib-es/modularDrawer/utils/index.d.ts.map +1 -1
  440. package/lib-es/modularDrawer/utils/index.js +1 -0
  441. package/lib-es/modularDrawer/utils/index.js.map +1 -1
  442. package/lib-es/modularDrawer/utils/sortAccountsByFiatValue.d.ts +8 -0
  443. package/lib-es/modularDrawer/utils/sortAccountsByFiatValue.d.ts.map +1 -0
  444. package/lib-es/modularDrawer/utils/sortAccountsByFiatValue.js +13 -0
  445. package/lib-es/modularDrawer/utils/sortAccountsByFiatValue.js.map +1 -0
  446. package/lib-es/modularDrawer/utils/type.d.ts +2 -2
  447. package/lib-es/modularDrawer/utils/type.d.ts.map +1 -1
  448. package/lib-es/platform/providers/RemoteLiveAppProvider/api/mock.json +3 -3
  449. package/lib-es/wallet-api/logic.d.ts +1 -0
  450. package/lib-es/wallet-api/logic.d.ts.map +1 -1
  451. package/lib-es/wallet-api/logic.js +19 -0
  452. package/lib-es/wallet-api/logic.js.map +1 -1
  453. package/lib-es/wallet-api/react.d.ts +9 -1
  454. package/lib-es/wallet-api/react.d.ts.map +1 -1
  455. package/lib-es/wallet-api/react.js +61 -3
  456. package/lib-es/wallet-api/react.js.map +1 -1
  457. package/lib-es/wallet-api/tracking.d.ts +3 -0
  458. package/lib-es/wallet-api/tracking.d.ts.map +1 -1
  459. package/lib-es/wallet-api/tracking.js +12 -0
  460. package/lib-es/wallet-api/tracking.js.map +1 -1
  461. package/lib-es/wallet-api/useDappLogic.js +2 -2
  462. package/lib-es/wallet-api/useDappLogic.js.map +1 -1
  463. package/package.json +59 -59
  464. package/src/bridge/crypto-assets/index.test.ts +0 -4
  465. package/src/bridge/crypto-assets/index.ts +0 -2
  466. package/src/bridge/generic-alpaca/accountBridge.ts +2 -0
  467. package/src/bridge/generic-alpaca/alpaca/network/network-alpaca.ts +8 -0
  468. package/src/bridge/generic-alpaca/prepareTransaction.ts +46 -69
  469. package/src/bridge/generic-alpaca/signOperation.ts +0 -20
  470. package/src/bridge/generic-alpaca/signRawOperation.ts +86 -0
  471. package/src/bridge/generic-alpaca/tests/getAccountShape.test.ts +1 -0
  472. package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +191 -109
  473. package/src/bridge/generic-alpaca/utils.ts +1 -0
  474. package/src/bridge/mockHelpers.ts +57 -0
  475. package/src/bridge/react/BridgeSync.test.tsx +513 -82
  476. package/src/bridge/react/BridgeSync.tsx +18 -17
  477. package/src/currencies/index.ts +1 -2
  478. package/src/currencies/sortByMarketcap.test.ts +1 -3
  479. package/src/dada-client/MIGRATION_GUIDE.md +215 -0
  480. package/src/dada-client/entities/index.ts +1 -1
  481. package/src/e2e/enum/Account.ts +31 -0
  482. package/src/e2e/enum/AppInfos.ts +2 -0
  483. package/src/e2e/enum/Currency.ts +11 -0
  484. package/src/e2e/enum/Network.ts +1 -0
  485. package/src/e2e/enum/TokenType.ts +1 -0
  486. package/src/e2e/enum/TransactionStatus.ts +3 -0
  487. package/src/e2e/families/sui.ts +7 -0
  488. package/src/e2e/speculos.ts +23 -0
  489. package/src/exchange/providers/swap.ts +4 -4
  490. package/src/exchange/swap/api/v5/__mocks__/fetchRates.mocks.ts +1 -2
  491. package/src/exchange/swap/mock.ts +1 -1
  492. package/src/families/algorand/bridge/mock.ts +2 -0
  493. package/src/families/bitcoin/bridge/mock.ts +2 -0
  494. package/src/families/canton/bridge/mock.ts +3 -0
  495. package/src/families/cardano/bridge/mock.ts +2 -0
  496. package/src/families/casper/bridge/mock.ts +2 -0
  497. package/src/families/cosmos/bridge/mock.ts +2 -0
  498. package/src/families/evm/bridge/mock.ts +2 -0
  499. package/src/families/icon/bridge/mock.ts +2 -0
  500. package/src/families/multiversx/bridge/mock.ts +2 -0
  501. package/src/families/polkadot/bridge/mock.ts +2 -0
  502. package/src/families/polkadot/config.ts +84 -0
  503. package/src/families/polkadot/setup.ts +6 -4
  504. package/src/families/stellar/bridge/mock.ts +2 -0
  505. package/src/families/tezos/bridge/mock.ts +2 -0
  506. package/src/families/tron/bridge/mock.ts +2 -0
  507. package/src/families/xrp/bridge/mock.ts +2 -0
  508. package/src/featureFlags/defaultFeatures.ts +15 -1
  509. package/src/hooks/useManifestWithSessionId.test.ts +105 -0
  510. package/src/hooks/useManifestWithSessionId.ts +83 -0
  511. package/src/hw/actions/rawTransaction.ts +190 -0
  512. package/src/market/utils/index.ts +3 -0
  513. package/src/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.ts +472 -0
  514. package/src/modularDrawer/hooks/index.ts +1 -0
  515. package/src/modularDrawer/hooks/useCurrenciesUnderFeatureFlag.ts +9 -0
  516. package/src/modularDrawer/hooks/useDetailedAccountsCore.ts +146 -0
  517. package/src/modularDrawer/hooks/useRightBalanceAsset.tsx +5 -1
  518. package/src/modularDrawer/hooks/useRightBalanceNetwork.tsx +10 -4
  519. package/src/modularDrawer/index.ts +3 -0
  520. package/src/modularDrawer/types/detailedAccount.ts +49 -0
  521. package/src/modularDrawer/types/index.ts +1 -0
  522. package/src/modularDrawer/utils/__tests__/sortAccountsByFiatValue.test.ts +117 -0
  523. package/src/modularDrawer/utils/getBalanceAndFiatValueByAssets.ts +6 -3
  524. package/src/modularDrawer/utils/index.ts +1 -0
  525. package/src/modularDrawer/utils/sortAccountsByFiatValue.ts +14 -0
  526. package/src/modularDrawer/utils/type.ts +3 -2
  527. package/src/platform/providers/RemoteLiveAppProvider/api/mock.json +3 -3
  528. package/src/wallet-api/logic.ts +35 -0
  529. package/src/wallet-api/react.ts +87 -1
  530. package/src/wallet-api/tracking.ts +15 -0
  531. package/src/wallet-api/useDappLogic.ts +3 -3
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=useManifestWithSessionId.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useManifestWithSessionId.test.d.ts","sourceRoot":"","sources":["../../src/hooks/useManifestWithSessionId.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,69 @@
1
+ /**
2
+ * @jest-environment jsdom
3
+ */
4
+ import { renderHook, waitFor } from "@testing-library/react";
5
+ import { useManifestWithSessionId } from "./useManifestWithSessionId";
6
+ const mockFetch = jest.fn();
7
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
8
+ global.fetch = mockFetch;
9
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
10
+ const baseManifest = {
11
+ id: "test-app",
12
+ name: "Test App",
13
+ url: "https://example.com",
14
+ };
15
+ describe("useManifestWithSessionId", () => {
16
+ beforeEach(() => {
17
+ jest.clearAllMocks();
18
+ });
19
+ it("returns null manifest during loading", async () => {
20
+ mockFetch.mockResolvedValueOnce({
21
+ ok: true,
22
+ json: async () => ({ providerSessionId: "abc123" }),
23
+ });
24
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: baseManifest, shareAnalytics: true }));
25
+ expect(result.current.loading).toBe(true);
26
+ expect(result.current.manifest).toBeNull();
27
+ });
28
+ it("returns manifest with externalID after success", async () => {
29
+ mockFetch.mockResolvedValueOnce({
30
+ ok: true,
31
+ json: async () => ({ providerSessionId: "abc123" }),
32
+ });
33
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: baseManifest, shareAnalytics: true }));
34
+ await waitFor(() => expect(result.current.manifest).toEqual({
35
+ ...baseManifest,
36
+ url: "https://example.com/?externalID=abc123",
37
+ }));
38
+ expect(result.current.loading).toBe(false);
39
+ });
40
+ it("falls back to original manifest if fetch rejects", async () => {
41
+ mockFetch.mockRejectedValueOnce(new Error("network error"));
42
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: baseManifest, shareAnalytics: true }));
43
+ await waitFor(() => {
44
+ expect(result.current.manifest).toEqual(baseManifest);
45
+ });
46
+ expect(result.current.loading).toBe(false);
47
+ });
48
+ it("falls back to original manifest if response is not ok", async () => {
49
+ mockFetch.mockResolvedValueOnce({ ok: false });
50
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: baseManifest, shareAnalytics: true }));
51
+ await waitFor(() => {
52
+ expect(result.current.manifest).toEqual(baseManifest);
53
+ });
54
+ expect(result.current.loading).toBe(false);
55
+ });
56
+ it("returns null if manifest is not provided", async () => {
57
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: null, shareAnalytics: true }));
58
+ expect(mockFetch).not.toHaveBeenCalled();
59
+ expect(result.current.manifest).toBeNull();
60
+ expect(result.current.loading).toBe(false);
61
+ });
62
+ it("skips fetch if shareAnalytics is false and just returns manifest", () => {
63
+ const { result } = renderHook(() => useManifestWithSessionId({ manifest: baseManifest, shareAnalytics: false }));
64
+ expect(mockFetch).not.toHaveBeenCalled();
65
+ expect(result.current.manifest).toEqual(baseManifest);
66
+ expect(result.current.loading).toBe(false);
67
+ });
68
+ });
69
+ //# sourceMappingURL=useManifestWithSessionId.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useManifestWithSessionId.test.js","sourceRoot":"","sources":["../../src/hooks/useManifestWithSessionId.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,37 @@
1
+ import { Observable } from "rxjs";
2
+ import type { ConnectAppEvent, Input as ConnectAppInput } from "../connectApp";
3
+ import type { Action, Device } from "./types";
4
+ import type { AppRequest, AppState } from "./app";
5
+ import type { Account, AccountLike, SignedOperation } from "@ledgerhq/types-live";
6
+ type State = {
7
+ signedOperation: SignedOperation | null | undefined;
8
+ deviceSignatureRequested: boolean;
9
+ deviceStreamingProgress: number | null | undefined;
10
+ transactionSignError: Error | null | undefined;
11
+ transactionChecksOptInTriggered: boolean;
12
+ transactionChecksOptIn: boolean | null;
13
+ manifestId?: string;
14
+ manifestName?: string;
15
+ };
16
+ type RawTransactionState = AppState & State;
17
+ type RawTransactionRequest = {
18
+ parentAccount: Account | null | undefined;
19
+ account: AccountLike;
20
+ transaction: string;
21
+ appName?: string;
22
+ dependencies?: AppRequest[];
23
+ requireLatestFirmware?: boolean;
24
+ manifestId?: string;
25
+ manifestName?: string;
26
+ };
27
+ export type RawTransactionResult = {
28
+ signedOperation: SignedOperation;
29
+ device: Device;
30
+ swapId?: string;
31
+ } | {
32
+ transactionSignError: Error;
33
+ };
34
+ type TransactionAction = Action<RawTransactionRequest, RawTransactionState, RawTransactionResult>;
35
+ export declare const createAction: (connectAppExec: (arg0: ConnectAppInput) => Observable<ConnectAppEvent>) => TransactionAction;
36
+ export {};
37
+ //# sourceMappingURL=rawTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rawTransaction.d.ts","sourceRoot":"","sources":["../../../src/hw/actions/rawTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAM,UAAU,EAAE,MAAM,MAAM,CAAC;AAQtC,OAAO,KAAK,EAAE,eAAe,EAAE,KAAK,IAAI,eAAe,EAAE,MAAM,eAAe,CAAC;AAC/E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAElD,OAAO,KAAK,EACV,OAAO,EACP,WAAW,EACX,eAAe,EAEhB,MAAM,sBAAsB,CAAC;AAE9B,KAAK,KAAK,GAAG;IACX,eAAe,EAAE,eAAe,GAAG,IAAI,GAAG,SAAS,CAAC;IACpD,wBAAwB,EAAE,OAAO,CAAC;IAClC,uBAAuB,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACnD,oBAAoB,EAAE,KAAK,GAAG,IAAI,GAAG,SAAS,CAAC;IAC/C,+BAA+B,EAAE,OAAO,CAAC;IACzC,sBAAsB,EAAE,OAAO,GAAG,IAAI,CAAC;IACvC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AACF,KAAK,mBAAmB,GAAG,QAAQ,GAAG,KAAK,CAAC;AAC5C,KAAK,qBAAqB,GAAG;IAC3B,aAAa,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC;IAC1C,OAAO,EAAE,WAAW,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,YAAY,CAAC,EAAE,UAAU,EAAE,CAAC;IAC5B,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AACF,MAAM,MAAM,oBAAoB,GAC5B;IACE,eAAe,EAAE,eAAe,CAAC;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB,GACD;IACE,oBAAoB,EAAE,KAAK,CAAC;CAC7B,CAAC;AACN,KAAK,iBAAiB,GAAG,MAAM,CAAC,qBAAqB,EAAE,mBAAmB,EAAE,oBAAoB,CAAC,CAAC;AAsElG,eAAO,MAAM,YAAY,0BACA,eAAe,KAAK,WAAW,eAAe,CAAC,KACrE,iBAoEF,CAAC"}
@@ -0,0 +1,103 @@
1
+ import { of } from "rxjs";
2
+ import { scan, catchError, tap } from "rxjs/operators";
3
+ import { useEffect, useState } from "react";
4
+ import { log } from "@ledgerhq/logs";
5
+ import { TransportStatusError } from "@ledgerhq/errors";
6
+ import { TransactionRefusedOnDevice } from "../../errors";
7
+ import { getMainAccount } from "../../account";
8
+ import { getAccountBridge } from "../../bridge";
9
+ import { createAction as createAppAction } from "./app";
10
+ const mapResult = ({ device, signedOperation, transactionSignError, }) => signedOperation && device
11
+ ? {
12
+ signedOperation,
13
+ device,
14
+ }
15
+ : transactionSignError
16
+ ? {
17
+ transactionSignError,
18
+ }
19
+ : null;
20
+ const initialState = {
21
+ signedOperation: null,
22
+ deviceSignatureRequested: false,
23
+ deviceStreamingProgress: null,
24
+ transactionSignError: null,
25
+ transactionChecksOptInTriggered: false,
26
+ transactionChecksOptIn: null,
27
+ };
28
+ const reducer = (state, e) => {
29
+ switch (e.type) {
30
+ case "error": {
31
+ const { error } = e;
32
+ const transactionSignError = error instanceof TransportStatusError && error.statusCode === 0x6985
33
+ ? new TransactionRefusedOnDevice()
34
+ : error;
35
+ return { ...initialState, transactionSignError };
36
+ }
37
+ case "signed":
38
+ return { ...state, signedOperation: e.signedOperation };
39
+ case "device-signature-requested":
40
+ return { ...state, deviceSignatureRequested: true };
41
+ case "device-signature-granted":
42
+ return { ...state, deviceSignatureRequested: false };
43
+ case "device-streaming":
44
+ return { ...state, deviceStreamingProgress: e.progress };
45
+ case "transaction-checks-opt-in-triggered":
46
+ return { ...state, transactionChecksOptInTriggered: true };
47
+ case "transaction-checks-opt-in":
48
+ return { ...state, transactionChecksOptIn: true };
49
+ case "transaction-checks-opt-out":
50
+ return { ...state, transactionChecksOptIn: false };
51
+ default:
52
+ return state;
53
+ }
54
+ };
55
+ export const createAction = (connectAppExec) => {
56
+ const useHook = (reduxDevice, { account, parentAccount, transaction, appName, dependencies, requireLatestFirmware, manifestId, manifestName, }) => {
57
+ const mainAccount = getMainAccount(account, parentAccount);
58
+ const appState = createAppAction(connectAppExec).useHook(reduxDevice, {
59
+ account: mainAccount,
60
+ appName,
61
+ dependencies,
62
+ requireLatestFirmware,
63
+ });
64
+ const { device, opened, inWrongDeviceForAccount, error } = appState;
65
+ const [state, setState] = useState(initialState);
66
+ useEffect(() => {
67
+ if (!device || !opened || inWrongDeviceForAccount || error) {
68
+ setState(initialState);
69
+ return;
70
+ }
71
+ const bridge = getAccountBridge(mainAccount);
72
+ const sub = bridge
73
+ .signRawOperation({
74
+ account: mainAccount,
75
+ transaction,
76
+ deviceId: device.deviceId,
77
+ deviceModelId: device.modelId,
78
+ })
79
+ .pipe(catchError(error => of({
80
+ type: "error",
81
+ error,
82
+ })), tap((e) => log("actions-transaction-event", e.type, e)), scan(reducer, initialState))
83
+ .subscribe((x) => setState(x));
84
+ return () => {
85
+ sub.unsubscribe();
86
+ };
87
+ }, [device, mainAccount, transaction, opened, inWrongDeviceForAccount, error]);
88
+ return {
89
+ ...appState,
90
+ ...state,
91
+ manifestId,
92
+ manifestName,
93
+ deviceStreamingProgress: state.signedOperation || state.transactionSignError
94
+ ? null // when good app is opened, we start the progress so it doesn't "blink"
95
+ : state.deviceStreamingProgress || (appState.opened ? 0 : null),
96
+ };
97
+ };
98
+ return {
99
+ useHook,
100
+ mapResult,
101
+ };
102
+ };
103
+ //# sourceMappingURL=rawTransaction.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rawTransaction.js","sourceRoot":"","sources":["../../../src/hw/actions/rawTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,EAAE,EAAc,MAAM,MAAM,CAAC;AACtC,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5C,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;AACxD,OAAO,EAAE,0BAA0B,EAAE,MAAM,cAAc,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAIhD,OAAO,EAAE,YAAY,IAAI,eAAe,EAAE,MAAM,OAAO,CAAC;AAwCxD,MAAM,SAAS,GAAG,CAAC,EACjB,MAAM,EACN,eAAe,EACf,oBAAoB,GACA,EAA2C,EAAE,CACjE,eAAe,IAAI,MAAM;IACvB,CAAC,CAAC;QACE,eAAe;QACf,MAAM;KACP;IACH,CAAC,CAAC,oBAAoB;QACpB,CAAC,CAAC;YACE,oBAAoB;SACrB;QACH,CAAC,CAAC,IAAI,CAAC;AAQb,MAAM,YAAY,GAAG;IACnB,eAAe,EAAE,IAAI;IACrB,wBAAwB,EAAE,KAAK;IAC/B,uBAAuB,EAAE,IAAI;IAC7B,oBAAoB,EAAE,IAAI;IAC1B,+BAA+B,EAAE,KAAK;IACtC,sBAAsB,EAAE,IAAI;CAC7B,CAAC;AAEF,MAAM,OAAO,GAAG,CAAC,KAAY,EAAE,CAAQ,EAAS,EAAE;IAChD,QAAQ,CAAC,CAAC,IAAI,EAAE;QACd,KAAK,OAAO,CAAC,CAAC;YACZ,MAAM,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;YACpB,MAAM,oBAAoB,GACxB,KAAK,YAAY,oBAAoB,IAAI,KAAK,CAAC,UAAU,KAAK,MAAM;gBAClE,CAAC,CAAC,IAAI,0BAA0B,EAAE;gBAClC,CAAC,CAAC,KAAK,CAAC;YACZ,OAAO,EAAE,GAAG,YAAY,EAAE,oBAAoB,EAAE,CAAC;SAClD;QAED,KAAK,QAAQ;YACX,OAAO,EAAE,GAAG,KAAK,EAAE,eAAe,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC;QAE1D,KAAK,4BAA4B;YAC/B,OAAO,EAAE,GAAG,KAAK,EAAE,wBAAwB,EAAE,IAAI,EAAE,CAAC;QAEtD,KAAK,0BAA0B;YAC7B,OAAO,EAAE,GAAG,KAAK,EAAE,wBAAwB,EAAE,KAAK,EAAE,CAAC;QAEvD,KAAK,kBAAkB;YACrB,OAAO,EAAE,GAAG,KAAK,EAAE,uBAAuB,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;QAE3D,KAAK,qCAAqC;YACxC,OAAO,EAAE,GAAG,KAAK,EAAE,+BAA+B,EAAE,IAAI,EAAE,CAAC;QAE7D,KAAK,2BAA2B;YAC9B,OAAO,EAAE,GAAG,KAAK,EAAE,sBAAsB,EAAE,IAAI,EAAE,CAAC;QAEpD,KAAK,4BAA4B;YAC/B,OAAO,EAAE,GAAG,KAAK,EAAE,sBAAsB,EAAE,KAAK,EAAE,CAAC;QAErD;YACE,OAAO,KAAK,CAAC;KAChB;AACH,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,cAAsE,EACnD,EAAE;IACrB,MAAM,OAAO,GAAG,CACd,WAAsC,EACtC,EACE,OAAO,EACP,aAAa,EACb,WAAW,EACX,OAAO,EACP,YAAY,EACZ,qBAAqB,EACrB,UAAU,EACV,YAAY,GACU,EACH,EAAE;QACvB,MAAM,WAAW,GAAG,cAAc,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC;QAC3D,MAAM,QAAQ,GAAG,eAAe,CAAC,cAAc,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE;YACpE,OAAO,EAAE,WAAW;YACpB,OAAO;YACP,YAAY;YACZ,qBAAqB;SACtB,CAAC,CAAC;QACH,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,uBAAuB,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC;QACpE,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,YAAY,CAAC,CAAC;QACjD,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,IAAI,uBAAuB,IAAI,KAAK,EAAE;gBAC1D,QAAQ,CAAC,YAAY,CAAC,CAAC;gBACvB,OAAO;aACR;YAED,MAAM,MAAM,GAAG,gBAAgB,CAAC,WAAW,CAAC,CAAC;YAC7C,MAAM,GAAG,GAAG,MAAM;iBACf,gBAAgB,CAAC;gBAChB,OAAO,EAAE,WAAW;gBACpB,WAAW;gBACX,QAAQ,EAAE,MAAM,CAAC,QAAQ;gBACzB,aAAa,EAAE,MAAM,CAAC,OAAO;aAC9B,CAAC;iBACD,IAAI,CACH,UAAU,CAAC,KAAK,CAAC,EAAE,CACjB,EAAE,CAAkC;gBAClC,IAAI,EAAE,OAAO;gBACb,KAAK;aACN,CAAC,CACH,EACD,GAAG,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,2BAA2B,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAC9D,IAAI,CAAC,OAAO,EAAE,YAAY,CAAC,CAC5B;iBACA,SAAS,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;YACtC,OAAO,GAAG,EAAE;gBACV,GAAG,CAAC,WAAW,EAAE,CAAC;YACpB,CAAC,CAAC;QACJ,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,EAAE,uBAAuB,EAAE,KAAK,CAAC,CAAC,CAAC;QAC/E,OAAO;YACL,GAAG,QAAQ;YACX,GAAG,KAAK;YACR,UAAU;YACV,YAAY;YACZ,uBAAuB,EACrB,KAAK,CAAC,eAAe,IAAI,KAAK,CAAC,oBAAoB;gBACjD,CAAC,CAAC,IAAI,CAAC,uEAAuE;gBAC9E,CAAC,CAAC,KAAK,CAAC,uBAAuB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SACpE,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO;QACL,OAAO;QACP,SAAS;KACV,CAAC;AACJ,CAAC,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import { PortfolioRange } from "@ledgerhq/types-live";
2
2
  import { Order } from "./types";
3
+ export * from "./types";
3
4
  export declare function getRange(range: PortfolioRange | string): "1y" | "1d" | "1w" | "1m" | undefined;
4
5
  export declare const getSortParam: (order: Order, range: PortfolioRange | string) => string;
5
6
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/market/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,wBAAgB,QAAQ,CAAC,KAAK,EAAE,cAAc,GAAG,MAAM,yCAgBtD;AAED,eAAO,MAAM,YAAY,UAAW,KAAK,SAAS,cAAc,GAAG,MAAM,WAYxE,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/market/utils/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAGhC,cAAc,SAAS,CAAC;AAExB,wBAAgB,QAAQ,CAAC,KAAK,EAAE,cAAc,GAAG,MAAM,yCAgBtD;AAED,eAAO,MAAM,YAAY,UAAW,KAAK,SAAS,cAAc,GAAG,MAAM,WAYxE,CAAC"}
@@ -1,4 +1,6 @@
1
1
  import { Order } from "./types";
2
+ // Export all types from types.ts
3
+ export * from "./types";
2
4
  export function getRange(range) {
3
5
  switch (range) {
4
6
  case "day":
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/market/utils/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,MAAM,UAAU,QAAQ,CAAC,KAA8B;IACrD,QAAQ,KAAK,EAAE;QACb,KAAK,KAAK,CAAC;QACX,KAAK,KAAK;YACR,OAAO,IAAI,CAAC;QACd,KAAK,IAAI,CAAC;QACV,KAAK,MAAM;YACT,OAAO,IAAI,CAAC;QACd,KAAK,KAAK,CAAC;QACX,KAAK,OAAO;YACV,OAAO,IAAI,CAAC;QACd,KAAK,IAAI,CAAC;QACV,KAAK,MAAM,CAAC;QACZ,KAAK,KAAK;YACR,OAAO,IAAI,CAAC;KACf;AACH,CAAC;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAY,EAAE,KAA8B,EAAE,EAAE;IAC3E,QAAQ,KAAK,EAAE;QACb,QAAQ;QACR,KAAK,KAAK,CAAC,aAAa;YACtB,OAAO,iBAAiB,CAAC;QAC3B,KAAK,KAAK,CAAC,YAAY;YACrB,OAAO,sBAAsB,CAAC;QAChC,KAAK,KAAK,CAAC,SAAS;YAClB,OAAO,yBAAyB,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACpD,KAAK,KAAK,CAAC,UAAU;YACnB,OAAO,yBAAyB,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;KACrD;AACH,CAAC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/market/utils/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAEhC,iCAAiC;AACjC,cAAc,SAAS,CAAC;AAExB,MAAM,UAAU,QAAQ,CAAC,KAA8B;IACrD,QAAQ,KAAK,EAAE;QACb,KAAK,KAAK,CAAC;QACX,KAAK,KAAK;YACR,OAAO,IAAI,CAAC;QACd,KAAK,IAAI,CAAC;QACV,KAAK,MAAM;YACT,OAAO,IAAI,CAAC;QACd,KAAK,KAAK,CAAC;QACX,KAAK,OAAO;YACV,OAAO,IAAI,CAAC;QACd,KAAK,IAAI,CAAC;QACV,KAAK,MAAM,CAAC;QACZ,KAAK,KAAK;YACR,OAAO,IAAI,CAAC;KACf;AACH,CAAC;AAED,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,KAAY,EAAE,KAA8B,EAAE,EAAE;IAC3E,QAAQ,KAAK,EAAE;QACb,QAAQ;QACR,KAAK,KAAK,CAAC,aAAa;YACtB,OAAO,iBAAiB,CAAC;QAC3B,KAAK,KAAK,CAAC,YAAY;YACrB,OAAO,sBAAsB,CAAC;QAChC,KAAK,KAAK,CAAC,SAAS;YAClB,OAAO,yBAAyB,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;QACpD,KAAK,KAAK,CAAC,UAAU;YACnB,OAAO,yBAAyB,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;KACrD;AACH,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=useDetailedAccountsCore.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useDetailedAccountsCore.test.d.ts","sourceRoot":"","sources":["../../../../src/modularDrawer/hooks/__tests__/useDetailedAccountsCore.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,345 @@
1
+ /**
2
+ * @jest-environment jsdom
3
+ */
4
+ import { renderHook } from "@testing-library/react";
5
+ import { useDetailedAccountsCore } from "../useDetailedAccountsCore";
6
+ import BigNumber from "bignumber.js";
7
+ // Mock the calculate function
8
+ jest.mock("@ledgerhq/live-countervalues/logic", () => ({
9
+ calculate: jest.fn(),
10
+ }));
11
+ // Mock the derivation function
12
+ jest.mock("@ledgerhq/coin-framework/derivation", () => ({
13
+ getTagDerivationMode: jest.fn(() => "native_segwit"),
14
+ }));
15
+ // Import the mocked functions
16
+ import { calculate } from "@ledgerhq/live-countervalues/logic";
17
+ import { getTagDerivationMode } from "@ledgerhq/coin-framework/derivation";
18
+ const mockCalculate = calculate;
19
+ const mockGetTagDerivationMode = getTagDerivationMode;
20
+ describe("useDetailedAccountsCore", () => {
21
+ const mockCounterValuesState = {};
22
+ const mockCounterValueCurrency = {
23
+ id: "usd",
24
+ ticker: "USD",
25
+ units: [{ name: "USD", code: "USD", magnitude: 2 }],
26
+ };
27
+ const mockAccount = {
28
+ id: "account1",
29
+ type: "Account",
30
+ currency: {
31
+ id: "ethereum",
32
+ ticker: "ETH",
33
+ name: "Ethereum",
34
+ units: [{ name: "Ethereum", code: "ETH", magnitude: 18 }],
35
+ },
36
+ balance: new BigNumber("1000000000000000000"),
37
+ freshAddress: "0x123...abc",
38
+ derivationMode: "ethM",
39
+ };
40
+ const mockTokenAccount = {
41
+ id: "token1",
42
+ type: "TokenAccount",
43
+ parentId: "account1",
44
+ token: {
45
+ id: "usdc",
46
+ ticker: "USDC",
47
+ name: "USD Coin",
48
+ units: [{ name: "USD Coin", code: "USDC", magnitude: 6 }],
49
+ parentCurrency: mockAccount.currency,
50
+ },
51
+ balance: new BigNumber("1000000"), // 1 USDC
52
+ };
53
+ beforeEach(() => {
54
+ mockCalculate.mockClear();
55
+ });
56
+ it("should calculate fiat value correctly", () => {
57
+ mockCalculate.mockReturnValue(2500); // Mock fiat value
58
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
59
+ const fiatValue = result.current.calculateFiatValue(mockAccount);
60
+ expect(mockCalculate).toHaveBeenCalledWith(mockCounterValuesState, {
61
+ from: mockAccount.currency,
62
+ to: mockCounterValueCurrency,
63
+ value: mockAccount.balance.toNumber(),
64
+ });
65
+ expect(fiatValue).toBe(2500);
66
+ });
67
+ it("should return 0 when mockCalculate returns null", () => {
68
+ mockCalculate.mockReturnValue(null);
69
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
70
+ const fiatValue = result.current.calculateFiatValue(mockAccount);
71
+ expect(fiatValue).toBe(0);
72
+ });
73
+ it("should create base detailed accounts for regular accounts", () => {
74
+ mockCalculate.mockReturnValue(2500);
75
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
76
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
77
+ const accountNameMap = { account1: "My Ethereum Account" };
78
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
79
+ asset: mockAccount.currency,
80
+ accountTuples,
81
+ accountNameMap,
82
+ isTokenCurrency: false,
83
+ });
84
+ expect(detailedAccounts).toHaveLength(1);
85
+ expect(detailedAccounts[0]).toEqual({
86
+ id: "account1",
87
+ name: "My Ethereum Account",
88
+ ticker: "ETH",
89
+ balance: mockAccount.balance,
90
+ balanceUnit: mockAccount.currency.units[0],
91
+ fiatValue: 2500,
92
+ address: "0x123...abc",
93
+ cryptoId: "ethereum",
94
+ });
95
+ });
96
+ it("should create base detailed accounts for token accounts", () => {
97
+ mockCalculate.mockReturnValue(1); // 1 USD for USDC
98
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
99
+ const accountTuples = [{ account: mockAccount, subAccount: mockTokenAccount }];
100
+ const accountNameMap = { account1: "My Ethereum Account" };
101
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
102
+ asset: mockTokenAccount.token,
103
+ accountTuples,
104
+ accountNameMap,
105
+ isTokenCurrency: true,
106
+ });
107
+ expect(detailedAccounts).toHaveLength(1);
108
+ expect(detailedAccounts[0]).toEqual({
109
+ id: "token1",
110
+ name: "My Ethereum Account",
111
+ ticker: "USDC",
112
+ balance: mockTokenAccount.balance,
113
+ balanceUnit: mockTokenAccount.token.units[0],
114
+ fiatValue: 1,
115
+ address: "0x123...abc",
116
+ cryptoId: "usdc",
117
+ parentId: "ethereum",
118
+ });
119
+ });
120
+ it("should create extended detailed accounts with account references", () => {
121
+ mockCalculate.mockReturnValue(2500);
122
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
123
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
124
+ const accountNameMap = { account1: "My Ethereum Account" };
125
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
126
+ asset: mockAccount.currency,
127
+ accountTuples,
128
+ accountNameMap,
129
+ isTokenCurrency: false,
130
+ });
131
+ expect(detailedAccounts).toHaveLength(1);
132
+ expect(detailedAccounts[0]).toEqual({
133
+ id: "account1",
134
+ name: "My Ethereum Account",
135
+ ticker: "ETH",
136
+ balance: mockAccount.balance,
137
+ balanceUnit: mockAccount.currency.units[0],
138
+ fiatValue: 2500,
139
+ address: "0x123...abc",
140
+ cryptoId: "ethereum",
141
+ account: mockAccount,
142
+ protocol: "native_segwit",
143
+ });
144
+ });
145
+ it("should sort accounts by fiat value in descending order", () => {
146
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
147
+ const mockAccount2 = { ...mockAccount, id: "account2" };
148
+ // Mock different fiat values for different accounts
149
+ mockCalculate
150
+ .mockReturnValueOnce(1000) // First account
151
+ .mockReturnValueOnce(5000); // Second account
152
+ const accountTuples = [
153
+ { account: mockAccount, subAccount: null },
154
+ { account: mockAccount2, subAccount: null },
155
+ ];
156
+ const accountNameMap = {
157
+ account1: "Account 1",
158
+ account2: "Account 2",
159
+ };
160
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
161
+ asset: mockAccount.currency,
162
+ accountTuples,
163
+ accountNameMap,
164
+ isTokenCurrency: false,
165
+ });
166
+ expect(detailedAccounts).toHaveLength(2);
167
+ expect(detailedAccounts[0].id).toBe("account2"); // Higher fiat value (5000)
168
+ expect(detailedAccounts[1].id).toBe("account1"); // Lower fiat value (1000)
169
+ });
170
+ it("should use fallback name when account name is not in map", () => {
171
+ mockCalculate.mockReturnValue(2500);
172
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
173
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
174
+ const accountNameMap = {}; // Empty map
175
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
176
+ asset: mockAccount.currency,
177
+ accountTuples,
178
+ accountNameMap,
179
+ isTokenCurrency: false,
180
+ });
181
+ expect(detailedAccounts[0].name).toBe("Ethereum"); // Falls back to currency name
182
+ });
183
+ it("should handle token accounts with extended detailed accounts", () => {
184
+ mockCalculate.mockReturnValue(1); // 1 USD for USDC
185
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
186
+ const accountTuples = [{ account: mockAccount, subAccount: mockTokenAccount }];
187
+ const accountNameMap = { account1: "My Ethereum Account" };
188
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
189
+ asset: mockTokenAccount.token,
190
+ accountTuples,
191
+ accountNameMap,
192
+ isTokenCurrency: true,
193
+ });
194
+ expect(detailedAccounts).toHaveLength(1);
195
+ expect(detailedAccounts[0]).toEqual({
196
+ id: "token1",
197
+ name: "My Ethereum Account",
198
+ ticker: "USDC",
199
+ balance: mockTokenAccount.balance,
200
+ balanceUnit: mockTokenAccount.token.units[0],
201
+ fiatValue: 1,
202
+ address: "0x123...abc",
203
+ cryptoId: "usdc",
204
+ parentId: "ethereum",
205
+ account: mockTokenAccount,
206
+ parentAccount: mockAccount,
207
+ });
208
+ });
209
+ it("should handle multiple accounts with mixed fiat values including zero", () => {
210
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
211
+ const mockAccount2 = { ...mockAccount, id: "account2" };
212
+ const mockAccount3 = { ...mockAccount, id: "account3" };
213
+ // Mock different fiat values including zero
214
+ mockCalculate
215
+ .mockReturnValueOnce(0) // First account - zero value
216
+ .mockReturnValueOnce(5000) // Second account - high value
217
+ .mockReturnValueOnce(100); // Third account - low value
218
+ const accountTuples = [
219
+ { account: mockAccount, subAccount: null },
220
+ { account: mockAccount2, subAccount: null },
221
+ { account: mockAccount3, subAccount: null },
222
+ ];
223
+ const accountNameMap = {
224
+ account1: "Account 1",
225
+ account2: "Account 2",
226
+ account3: "Account 3",
227
+ };
228
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
229
+ asset: mockAccount.currency,
230
+ accountTuples,
231
+ accountNameMap,
232
+ isTokenCurrency: false,
233
+ });
234
+ expect(detailedAccounts).toHaveLength(3);
235
+ // Should be sorted by fiat value descending: 5000, 100, 0
236
+ expect(detailedAccounts[0].id).toBe("account2"); // 5000
237
+ expect(detailedAccounts[1].id).toBe("account3"); // 100
238
+ expect(detailedAccounts[2].id).toBe("account1"); // 0
239
+ expect(detailedAccounts[2].fiatValue).toBe(0);
240
+ });
241
+ it("should handle token account fiat value calculation correctly", () => {
242
+ mockCalculate.mockReturnValue(50); // Mock fiat value for token
243
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
244
+ const fiatValue = result.current.calculateFiatValue(mockTokenAccount);
245
+ expect(mockCalculate).toHaveBeenCalledWith(mockCounterValuesState, {
246
+ from: mockTokenAccount.token,
247
+ to: mockCounterValueCurrency,
248
+ value: mockTokenAccount.balance.toNumber(),
249
+ });
250
+ expect(fiatValue).toBe(50);
251
+ });
252
+ it("should handle empty account tuples", () => {
253
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
254
+ const accountTuples = [];
255
+ const accountNameMap = {};
256
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
257
+ asset: mockAccount.currency,
258
+ accountTuples,
259
+ accountNameMap,
260
+ isTokenCurrency: false,
261
+ });
262
+ expect(detailedAccounts).toHaveLength(0);
263
+ });
264
+ it("should handle accounts with undefined fiat values", () => {
265
+ mockCalculate.mockReturnValue(undefined); // Simulate undefined return
266
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
267
+ const fiatValue = result.current.calculateFiatValue(mockAccount);
268
+ expect(fiatValue).toBe(0); // Should default to 0
269
+ });
270
+ it("should preserve account properties in extended detailed accounts", () => {
271
+ mockCalculate.mockReturnValue(1500);
272
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
273
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
274
+ const accountNameMap = { account1: "Custom Account Name" };
275
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
276
+ asset: mockAccount.currency,
277
+ accountTuples,
278
+ accountNameMap,
279
+ isTokenCurrency: false,
280
+ });
281
+ expect(detailedAccounts[0].account).toBe(mockAccount);
282
+ expect(detailedAccounts[0].protocol).toBe("native_segwit");
283
+ expect(detailedAccounts[0].parentAccount).toBeUndefined();
284
+ });
285
+ it("should use fallback name when parent account name is not in map for token accounts", () => {
286
+ mockCalculate.mockReturnValue(1);
287
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
288
+ const accountTuples = [{ account: mockAccount, subAccount: mockTokenAccount }];
289
+ const accountNameMap = {}; // Empty map - no parent account name
290
+ const detailedAccounts = result.current.createBaseDetailedAccounts({
291
+ asset: mockTokenAccount.token,
292
+ accountTuples,
293
+ accountNameMap,
294
+ isTokenCurrency: true,
295
+ });
296
+ expect(detailedAccounts[0].name).toBe("USD Coin"); // Falls back to token name
297
+ });
298
+ it("should use fallback name when parent account name is not in map for extended token accounts", () => {
299
+ mockCalculate.mockReturnValue(1);
300
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
301
+ const accountTuples = [{ account: mockAccount, subAccount: mockTokenAccount }];
302
+ const accountNameMap = {}; // Empty map - no parent account name
303
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
304
+ asset: mockTokenAccount.token,
305
+ accountTuples,
306
+ accountNameMap,
307
+ isTokenCurrency: true,
308
+ });
309
+ expect(detailedAccounts[0].name).toBe("USD Coin"); // Falls back to token name
310
+ expect(detailedAccounts[0].account).toBe(mockTokenAccount);
311
+ expect(detailedAccounts[0].parentAccount).toBe(mockAccount);
312
+ });
313
+ it("should handle null derivation mode in extended detailed accounts", () => {
314
+ // Mock getTagDerivationMode to return null
315
+ mockGetTagDerivationMode.mockReturnValue(null);
316
+ mockCalculate.mockReturnValue(2500);
317
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
318
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
319
+ const accountNameMap = { account1: "My Account" };
320
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
321
+ asset: mockAccount.currency,
322
+ accountTuples,
323
+ accountNameMap,
324
+ isTokenCurrency: false,
325
+ });
326
+ expect(detailedAccounts[0].protocol).toBe(""); // Should fallback to empty string
327
+ // Reset mock for other tests
328
+ mockGetTagDerivationMode.mockReturnValue("native_segwit");
329
+ });
330
+ it("should use fallback name when account name is not in map for extended accounts", () => {
331
+ mockCalculate.mockReturnValue(2500);
332
+ const { result } = renderHook(() => useDetailedAccountsCore(mockCounterValuesState, mockCounterValueCurrency));
333
+ const accountTuples = [{ account: mockAccount, subAccount: null }];
334
+ const accountNameMap = {}; // Empty map - no account name
335
+ const detailedAccounts = result.current.createExtendedDetailedAccounts({
336
+ asset: mockAccount.currency,
337
+ accountTuples,
338
+ accountNameMap,
339
+ isTokenCurrency: false,
340
+ });
341
+ expect(detailedAccounts[0].name).toBe("Ethereum"); // Falls back to currency name
342
+ expect(detailedAccounts[0].account).toBe(mockAccount);
343
+ });
344
+ });
345
+ //# sourceMappingURL=useDetailedAccountsCore.test.js.map