@ledgerhq/live-common 34.54.0-nightly.20251209023841 → 34.54.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (553) hide show
  1. package/lib/__tests__/test-helpers/bridge.js +1 -1
  2. package/lib/__tests__/test-helpers/bridge.js.map +1 -1
  3. package/lib/__tests__/test-helpers/environment.js +0 -1
  4. package/lib/__tests__/test-helpers/environment.js.map +1 -1
  5. package/lib/account/index.d.ts +0 -1
  6. package/lib/account/index.d.ts.map +1 -1
  7. package/lib/account/index.js +1 -4
  8. package/lib/account/index.js.map +1 -1
  9. package/lib/account/serialization.js +1 -1
  10. package/lib/account/serialization.js.map +1 -1
  11. package/lib/account/support.js +1 -1
  12. package/lib/account/support.js.map +1 -1
  13. package/lib/bridge/generic-alpaca/accountBridge.d.ts +1 -1
  14. package/lib/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
  15. package/lib/bridge/generic-alpaca/accountBridge.js +1 -2
  16. package/lib/bridge/generic-alpaca/accountBridge.js.map +1 -1
  17. package/lib/bridge/generic-alpaca/broadcast.d.ts.map +1 -1
  18. package/lib/bridge/generic-alpaca/broadcast.js +3 -3
  19. package/lib/bridge/generic-alpaca/broadcast.js.map +1 -1
  20. package/lib/bridge/generic-alpaca/currencyBridge.d.ts.map +1 -1
  21. package/lib/bridge/generic-alpaca/currencyBridge.js +3 -3
  22. package/lib/bridge/generic-alpaca/currencyBridge.js.map +1 -1
  23. package/lib/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
  24. package/lib/bridge/generic-alpaca/estimateMaxSpendable.js +1 -2
  25. package/lib/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
  26. package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  27. package/lib/bridge/generic-alpaca/getAccountShape.js +7 -16
  28. package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  29. package/lib/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
  30. package/lib/bridge/generic-alpaca/getTransactionStatus.js +1 -16
  31. package/lib/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  32. package/lib/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  33. package/lib/bridge/generic-alpaca/prepareTransaction.js +4 -38
  34. package/lib/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  35. package/lib/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  36. package/lib/bridge/generic-alpaca/signOperation.js +2 -18
  37. package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
  38. package/lib/bridge/generic-alpaca/signer/Eth.d.ts +0 -2
  39. package/lib/bridge/generic-alpaca/signer/Eth.d.ts.map +1 -1
  40. package/lib/bridge/generic-alpaca/signer/Eth.js +1 -8
  41. package/lib/bridge/generic-alpaca/signer/Eth.js.map +1 -1
  42. package/lib/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
  43. package/lib/bridge/generic-alpaca/signer/index.js +0 -7
  44. package/lib/bridge/generic-alpaca/signer/index.js.map +1 -1
  45. package/lib/bridge/generic-alpaca/types.d.ts +0 -4
  46. package/lib/bridge/generic-alpaca/types.d.ts.map +1 -1
  47. package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
  48. package/lib/bridge/generic-alpaca/utils.js +3 -12
  49. package/lib/bridge/generic-alpaca/utils.js.map +1 -1
  50. package/lib/bridge/impl.d.ts.map +1 -1
  51. package/lib/bridge/impl.js +3 -14
  52. package/lib/bridge/impl.js.map +1 -1
  53. package/lib/currencies/cryptoIcons.d.ts +3 -0
  54. package/lib/currencies/cryptoIcons.d.ts.map +1 -0
  55. package/lib/currencies/cryptoIcons.js +24 -0
  56. package/lib/currencies/cryptoIcons.js.map +1 -0
  57. package/lib/currencies/helpers.d.ts +0 -1
  58. package/lib/currencies/helpers.d.ts.map +1 -1
  59. package/lib/currencies/helpers.js +1 -7
  60. package/lib/currencies/helpers.js.map +1 -1
  61. package/lib/domain/getTokensWithFunds.d.ts +1 -7
  62. package/lib/domain/getTokensWithFunds.d.ts.map +1 -1
  63. package/lib/domain/getTokensWithFunds.js +4 -15
  64. package/lib/domain/getTokensWithFunds.js.map +1 -1
  65. package/lib/e2e/data/deviceLabelsData.d.ts.map +1 -1
  66. package/lib/e2e/data/deviceLabelsData.js +0 -1
  67. package/lib/e2e/data/deviceLabelsData.js.map +1 -1
  68. package/lib/e2e/enum/Device.d.ts +0 -1
  69. package/lib/e2e/enum/Device.d.ts.map +1 -1
  70. package/lib/e2e/enum/Device.js +0 -1
  71. package/lib/e2e/enum/Device.js.map +1 -1
  72. package/lib/e2e/families/cardano.d.ts.map +1 -1
  73. package/lib/e2e/families/cardano.js +14 -29
  74. package/lib/e2e/families/cardano.js.map +1 -1
  75. package/lib/e2e/index.d.ts +3 -26
  76. package/lib/e2e/index.d.ts.map +1 -1
  77. package/lib/e2e/index.js +1 -21
  78. package/lib/e2e/index.js.map +1 -1
  79. package/lib/e2e/speculos.d.ts.map +1 -1
  80. package/lib/e2e/speculos.js +4 -31
  81. package/lib/e2e/speculos.js.map +1 -1
  82. package/lib/e2e/speculosAppVersion.d.ts.map +1 -1
  83. package/lib/e2e/speculosAppVersion.js +2 -6
  84. package/lib/e2e/speculosAppVersion.js.map +1 -1
  85. package/lib/e2e/swap.d.ts.map +1 -1
  86. package/lib/e2e/swap.js +6 -7
  87. package/lib/e2e/swap.js.map +1 -1
  88. package/lib/env.react.d.ts +1 -1
  89. package/lib/env.react.d.ts.map +1 -1
  90. package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js +1 -1
  91. package/lib/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
  92. package/lib/exchange/swap/postSwapState.d.ts.map +1 -1
  93. package/lib/exchange/swap/postSwapState.js +6 -10
  94. package/lib/exchange/swap/postSwapState.js.map +1 -1
  95. package/lib/exchange/swap/types.d.ts +1 -3
  96. package/lib/exchange/swap/types.d.ts.map +1 -1
  97. package/lib/families/bitcoin/walletApiAdapter.d.ts.map +1 -1
  98. package/lib/families/bitcoin/walletApiAdapter.js +0 -3
  99. package/lib/families/bitcoin/walletApiAdapter.js.map +1 -1
  100. package/lib/families/canton/config.d.ts.map +1 -1
  101. package/lib/families/canton/config.js +4 -4
  102. package/lib/families/canton/config.js.map +1 -1
  103. package/lib/families/canton/react.d.ts +0 -2
  104. package/lib/families/canton/react.d.ts.map +1 -1
  105. package/lib/families/canton/react.js +1 -40
  106. package/lib/families/canton/react.js.map +1 -1
  107. package/lib/families/celo/setup.d.ts.map +1 -1
  108. package/lib/families/celo/setup.js +0 -11
  109. package/lib/families/celo/setup.js.map +1 -1
  110. package/lib/families/evm/bridge/mock.d.ts +0 -1
  111. package/lib/families/evm/bridge/mock.d.ts.map +1 -1
  112. package/lib/families/evm/bridge/mock.js +0 -12
  113. package/lib/families/evm/bridge/mock.js.map +1 -1
  114. package/lib/families/evm/setup.d.ts +4 -1
  115. package/lib/families/evm/setup.d.ts.map +1 -1
  116. package/lib/families/evm/setup.js +8 -1
  117. package/lib/families/evm/setup.js.map +1 -1
  118. package/lib/families/evm/walletApiAdapter.d.ts +0 -7
  119. package/lib/families/evm/walletApiAdapter.d.ts.map +1 -1
  120. package/lib/families/evm/walletApiAdapter.js +2 -36
  121. package/lib/families/evm/walletApiAdapter.js.map +1 -1
  122. package/lib/families/polkadot/config.js +1 -1
  123. package/lib/families/polkadot/config.js.map +1 -1
  124. package/lib/families/stacks/constants.d.ts +1 -1
  125. package/lib/families/stacks/constants.d.ts.map +1 -1
  126. package/lib/families/stacks/constants.js +1 -1
  127. package/lib/families/stacks/constants.js.map +1 -1
  128. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
  129. package/lib/featureFlags/defaultFeatures.js +1 -19
  130. package/lib/featureFlags/defaultFeatures.js.map +1 -1
  131. package/lib/featureFlags/firebaseFeatureFlags.js +1 -1
  132. package/lib/featureFlags/firebaseFeatureFlags.js.map +1 -1
  133. package/lib/featureFlags/stakePrograms/index.js +4 -4
  134. package/lib/featureFlags/stakePrograms/index.js.map +1 -1
  135. package/lib/featureFlags/useFeature.d.ts +1 -1
  136. package/lib/featureFlags/useFeature.d.ts.map +1 -1
  137. package/lib/featureFlags/useHasOverriddenFeatureFlags.js +1 -1
  138. package/lib/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -1
  139. package/lib/generated/bridge/js.d.ts +1 -0
  140. package/lib/generated/bridge/js.d.ts.map +1 -1
  141. package/lib/generated/bridge/js.js +32 -30
  142. package/lib/generated/bridge/js.js.map +1 -1
  143. package/lib/generated/bridge/mock.d.ts +0 -1
  144. package/lib/generated/bridge/mock.d.ts.map +1 -1
  145. package/lib/helpers.d.ts +0 -1
  146. package/lib/helpers.d.ts.map +1 -1
  147. package/lib/helpers.js +0 -15
  148. package/lib/helpers.js.map +1 -1
  149. package/lib/hw/getAppAndVersion.d.ts +1 -3
  150. package/lib/hw/getAppAndVersion.d.ts.map +1 -1
  151. package/lib/hw/getAppAndVersion.js +2 -2
  152. package/lib/hw/getAppAndVersion.js.map +1 -1
  153. package/lib/hw/getBitcoinLikeInfo.js +1 -1
  154. package/lib/hw/getBitcoinLikeInfo.js.map +1 -1
  155. package/lib/load/speculos.d.ts.map +1 -1
  156. package/lib/load/speculos.js +0 -1
  157. package/lib/load/speculos.js.map +1 -1
  158. package/lib/mock/account.js +1 -1
  159. package/lib/mock/account.js.map +1 -1
  160. package/lib/operation.d.ts.map +1 -1
  161. package/lib/operation.js +2 -7
  162. package/lib/operation.js.map +1 -1
  163. package/lib/postOnboarding/reducer.d.ts +0 -2
  164. package/lib/postOnboarding/reducer.d.ts.map +1 -1
  165. package/lib/react.d.ts +16 -0
  166. package/lib/react.d.ts.map +1 -0
  167. package/lib/react.js +64 -0
  168. package/lib/react.js.map +1 -0
  169. package/lib/reactNative.d.ts +16 -0
  170. package/lib/reactNative.d.ts.map +1 -0
  171. package/lib/reactNative.js +43 -0
  172. package/lib/reactNative.js.map +1 -0
  173. package/lib/wallet-api/Exchange/server.d.ts.map +1 -1
  174. package/lib/wallet-api/Exchange/server.js +1 -7
  175. package/lib/wallet-api/Exchange/server.js.map +1 -1
  176. package/lib/wallet-api/Exchange/tracking.d.ts +6 -7
  177. package/lib/wallet-api/Exchange/tracking.d.ts.map +1 -1
  178. package/lib/wallet-api/Exchange/tracking.js +13 -52
  179. package/lib/wallet-api/Exchange/tracking.js.map +1 -1
  180. package/lib/wallet-api/constants.d.ts +1 -1
  181. package/lib/wallet-api/logic.d.ts +1 -1
  182. package/lib/wallet-api/logic.d.ts.map +1 -1
  183. package/lib/wallet-api/logic.js +5 -5
  184. package/lib/wallet-api/logic.js.map +1 -1
  185. package/lib/wallet-api/react.d.ts.map +1 -1
  186. package/lib/wallet-api/react.js +6 -9
  187. package/lib/wallet-api/react.js.map +1 -1
  188. package/lib/wallet-api/tracking.d.ts +5 -5
  189. package/lib/wallet-api/tracking.d.ts.map +1 -1
  190. package/lib/wallet-api/tracking.js +10 -30
  191. package/lib/wallet-api/tracking.js.map +1 -1
  192. package/lib/wallet-api/useDappLogic.d.ts.map +1 -1
  193. package/lib/wallet-api/useDappLogic.js +20 -31
  194. package/lib/wallet-api/useDappLogic.js.map +1 -1
  195. package/lib/wallet-api/utils/extractDappURLFromManifest.js +3 -3
  196. package/lib/wallet-api/utils/extractDappURLFromManifest.js.map +1 -1
  197. package/lib/wallet-api/utils/extractURLFromManifest.js +1 -1
  198. package/lib/wallet-api/utils/extractURLFromManifest.js.map +1 -1
  199. package/lib/walletSync/getEnvironmentParams.js +6 -6
  200. package/lib/walletSync/getEnvironmentParams.js.map +1 -1
  201. package/lib-es/__tests__/test-helpers/bridge.js +1 -1
  202. package/lib-es/__tests__/test-helpers/bridge.js.map +1 -1
  203. package/lib-es/__tests__/test-helpers/environment.js +0 -1
  204. package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
  205. package/lib-es/account/index.d.ts +0 -1
  206. package/lib-es/account/index.d.ts.map +1 -1
  207. package/lib-es/account/index.js +0 -1
  208. package/lib-es/account/index.js.map +1 -1
  209. package/lib-es/account/serialization.js +1 -1
  210. package/lib-es/account/serialization.js.map +1 -1
  211. package/lib-es/account/support.js +1 -1
  212. package/lib-es/account/support.js.map +1 -1
  213. package/lib-es/bridge/generic-alpaca/accountBridge.d.ts +1 -1
  214. package/lib-es/bridge/generic-alpaca/accountBridge.d.ts.map +1 -1
  215. package/lib-es/bridge/generic-alpaca/accountBridge.js +1 -2
  216. package/lib-es/bridge/generic-alpaca/accountBridge.js.map +1 -1
  217. package/lib-es/bridge/generic-alpaca/broadcast.d.ts.map +1 -1
  218. package/lib-es/bridge/generic-alpaca/broadcast.js +3 -3
  219. package/lib-es/bridge/generic-alpaca/broadcast.js.map +1 -1
  220. package/lib-es/bridge/generic-alpaca/currencyBridge.d.ts.map +1 -1
  221. package/lib-es/bridge/generic-alpaca/currencyBridge.js +3 -3
  222. package/lib-es/bridge/generic-alpaca/currencyBridge.js.map +1 -1
  223. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.d.ts.map +1 -1
  224. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js +1 -2
  225. package/lib-es/bridge/generic-alpaca/estimateMaxSpendable.js.map +1 -1
  226. package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  227. package/lib-es/bridge/generic-alpaca/getAccountShape.js +7 -16
  228. package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  229. package/lib-es/bridge/generic-alpaca/getTransactionStatus.d.ts.map +1 -1
  230. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js +1 -16
  231. package/lib-es/bridge/generic-alpaca/getTransactionStatus.js.map +1 -1
  232. package/lib-es/bridge/generic-alpaca/prepareTransaction.d.ts.map +1 -1
  233. package/lib-es/bridge/generic-alpaca/prepareTransaction.js +4 -38
  234. package/lib-es/bridge/generic-alpaca/prepareTransaction.js.map +1 -1
  235. package/lib-es/bridge/generic-alpaca/signOperation.d.ts.map +1 -1
  236. package/lib-es/bridge/generic-alpaca/signOperation.js +2 -18
  237. package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
  238. package/lib-es/bridge/generic-alpaca/signer/Eth.d.ts +0 -2
  239. package/lib-es/bridge/generic-alpaca/signer/Eth.d.ts.map +1 -1
  240. package/lib-es/bridge/generic-alpaca/signer/Eth.js +0 -4
  241. package/lib-es/bridge/generic-alpaca/signer/Eth.js.map +1 -1
  242. package/lib-es/bridge/generic-alpaca/signer/index.d.ts.map +1 -1
  243. package/lib-es/bridge/generic-alpaca/signer/index.js +0 -7
  244. package/lib-es/bridge/generic-alpaca/signer/index.js.map +1 -1
  245. package/lib-es/bridge/generic-alpaca/types.d.ts +0 -4
  246. package/lib-es/bridge/generic-alpaca/types.d.ts.map +1 -1
  247. package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
  248. package/lib-es/bridge/generic-alpaca/utils.js +3 -12
  249. package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
  250. package/lib-es/bridge/impl.d.ts.map +1 -1
  251. package/lib-es/bridge/impl.js +3 -14
  252. package/lib-es/bridge/impl.js.map +1 -1
  253. package/lib-es/currencies/cryptoIcons.d.ts +3 -0
  254. package/lib-es/currencies/cryptoIcons.d.ts.map +1 -0
  255. package/lib-es/currencies/cryptoIcons.js +20 -0
  256. package/lib-es/currencies/cryptoIcons.js.map +1 -0
  257. package/lib-es/currencies/helpers.d.ts +0 -1
  258. package/lib-es/currencies/helpers.d.ts.map +1 -1
  259. package/lib-es/currencies/helpers.js +0 -5
  260. package/lib-es/currencies/helpers.js.map +1 -1
  261. package/lib-es/domain/getTokensWithFunds.d.ts +1 -7
  262. package/lib-es/domain/getTokensWithFunds.d.ts.map +1 -1
  263. package/lib-es/domain/getTokensWithFunds.js +3 -13
  264. package/lib-es/domain/getTokensWithFunds.js.map +1 -1
  265. package/lib-es/e2e/data/deviceLabelsData.d.ts.map +1 -1
  266. package/lib-es/e2e/data/deviceLabelsData.js +0 -1
  267. package/lib-es/e2e/data/deviceLabelsData.js.map +1 -1
  268. package/lib-es/e2e/enum/Device.d.ts +0 -1
  269. package/lib-es/e2e/enum/Device.d.ts.map +1 -1
  270. package/lib-es/e2e/enum/Device.js +0 -1
  271. package/lib-es/e2e/enum/Device.js.map +1 -1
  272. package/lib-es/e2e/families/cardano.d.ts.map +1 -1
  273. package/lib-es/e2e/families/cardano.js +14 -29
  274. package/lib-es/e2e/families/cardano.js.map +1 -1
  275. package/lib-es/e2e/index.d.ts +3 -26
  276. package/lib-es/e2e/index.d.ts.map +1 -1
  277. package/lib-es/e2e/index.js +0 -16
  278. package/lib-es/e2e/index.js.map +1 -1
  279. package/lib-es/e2e/speculos.d.ts.map +1 -1
  280. package/lib-es/e2e/speculos.js +4 -31
  281. package/lib-es/e2e/speculos.js.map +1 -1
  282. package/lib-es/e2e/speculosAppVersion.d.ts.map +1 -1
  283. package/lib-es/e2e/speculosAppVersion.js +2 -6
  284. package/lib-es/e2e/speculosAppVersion.js.map +1 -1
  285. package/lib-es/e2e/swap.d.ts.map +1 -1
  286. package/lib-es/e2e/swap.js +6 -7
  287. package/lib-es/e2e/swap.js.map +1 -1
  288. package/lib-es/env.react.d.ts +1 -1
  289. package/lib-es/env.react.d.ts.map +1 -1
  290. package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js +1 -1
  291. package/lib-es/exchange/swap/api/v5/fetchCurrencyFrom.js.map +1 -1
  292. package/lib-es/exchange/swap/postSwapState.d.ts.map +1 -1
  293. package/lib-es/exchange/swap/postSwapState.js +6 -10
  294. package/lib-es/exchange/swap/postSwapState.js.map +1 -1
  295. package/lib-es/exchange/swap/types.d.ts +1 -3
  296. package/lib-es/exchange/swap/types.d.ts.map +1 -1
  297. package/lib-es/families/bitcoin/walletApiAdapter.d.ts.map +1 -1
  298. package/lib-es/families/bitcoin/walletApiAdapter.js +0 -3
  299. package/lib-es/families/bitcoin/walletApiAdapter.js.map +1 -1
  300. package/lib-es/families/canton/config.d.ts.map +1 -1
  301. package/lib-es/families/canton/config.js +4 -4
  302. package/lib-es/families/canton/config.js.map +1 -1
  303. package/lib-es/families/canton/react.d.ts +0 -2
  304. package/lib-es/families/canton/react.d.ts.map +1 -1
  305. package/lib-es/families/canton/react.js +1 -38
  306. package/lib-es/families/canton/react.js.map +1 -1
  307. package/lib-es/families/celo/setup.d.ts.map +1 -1
  308. package/lib-es/families/celo/setup.js +0 -11
  309. package/lib-es/families/celo/setup.js.map +1 -1
  310. package/lib-es/families/evm/bridge/mock.d.ts +0 -1
  311. package/lib-es/families/evm/bridge/mock.d.ts.map +1 -1
  312. package/lib-es/families/evm/bridge/mock.js +0 -12
  313. package/lib-es/families/evm/bridge/mock.js.map +1 -1
  314. package/lib-es/families/evm/setup.d.ts +4 -1
  315. package/lib-es/families/evm/setup.d.ts.map +1 -1
  316. package/lib-es/families/evm/setup.js +8 -2
  317. package/lib-es/families/evm/setup.js.map +1 -1
  318. package/lib-es/families/evm/walletApiAdapter.d.ts +0 -7
  319. package/lib-es/families/evm/walletApiAdapter.d.ts.map +1 -1
  320. package/lib-es/families/evm/walletApiAdapter.js +1 -30
  321. package/lib-es/families/evm/walletApiAdapter.js.map +1 -1
  322. package/lib-es/families/polkadot/config.js +1 -1
  323. package/lib-es/families/polkadot/config.js.map +1 -1
  324. package/lib-es/families/stacks/constants.d.ts +1 -1
  325. package/lib-es/families/stacks/constants.d.ts.map +1 -1
  326. package/lib-es/families/stacks/constants.js +1 -1
  327. package/lib-es/families/stacks/constants.js.map +1 -1
  328. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
  329. package/lib-es/featureFlags/defaultFeatures.js +1 -19
  330. package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
  331. package/lib-es/featureFlags/firebaseFeatureFlags.js +1 -1
  332. package/lib-es/featureFlags/firebaseFeatureFlags.js.map +1 -1
  333. package/lib-es/featureFlags/stakePrograms/index.js +4 -4
  334. package/lib-es/featureFlags/stakePrograms/index.js.map +1 -1
  335. package/lib-es/featureFlags/useFeature.d.ts +1 -1
  336. package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
  337. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js +1 -1
  338. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -1
  339. package/lib-es/generated/bridge/js.d.ts +1 -0
  340. package/lib-es/generated/bridge/js.d.ts.map +1 -1
  341. package/lib-es/generated/bridge/js.js +2 -0
  342. package/lib-es/generated/bridge/js.js.map +1 -1
  343. package/lib-es/generated/bridge/mock.d.ts +0 -1
  344. package/lib-es/generated/bridge/mock.d.ts.map +1 -1
  345. package/lib-es/helpers.d.ts +0 -1
  346. package/lib-es/helpers.d.ts.map +1 -1
  347. package/lib-es/helpers.js +0 -1
  348. package/lib-es/helpers.js.map +1 -1
  349. package/lib-es/hw/getAppAndVersion.d.ts +1 -3
  350. package/lib-es/hw/getAppAndVersion.d.ts.map +1 -1
  351. package/lib-es/hw/getAppAndVersion.js +2 -2
  352. package/lib-es/hw/getAppAndVersion.js.map +1 -1
  353. package/lib-es/hw/getBitcoinLikeInfo.js +1 -1
  354. package/lib-es/hw/getBitcoinLikeInfo.js.map +1 -1
  355. package/lib-es/load/speculos.d.ts.map +1 -1
  356. package/lib-es/load/speculos.js +0 -1
  357. package/lib-es/load/speculos.js.map +1 -1
  358. package/lib-es/mock/account.js +1 -1
  359. package/lib-es/mock/account.js.map +1 -1
  360. package/lib-es/operation.d.ts.map +1 -1
  361. package/lib-es/operation.js +2 -7
  362. package/lib-es/operation.js.map +1 -1
  363. package/lib-es/postOnboarding/reducer.d.ts +0 -2
  364. package/lib-es/postOnboarding/reducer.d.ts.map +1 -1
  365. package/lib-es/react.d.ts +16 -0
  366. package/lib-es/react.d.ts.map +1 -0
  367. package/lib-es/react.js +33 -0
  368. package/lib-es/react.js.map +1 -0
  369. package/lib-es/reactNative.d.ts +16 -0
  370. package/lib-es/reactNative.d.ts.map +1 -0
  371. package/lib-es/reactNative.js +15 -0
  372. package/lib-es/reactNative.js.map +1 -0
  373. package/lib-es/wallet-api/Exchange/server.d.ts.map +1 -1
  374. package/lib-es/wallet-api/Exchange/server.js +1 -7
  375. package/lib-es/wallet-api/Exchange/server.js.map +1 -1
  376. package/lib-es/wallet-api/Exchange/tracking.d.ts +6 -7
  377. package/lib-es/wallet-api/Exchange/tracking.d.ts.map +1 -1
  378. package/lib-es/wallet-api/Exchange/tracking.js +13 -52
  379. package/lib-es/wallet-api/Exchange/tracking.js.map +1 -1
  380. package/lib-es/wallet-api/constants.d.ts +1 -1
  381. package/lib-es/wallet-api/logic.d.ts +1 -1
  382. package/lib-es/wallet-api/logic.d.ts.map +1 -1
  383. package/lib-es/wallet-api/logic.js +5 -5
  384. package/lib-es/wallet-api/logic.js.map +1 -1
  385. package/lib-es/wallet-api/react.d.ts.map +1 -1
  386. package/lib-es/wallet-api/react.js +6 -9
  387. package/lib-es/wallet-api/react.js.map +1 -1
  388. package/lib-es/wallet-api/tracking.d.ts +5 -5
  389. package/lib-es/wallet-api/tracking.d.ts.map +1 -1
  390. package/lib-es/wallet-api/tracking.js +10 -30
  391. package/lib-es/wallet-api/tracking.js.map +1 -1
  392. package/lib-es/wallet-api/useDappLogic.d.ts.map +1 -1
  393. package/lib-es/wallet-api/useDappLogic.js +20 -31
  394. package/lib-es/wallet-api/useDappLogic.js.map +1 -1
  395. package/lib-es/wallet-api/utils/extractDappURLFromManifest.js +3 -3
  396. package/lib-es/wallet-api/utils/extractDappURLFromManifest.js.map +1 -1
  397. package/lib-es/wallet-api/utils/extractURLFromManifest.js +1 -1
  398. package/lib-es/wallet-api/utils/extractURLFromManifest.js.map +1 -1
  399. package/lib-es/walletSync/getEnvironmentParams.js +6 -6
  400. package/lib-es/walletSync/getEnvironmentParams.js.map +1 -1
  401. package/package.json +90 -82
  402. package/react.js +1 -0
  403. package/reactNative.js +1 -0
  404. package/src/__tests__/test-helpers/bridge.ts +1 -1
  405. package/src/__tests__/test-helpers/environment.ts +0 -1
  406. package/src/account/index.ts +0 -6
  407. package/src/account/serialization.ts +1 -1
  408. package/src/account/support.ts +1 -1
  409. package/src/bridge/generic-alpaca/accountBridge.ts +2 -3
  410. package/src/bridge/generic-alpaca/broadcast.ts +3 -6
  411. package/src/bridge/generic-alpaca/currencyBridge.ts +3 -3
  412. package/src/bridge/generic-alpaca/estimateMaxSpendable.ts +1 -2
  413. package/src/bridge/generic-alpaca/getAccountShape.ts +12 -24
  414. package/src/bridge/generic-alpaca/getTransactionStatus.ts +1 -16
  415. package/src/bridge/generic-alpaca/prepareTransaction.ts +10 -44
  416. package/src/bridge/generic-alpaca/signOperation.ts +2 -18
  417. package/src/bridge/generic-alpaca/signer/Eth.ts +1 -5
  418. package/src/bridge/generic-alpaca/signer/index.ts +0 -7
  419. package/src/bridge/generic-alpaca/tests/getAccountShape.test.ts +2 -2
  420. package/src/bridge/generic-alpaca/tests/prepareTransaction.test.ts +0 -32
  421. package/src/bridge/generic-alpaca/types.ts +0 -4
  422. package/src/bridge/generic-alpaca/utils.test.ts +0 -4
  423. package/src/bridge/generic-alpaca/utils.ts +3 -15
  424. package/src/bridge/impl.ts +3 -16
  425. package/src/currencies/cryptoIcons.test.ts +54 -0
  426. package/src/currencies/cryptoIcons.ts +21 -0
  427. package/src/currencies/helpers.test.ts +1 -10
  428. package/src/currencies/helpers.ts +0 -6
  429. package/src/domain/getTokensWithFunds.ts +5 -18
  430. package/src/e2e/data/deviceLabelsData.ts +0 -1
  431. package/src/e2e/enum/Device.ts +0 -1
  432. package/src/e2e/families/cardano.ts +14 -32
  433. package/src/e2e/index.ts +0 -20
  434. package/src/e2e/speculos.ts +4 -35
  435. package/src/e2e/speculosAppVersion.ts +2 -8
  436. package/src/e2e/swap.ts +7 -8
  437. package/src/exchange/swap/api/v5/fetchCurrencyFrom.ts +1 -1
  438. package/src/exchange/swap/postSwapState.ts +5 -10
  439. package/src/exchange/swap/types.ts +1 -3
  440. package/src/families/bitcoin/walletApiAdapter.test.ts +0 -36
  441. package/src/families/bitcoin/walletApiAdapter.ts +0 -4
  442. package/src/families/canton/config.ts +4 -5
  443. package/src/families/canton/react.ts +1 -45
  444. package/src/families/celo/setup.ts +0 -12
  445. package/src/families/cosmos/datasets/__snapshots__/cosmos.integration.test.ts.snap +4 -73
  446. package/src/families/cosmos/datasets/__snapshots__/cryptoOrg.integration.test.ts.snap +2 -2
  447. package/src/families/cosmos/datasets/__snapshots__/injective.integration.test.ts.snap +2 -2
  448. package/src/families/cosmos/datasets/__snapshots__/mantra.integration.test.ts.snap +2 -2
  449. package/src/families/cosmos/datasets/__snapshots__/osmosis.integration.test.ts.snap +2 -2
  450. package/src/families/cosmos/datasets/__snapshots__/persistence.integration.test.ts.snap +4 -4
  451. package/src/families/cosmos/datasets/__snapshots__/stargaze.integration.test.ts.snap +2 -2
  452. package/src/families/evm/bridge/mock.ts +0 -14
  453. package/src/families/evm/setup.ts +22 -3
  454. package/src/families/evm/walletApiAdapter.ts +1 -33
  455. package/src/families/hedera/__snapshots__/bridge.integration.test.ts.snap +17 -278
  456. package/src/families/polkadot/__snapshots__/bridge.integration.test.ts.snap +3653 -6
  457. package/src/families/polkadot/config.ts +1 -1
  458. package/src/families/stacks/__snapshots__/bridge.integration.test.ts.snap +17 -1536
  459. package/src/families/stacks/__tests__/sync.integration.test.ts +2 -2
  460. package/src/families/stacks/constants.ts +1 -1
  461. package/src/families/stellar/__snapshots__/bridge.integration.test.ts.snap +9 -9
  462. package/src/featureFlags/defaultFeatures.ts +1 -19
  463. package/src/featureFlags/firebaseFeatureFlags.ts +1 -1
  464. package/src/featureFlags/stakePrograms/index.ts +4 -4
  465. package/src/featureFlags/useHasOverriddenFeatureFlags.ts +1 -1
  466. package/src/generated/bridge/js.ts +2 -0
  467. package/src/helpers.ts +0 -2
  468. package/src/hw/getAppAndVersion.ts +1 -2
  469. package/src/hw/getBitcoinLikeInfo.ts +1 -1
  470. package/src/load/speculos.ts +0 -1
  471. package/src/mock/account.ts +1 -1
  472. package/src/operation.ts +2 -10
  473. package/src/react.tsx +43 -0
  474. package/src/reactNative.ts +23 -0
  475. package/src/reactNativeSvg.d.ts +19 -0
  476. package/src/wallet-api/Exchange/server.ts +0 -8
  477. package/src/wallet-api/Exchange/tracking.ts +13 -56
  478. package/src/wallet-api/logic.ts +4 -5
  479. package/src/wallet-api/react.ts +5 -10
  480. package/src/wallet-api/tracking.ts +10 -30
  481. package/src/wallet-api/useDappLogic.ts +20 -32
  482. package/src/wallet-api/utils/extractDappURLFromManifest.ts +3 -3
  483. package/src/wallet-api/utils/extractURLFromManifest.ts +1 -1
  484. package/src/walletSync/getEnvironmentParams.ts +6 -6
  485. package/lib/account/recentAddresses.d.ts +0 -10
  486. package/lib/account/recentAddresses.d.ts.map +0 -1
  487. package/lib/account/recentAddresses.js +0 -60
  488. package/lib/account/recentAddresses.js.map +0 -1
  489. package/lib/bridge/generic-alpaca/postSync.d.ts +0 -16
  490. package/lib/bridge/generic-alpaca/postSync.d.ts.map +0 -1
  491. package/lib/bridge/generic-alpaca/postSync.js +0 -44
  492. package/lib/bridge/generic-alpaca/postSync.js.map +0 -1
  493. package/lib/domain/getTotalStakeableAssets.d.ts +0 -10
  494. package/lib/domain/getTotalStakeableAssets.d.ts.map +0 -1
  495. package/lib/domain/getTotalStakeableAssets.js +0 -35
  496. package/lib/domain/getTotalStakeableAssets.js.map +0 -1
  497. package/lib/e2e/data/regexes.d.ts +0 -2
  498. package/lib/e2e/data/regexes.d.ts.map +0 -1
  499. package/lib/e2e/data/regexes.js +0 -5
  500. package/lib/e2e/data/regexes.js.map +0 -1
  501. package/lib/families/hedera/react.d.ts +0 -6
  502. package/lib/families/hedera/react.d.ts.map +0 -1
  503. package/lib/families/hedera/react.js +0 -50
  504. package/lib/families/hedera/react.js.map +0 -1
  505. package/lib/helpers/cryptoIconSize.d.ts +0 -3
  506. package/lib/helpers/cryptoIconSize.d.ts.map +0 -1
  507. package/lib/helpers/cryptoIconSize.js +0 -40
  508. package/lib/helpers/cryptoIconSize.js.map +0 -1
  509. package/lib/hooks/useHtmlLinkSegments.d.ts +0 -19
  510. package/lib/hooks/useHtmlLinkSegments.d.ts.map +0 -1
  511. package/lib/hooks/useHtmlLinkSegments.js +0 -128
  512. package/lib/hooks/useHtmlLinkSegments.js.map +0 -1
  513. package/lib-es/account/recentAddresses.d.ts +0 -10
  514. package/lib-es/account/recentAddresses.d.ts.map +0 -1
  515. package/lib-es/account/recentAddresses.js +0 -55
  516. package/lib-es/account/recentAddresses.js.map +0 -1
  517. package/lib-es/bridge/generic-alpaca/postSync.d.ts +0 -16
  518. package/lib-es/bridge/generic-alpaca/postSync.d.ts.map +0 -1
  519. package/lib-es/bridge/generic-alpaca/postSync.js +0 -37
  520. package/lib-es/bridge/generic-alpaca/postSync.js.map +0 -1
  521. package/lib-es/domain/getTotalStakeableAssets.d.ts +0 -10
  522. package/lib-es/domain/getTotalStakeableAssets.d.ts.map +0 -1
  523. package/lib-es/domain/getTotalStakeableAssets.js +0 -31
  524. package/lib-es/domain/getTotalStakeableAssets.js.map +0 -1
  525. package/lib-es/e2e/data/regexes.d.ts +0 -2
  526. package/lib-es/e2e/data/regexes.d.ts.map +0 -1
  527. package/lib-es/e2e/data/regexes.js +0 -2
  528. package/lib-es/e2e/data/regexes.js.map +0 -1
  529. package/lib-es/families/hedera/react.d.ts +0 -6
  530. package/lib-es/families/hedera/react.d.ts.map +0 -1
  531. package/lib-es/families/hedera/react.js +0 -41
  532. package/lib-es/families/hedera/react.js.map +0 -1
  533. package/lib-es/helpers/cryptoIconSize.d.ts +0 -3
  534. package/lib-es/helpers/cryptoIconSize.d.ts.map +0 -1
  535. package/lib-es/helpers/cryptoIconSize.js +0 -35
  536. package/lib-es/helpers/cryptoIconSize.js.map +0 -1
  537. package/lib-es/hooks/useHtmlLinkSegments.d.ts +0 -19
  538. package/lib-es/hooks/useHtmlLinkSegments.d.ts.map +0 -1
  539. package/lib-es/hooks/useHtmlLinkSegments.js +0 -121
  540. package/lib-es/hooks/useHtmlLinkSegments.js.map +0 -1
  541. package/src/account/recentAddresses.test.ts +0 -104
  542. package/src/account/recentAddresses.ts +0 -84
  543. package/src/bridge/generic-alpaca/postSync.test.ts +0 -97
  544. package/src/bridge/generic-alpaca/postSync.ts +0 -42
  545. package/src/domain/getTotalStakeableAssets.test.ts +0 -267
  546. package/src/domain/getTotalStakeableAssets.ts +0 -47
  547. package/src/e2e/data/regexes.ts +0 -1
  548. package/src/families/canton/react.test.ts +0 -147
  549. package/src/families/hedera/react.test.ts +0 -272
  550. package/src/families/hedera/react.ts +0 -63
  551. package/src/helpers/cryptoIconSize.ts +0 -25
  552. package/src/hooks/__tests__/useHtmlLinkSegments.test.ts +0 -105
  553. package/src/hooks/useHtmlLinkSegments.ts +0 -158
@@ -1,104 +0,0 @@
1
- import { RecentAddressesStore, setupRecentAddressesStore, getRecentAddressesStore } from ".";
2
- import { RECENT_ADDRESSES_COUNT_LIMIT } from "./recentAddresses";
3
-
4
- describe("RecentAddressesStore", () => {
5
- const onAddAddressCompleteMock = jest.fn();
6
- let store: RecentAddressesStore;
7
-
8
- beforeEach(() => {
9
- onAddAddressCompleteMock.mockClear();
10
- setupRecentAddressesStore({}, onAddAddressCompleteMock);
11
- store = getRecentAddressesStore();
12
- });
13
-
14
- it("should add one address and return this only address", async () => {
15
- const newAddress = "0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3";
16
- await store.addAddress("ethereum", newAddress);
17
- const addresses = store.getAddresses("ethereum");
18
- expect(addresses).toEqual([newAddress]);
19
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(1);
20
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress] });
21
- });
22
-
23
- it("should add a second address and return addresses sorted by insertion", async () => {
24
- const newAddress = "0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3";
25
- await store.addAddress("ethereum", newAddress);
26
- let addresses = store.getAddresses("ethereum");
27
- expect(addresses).toEqual([newAddress]);
28
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(1);
29
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress] });
30
-
31
- const newAddress2 = "0xB69B37A4Fb4A18b3258f974ff6e9f529AD2647b1";
32
- await store.addAddress("ethereum", newAddress2);
33
- addresses = store.getAddresses("ethereum");
34
- expect(addresses).toEqual([newAddress2, newAddress]);
35
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(2);
36
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress2, newAddress] });
37
- });
38
-
39
- it("should replace at first place when an address is already saved", async () => {
40
- const newAddress = "0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3";
41
- await store.addAddress("ethereum", newAddress);
42
- let addresses = store.getAddresses("ethereum");
43
- expect(addresses).toEqual([newAddress]);
44
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(1);
45
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress] });
46
-
47
- const newAddress2 = "0xB69B37A4Fb4A18b3258f974ff6e9f529AD2647b1";
48
- await store.addAddress("ethereum", newAddress2);
49
- addresses = store.getAddresses("ethereum");
50
- expect(addresses).toEqual([newAddress2, newAddress]);
51
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(2);
52
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress2, newAddress] });
53
-
54
- await store.addAddress("ethereum", newAddress);
55
- addresses = store.getAddresses("ethereum");
56
- expect(addresses).toEqual([newAddress, newAddress2]);
57
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(3);
58
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress, newAddress2] });
59
- });
60
-
61
- it("should replace at first place and remove last element when addresses exceed count limit", async () => {
62
- let expectedAddresses: string[] = [];
63
- for (let index = 0; index < RECENT_ADDRESSES_COUNT_LIMIT; index++) {
64
- await store.addAddress("ethereum", `0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3${index}`);
65
- expectedAddresses.unshift(`0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3${index}`);
66
- }
67
-
68
- let addresses = store.getAddresses("ethereum");
69
- expect(addresses).toEqual(expectedAddresses);
70
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(RECENT_ADDRESSES_COUNT_LIMIT);
71
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: expectedAddresses });
72
-
73
- const newAddress2 = "0xB69B37A4Fb4A18b3258f974ff6e9f529AD2647b1";
74
- expectedAddresses.splice(expectedAddresses.length - 1, 1);
75
- expectedAddresses = [newAddress2, ...expectedAddresses];
76
-
77
- await store.addAddress("ethereum", newAddress2);
78
- addresses = store.getAddresses("ethereum");
79
- expect(addresses).toEqual(expectedAddresses);
80
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(RECENT_ADDRESSES_COUNT_LIMIT + 1);
81
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: expectedAddresses });
82
- });
83
-
84
- it("should add an address of a different currency", async () => {
85
- const newAddress = "0x66c4371aE8FFeD2ec1c2EBbbcCfb7E494181E1E3";
86
- await store.addAddress("ethereum", newAddress);
87
-
88
- let addresses = store.getAddresses("ethereum");
89
- expect(addresses).toEqual([newAddress]);
90
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(1);
91
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({ ethereum: [newAddress] });
92
-
93
- const newAddress2 = "bc1pxlmrudqyq8qd8pfsc4mpmlaw56x6vtcr9m8nvp8kj3gckefc4kmqhkg4l7";
94
- await store.addAddress("bitcoin", newAddress2);
95
-
96
- addresses = store.getAddresses("bitcoin");
97
- expect(addresses).toEqual([newAddress2]);
98
- expect(onAddAddressCompleteMock).toHaveBeenCalledTimes(2);
99
- expect(onAddAddressCompleteMock).toHaveBeenCalledWith({
100
- ethereum: [newAddress],
101
- bitcoin: [newAddress2],
102
- });
103
- });
104
- });
@@ -1,84 +0,0 @@
1
- export const RECENT_ADDRESSES_COUNT_LIMIT = 12;
2
-
3
- export type RecentAddressesCache = Record<string, string[]>;
4
-
5
- export interface RecentAddressesStore {
6
- addAddress(currency: string, address: string): void;
7
- syncAddresses(cache: RecentAddressesCache): void;
8
- getAddresses(currency: string): string[];
9
- }
10
-
11
- type CallbackMode = "triggerCallback" | "skipCallback";
12
-
13
- let recentAddressesStore: RecentAddressesStore | null = null;
14
-
15
- export function getRecentAddressesStore(): RecentAddressesStore {
16
- if (recentAddressesStore === null) {
17
- throw new Error(
18
- "Recent addresses store instance is null, please call function setupRecentAddressesStore in application initialization",
19
- );
20
- }
21
- return recentAddressesStore;
22
- }
23
-
24
- export function setupRecentAddressesStore(
25
- addressesByCurrency: RecentAddressesCache,
26
- onAddAddressComplete: (addressesByCurrency: RecentAddressesCache) => void,
27
- ): void {
28
- recentAddressesStore = new RecentAddressesStoreImpl(addressesByCurrency, onAddAddressComplete);
29
- }
30
-
31
- class RecentAddressesStoreImpl implements RecentAddressesStore {
32
- private addressesByCurrency: RecentAddressesCache = {};
33
- private readonly onAddAddressComplete: (addressesByCurrency: Record<string, string[]>) => void;
34
-
35
- constructor(
36
- addressesByCurrency: RecentAddressesCache,
37
- onAddAddressComplete: (addressesByCurrency: RecentAddressesCache) => void,
38
- ) {
39
- this.addressesByCurrency = { ...addressesByCurrency };
40
- this.onAddAddressComplete = onAddAddressComplete;
41
- }
42
-
43
- addAddress(currency: string, address: string): void {
44
- this.addAddressToCache(currency, address, "triggerCallback");
45
- }
46
-
47
- syncAddresses(cache: RecentAddressesCache): void {
48
- const previousAddresses = { ...this.addressesByCurrency };
49
- this.addressesByCurrency = { ...cache };
50
- for (const currency in previousAddresses) {
51
- for (const address of previousAddresses[currency]) {
52
- this.addAddressToCache(currency, address, "skipCallback");
53
- }
54
- }
55
-
56
- this.onAddAddressComplete(this.addressesByCurrency);
57
- }
58
-
59
- getAddresses(currency: string): string[] {
60
- const addresses = this.addressesByCurrency[currency];
61
- return addresses ?? [];
62
- }
63
-
64
- private addAddressToCache(currency: string, address: string, callbackMode: CallbackMode): void {
65
- if (!this.addressesByCurrency[currency]) {
66
- this.addressesByCurrency[currency] = [];
67
- }
68
-
69
- const addresses = this.addressesByCurrency[currency];
70
- const addressIndex = addresses.indexOf(address);
71
- if (addressIndex !== -1) {
72
- addresses.splice(addressIndex, 1);
73
- } else if (addresses.length >= RECENT_ADDRESSES_COUNT_LIMIT) {
74
- addresses.pop();
75
- }
76
-
77
- addresses.unshift(address);
78
- this.addressesByCurrency[currency] = [...addresses];
79
-
80
- if (callbackMode === "triggerCallback") {
81
- this.onAddAddressComplete(this.addressesByCurrency);
82
- }
83
- }
84
- }
@@ -1,97 +0,0 @@
1
- import type { Account } from "@ledgerhq/types-live";
2
- import { postSync } from "./postSync";
3
- import BigNumber from "bignumber.js";
4
-
5
- describe("postSync", () => {
6
- it("removes confirmed and outdated native operations from the pending pool", () => {
7
- const initialAccount = {
8
- operations: [{ hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" }],
9
- pendingOperations: [
10
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "IN" },
11
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "OUT" },
12
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
13
- ],
14
- } as Account;
15
- const synced = {
16
- operations: [
17
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "OUT" },
18
- { hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" },
19
- ],
20
- pendingOperations: [
21
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "IN" },
22
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "OUT" },
23
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
24
- ],
25
- } as Account;
26
-
27
- expect(postSync(initialAccount, synced)).toMatchObject({
28
- operations: [
29
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "OUT" },
30
- { hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" },
31
- ],
32
- pendingOperations: [
33
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
34
- ],
35
- });
36
- });
37
-
38
- it("removes confirmed and outdated token operations from the pending pool", () => {
39
- const initialAccount = {
40
- operations: [{ hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" }],
41
- pendingOperations: [
42
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "NONE" },
43
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "FEES" },
44
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
45
- ],
46
- subAccounts: [
47
- {
48
- pendingOperations: [
49
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "IN" },
50
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "FEES" },
51
- ],
52
- },
53
- ],
54
- } as Account;
55
- const synced = {
56
- operations: [
57
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "FEES" },
58
- { hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" },
59
- ],
60
- pendingOperations: [
61
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "NONE" },
62
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "FEES" },
63
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
64
- ],
65
- subAccounts: [
66
- {
67
- operations: [{ hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "OUT" }],
68
- pendingOperations: [
69
- { hash: "outdated", transactionSequenceNumber: new BigNumber(3), type: "IN" },
70
- ],
71
- },
72
- ],
73
- } as Account;
74
-
75
- expect(postSync(initialAccount, synced)).toMatchObject({
76
- operations: [
77
- { hash: "hash1", transactionSequenceNumber: new BigNumber(5), type: "FEES" },
78
- { hash: "hash0", transactionSequenceNumber: new BigNumber(4), type: "OUT" },
79
- ],
80
- pendingOperations: [
81
- { hash: "hash2", transactionSequenceNumber: new BigNumber(6), type: "IN" },
82
- ],
83
- subAccounts: [
84
- {
85
- operations: [
86
- {
87
- hash: "hash1",
88
- transactionSequenceNumber: new BigNumber(5),
89
- type: "OUT",
90
- },
91
- ],
92
- pendingOperations: [],
93
- },
94
- ],
95
- });
96
- });
97
- });
@@ -1,42 +0,0 @@
1
- import type { Account, AccountLike, Operation } from "@ledgerhq/types-live";
2
- import BigNumber from "bignumber.js";
3
-
4
- /**
5
- * After each sync or scan, remove operations from the pending pools if necessary
6
- * Operations stay pending if and only if
7
- * - they are confirmed, i.e. their hash appear in the operation list
8
- * - they are not outdated, i.e. their sequence number is at least greater than the
9
- * sequence number of the latest transaction
10
- * NOTE Compared to the default behaviour
11
- * - pending operations of token accounts are cleaned up, so we don't see both pending and completed
12
- * sub operations in the operation details drawer
13
- * - pending operations are cleaned if their hash already belong to the completed operations, preventing
14
- * undesired replacement (ex: optimistic operation for self token sending on EVM is incomplete, since
15
- * it only contains the OUT sub operation)
16
- */
17
- export function postSync(initial: Account, synced: Account): Account {
18
- const lastOperation = synced.operations.find(op => ["OUT", "FEES"].includes(op.type));
19
- const latestSequence = lastOperation?.transactionSequenceNumber || new BigNumber(-1);
20
-
21
- function isPending(account: AccountLike, op: Operation): boolean {
22
- return (
23
- // Operation is not confirmed
24
- !account.operations.some(o => o.hash === op.hash) &&
25
- // Operation is not outdated
26
- op.transactionSequenceNumber !== undefined &&
27
- op.transactionSequenceNumber.gt(latestSequence)
28
- );
29
- }
30
-
31
- const pendingOperations = initial.pendingOperations.length
32
- ? initial.pendingOperations.filter(op => isPending(synced, op))
33
- : [];
34
- const subAccounts = synced.subAccounts?.length
35
- ? synced.subAccounts.map(subAccount => ({
36
- ...subAccount,
37
- pendingOperations: subAccount.pendingOperations.filter(op => isPending(subAccount, op)),
38
- }))
39
- : [];
40
-
41
- return { ...synced, pendingOperations, subAccounts };
42
- }
@@ -1,267 +0,0 @@
1
- import { genAccount } from "@ledgerhq/coin-framework/lib/mocks/account";
2
- import { getCryptoCurrencyById } from "../currencies/index";
3
- import { Account } from "@ledgerhq/types-live";
4
- import type { TokenCurrency } from "@ledgerhq/types-cryptoassets";
5
- import BigNumber from "bignumber.js";
6
- import { getTotalStakeableAssets } from "./getTotalStakeableAssets";
7
- import { setupMockCryptoAssetsStore } from "@ledgerhq/cryptoassets/cal-client/test-helpers";
8
-
9
- // Setup mock store for unit tests
10
- setupMockCryptoAssetsStore();
11
-
12
- const ETH = getCryptoCurrencyById("ethereum");
13
- const BTC = getCryptoCurrencyById("bitcoin");
14
-
15
- // Create mock tokens for tests
16
- const ZRX_TOKEN: TokenCurrency = {
17
- type: "TokenCurrency",
18
- id: "ethereum/erc20/0x_project",
19
- contractAddress: "0xE41d2489571d322189246DaFA5ebDe1F4699F498",
20
- parentCurrency: ETH,
21
- tokenType: "erc20",
22
- name: "0x Project",
23
- ticker: "ZRX",
24
- delisted: false,
25
- disableCountervalue: false,
26
- units: [{ name: "ZRX", code: "ZRX", magnitude: 18 }],
27
- };
28
-
29
- const REP_TOKEN: TokenCurrency = {
30
- type: "TokenCurrency",
31
- id: "ethereum/erc20/augur",
32
- contractAddress: "0x1985365e9f78359a9B6AD760e32412f4a445E862",
33
- parentCurrency: ETH,
34
- tokenType: "erc20",
35
- name: "Augur",
36
- ticker: "REP",
37
- delisted: false,
38
- disableCountervalue: false,
39
- units: [{ name: "REP", code: "REP", magnitude: 18 }],
40
- };
41
-
42
- const mockedAccounts: Account[] = [
43
- genAccount("mocked-account-1", {
44
- currency: ETH,
45
- tokensData: [ZRX_TOKEN, REP_TOKEN],
46
- }),
47
- ];
48
-
49
- describe("getTotalStakeableAssets", () => {
50
- it("should return empty Set if no accounts", () => {
51
- const result = getTotalStakeableAssets([], [], []);
52
- expect(result.combinedIds).toBeInstanceOf(Set);
53
- expect(result.combinedIds.size).toBe(0);
54
- expect(result.stakeableAssets).toEqual([]);
55
- });
56
-
57
- it("should return empty Set if accounts is null", () => {
58
- const result = getTotalStakeableAssets(null, [], []);
59
- expect(result.combinedIds).toBeInstanceOf(Set);
60
- expect(result.combinedIds.size).toBe(0);
61
- expect(result.stakeableAssets).toEqual([]);
62
- });
63
-
64
- it("should return empty Set if accounts is undefined", () => {
65
- const result = getTotalStakeableAssets(undefined, [], []);
66
- expect(result.combinedIds).toBeInstanceOf(Set);
67
- expect(result.combinedIds.size).toBe(0);
68
- expect(result.stakeableAssets).toEqual([]);
69
- });
70
-
71
- it("should return empty Set if no staking currencies enabled", () => {
72
- const result = getTotalStakeableAssets(mockedAccounts, [], []);
73
- expect(result.combinedIds).toBeInstanceOf(Set);
74
- expect(result.combinedIds.size).toBe(0);
75
- expect(result.stakeableAssets).toEqual([]);
76
- });
77
-
78
- it("should return Set with matching currency ID when staking currency is enabled", () => {
79
- const account = mockedAccounts[0];
80
- const stakingCurrenciesEnabled = [ETH.id]; // "ethereum"
81
-
82
- expect(account.balance).toBeTruthy();
83
- expect(account.balance instanceof BigNumber).toBe(true);
84
- expect(account.balance.gt(0)).toBe(true);
85
-
86
- const result = getTotalStakeableAssets([account], stakingCurrenciesEnabled, []);
87
-
88
- expect(result.combinedIds).toBeInstanceOf(Set);
89
- expect(result.combinedIds.size).toBe(1);
90
- expect(result.combinedIds.has(ETH.id)).toBe(true);
91
- expect(result.stakeableAssets.length).toBe(1);
92
- expect(result.stakeableAssets[0]).toEqual({
93
- ticker: ETH.ticker,
94
- networkName: ETH.name,
95
- id: ETH.id,
96
- });
97
- });
98
-
99
- it("should return Set with matching token IDs when staking tokens are enabled", () => {
100
- const account = mockedAccounts[0];
101
- const stakingCurrenciesEnabled = [ZRX_TOKEN.id, REP_TOKEN.id];
102
-
103
- expect(account.subAccounts).toBeDefined();
104
- expect(account.subAccounts?.length).toBe(2);
105
-
106
- const result = getTotalStakeableAssets([account], stakingCurrenciesEnabled, []);
107
-
108
- expect(result.combinedIds).toBeInstanceOf(Set);
109
- expect(result.combinedIds.size).toBe(2);
110
- expect(result.combinedIds.has(ZRX_TOKEN.id)).toBe(true);
111
- expect(result.combinedIds.has(REP_TOKEN.id)).toBe(true);
112
- expect(result.stakeableAssets.length).toBe(2);
113
- expect(result.stakeableAssets).toEqual(
114
- expect.arrayContaining([
115
- expect.objectContaining({ id: ZRX_TOKEN.id, ticker: ZRX_TOKEN.ticker }),
116
- expect.objectContaining({ id: REP_TOKEN.id, ticker: REP_TOKEN.ticker }),
117
- ]),
118
- );
119
- });
120
-
121
- it("should return Set with both currency and token IDs when both are enabled", () => {
122
- const account = mockedAccounts[0];
123
- const stakingCurrenciesEnabled = [ETH.id, ZRX_TOKEN.id, REP_TOKEN.id];
124
-
125
- const result = getTotalStakeableAssets([account], stakingCurrenciesEnabled, []);
126
-
127
- expect(result.combinedIds).toBeInstanceOf(Set);
128
- expect(result.combinedIds.size).toBe(3);
129
- expect(result.combinedIds.has(ETH.id)).toBe(true);
130
- expect(result.combinedIds.has(ZRX_TOKEN.id)).toBe(true);
131
- expect(result.combinedIds.has(REP_TOKEN.id)).toBe(true);
132
- expect(result.stakeableAssets.length).toBe(3);
133
- expect(result.stakeableAssets).toEqual(
134
- expect.arrayContaining([
135
- expect.objectContaining({ id: ETH.id, ticker: ETH.ticker }),
136
- expect.objectContaining({ id: ZRX_TOKEN.id, ticker: ZRX_TOKEN.ticker }),
137
- expect.objectContaining({ id: REP_TOKEN.id, ticker: REP_TOKEN.ticker }),
138
- ]),
139
- );
140
- });
141
-
142
- it("should filter out currencies without funds", () => {
143
- const account = mockedAccounts[0];
144
- const accountWithZeroBalance = { ...account, balance: new BigNumber(0) };
145
- const stakingCurrenciesEnabled = [ETH.id];
146
-
147
- const result = getTotalStakeableAssets([accountWithZeroBalance], stakingCurrenciesEnabled, []);
148
-
149
- expect(result.combinedIds).toBeInstanceOf(Set);
150
- expect(result.combinedIds.size).toBe(0);
151
- expect(result.stakeableAssets).toEqual([]);
152
- });
153
-
154
- it("should filter out tokens without funds", () => {
155
- const account = mockedAccounts[0];
156
- const [zrxAccount, repAccount] = account.subAccounts || [];
157
- const emptyRepAccount = { ...repAccount, balance: new BigNumber(0) };
158
- const accountWithEmptyToken = { ...account, subAccounts: [zrxAccount, emptyRepAccount] };
159
- const stakingCurrenciesEnabled = [ZRX_TOKEN.id, REP_TOKEN.id];
160
-
161
- const result = getTotalStakeableAssets([accountWithEmptyToken], stakingCurrenciesEnabled, []);
162
-
163
- expect(result.combinedIds).toBeInstanceOf(Set);
164
- expect(result.combinedIds.size).toBe(1);
165
- expect(result.combinedIds.has(ZRX_TOKEN.id)).toBe(true);
166
- expect(result.combinedIds.has(REP_TOKEN.id)).toBe(false);
167
- expect(result.stakeableAssets.length).toBe(1);
168
- expect(result.stakeableAssets[0]).toEqual(
169
- expect.objectContaining({ id: ZRX_TOKEN.id, ticker: ZRX_TOKEN.ticker }),
170
- );
171
- });
172
-
173
- it("should include partner staking currencies enabled", () => {
174
- const account = mockedAccounts[0];
175
- const stakingCurrenciesEnabled = [ETH.id];
176
- const partnerStakingCurrenciesEnabled = [ZRX_TOKEN.id];
177
-
178
- const result = getTotalStakeableAssets(
179
- [account],
180
- stakingCurrenciesEnabled,
181
- partnerStakingCurrenciesEnabled,
182
- );
183
-
184
- expect(result.combinedIds).toBeInstanceOf(Set);
185
- expect(result.combinedIds.size).toBe(2);
186
- expect(result.combinedIds.has(ETH.id)).toBe(true);
187
- expect(result.combinedIds.has(ZRX_TOKEN.id)).toBe(true);
188
- expect(result.stakeableAssets.length).toBe(2);
189
- expect(result.stakeableAssets).toEqual(
190
- expect.arrayContaining([
191
- expect.objectContaining({ id: ETH.id, ticker: ETH.ticker }),
192
- expect.objectContaining({ id: ZRX_TOKEN.id, ticker: ZRX_TOKEN.ticker }),
193
- ]),
194
- );
195
- });
196
-
197
- it("should deduplicate IDs when same currency appears in both lists", () => {
198
- const account = mockedAccounts[0];
199
- const stakingCurrenciesEnabled = [ETH.id];
200
- const partnerStakingCurrenciesEnabled = [ETH.id]; // Same currency
201
-
202
- const result = getTotalStakeableAssets(
203
- [account],
204
- stakingCurrenciesEnabled,
205
- partnerStakingCurrenciesEnabled,
206
- );
207
-
208
- expect(result.combinedIds).toBeInstanceOf(Set);
209
- expect(result.combinedIds.size).toBe(1);
210
- expect(result.combinedIds.has(ETH.id)).toBe(true);
211
- expect(result.stakeableAssets.length).toBe(1);
212
- expect(result.stakeableAssets[0]).toEqual({
213
- ticker: ETH.ticker,
214
- networkName: ETH.name,
215
- id: ETH.id,
216
- });
217
- });
218
-
219
- it("should handle multiple accounts with different currencies", () => {
220
- const ethAccount = mockedAccounts[0];
221
- const btcAccount = genAccount("mocked-account-2", {
222
- currency: BTC,
223
- });
224
- const accounts = [ethAccount, btcAccount];
225
- const stakingCurrenciesEnabled = [ETH.id, BTC.id];
226
-
227
- const result = getTotalStakeableAssets(accounts, stakingCurrenciesEnabled, []);
228
-
229
- expect(result.combinedIds).toBeInstanceOf(Set);
230
- expect(result.combinedIds.size).toBe(2);
231
- expect(result.combinedIds.has(ETH.id)).toBe(true);
232
- expect(result.combinedIds.has(BTC.id)).toBe(true);
233
- expect(result.stakeableAssets.length).toBe(2);
234
- expect(result.stakeableAssets).toEqual(
235
- expect.arrayContaining([
236
- expect.objectContaining({ id: ETH.id, ticker: ETH.ticker }),
237
- expect.objectContaining({ id: BTC.id, ticker: BTC.ticker }),
238
- ]),
239
- );
240
- });
241
-
242
- it("should only include IDs that match staking currencies enabled", () => {
243
- const account = mockedAccounts[0];
244
- const stakingCurrenciesEnabled = [ZRX_TOKEN.id]; // Only ZRX enabled, not ETH or REP
245
-
246
- const result = getTotalStakeableAssets([account], stakingCurrenciesEnabled, []);
247
-
248
- expect(result.combinedIds).toBeInstanceOf(Set);
249
- expect(result.combinedIds.size).toBe(1);
250
- expect(result.combinedIds.has(ZRX_TOKEN.id)).toBe(true);
251
- expect(result.combinedIds.has(ETH.id)).toBe(false);
252
- expect(result.combinedIds.has(REP_TOKEN.id)).toBe(false);
253
- expect(result.stakeableAssets.length).toBe(1);
254
- expect(result.stakeableAssets[0]).toEqual(
255
- expect.objectContaining({ id: ZRX_TOKEN.id, ticker: ZRX_TOKEN.ticker }),
256
- );
257
- });
258
-
259
- it("should handle empty arrays for staking currencies", () => {
260
- const account = mockedAccounts[0];
261
- const result = getTotalStakeableAssets([account], [], []);
262
-
263
- expect(result.combinedIds).toBeInstanceOf(Set);
264
- expect(result.combinedIds.size).toBe(0);
265
- expect(result.stakeableAssets).toEqual([]);
266
- });
267
- });
@@ -1,47 +0,0 @@
1
- import { getTokensWithFundsMap } from "./getTokensWithFunds";
2
- import { Account } from "@ledgerhq/types-live";
3
-
4
- export function getTotalStakeableAssets(
5
- accounts: Account[] | null | undefined,
6
- stakingCurrenciesEnabled: string[],
7
- partnerStakingCurrenciesEnabled: string[],
8
- ): {
9
- combinedIds: Set<string>;
10
- stakeableAssets: { ticker: string; networkName: string; id: string }[];
11
- } {
12
- if (!accounts) return { combinedIds: new Set<string>(), stakeableAssets: [] };
13
-
14
- const accountsWithFundsCurrencies = accounts
15
- .filter(account => account?.balance.isGreaterThan(0))
16
- .map(account => account?.currency);
17
-
18
- const allStakingCurrenciesEnabled = new Set([
19
- ...stakingCurrenciesEnabled,
20
- ...partnerStakingCurrenciesEnabled,
21
- ]);
22
-
23
- const tokenWithFundsMap = getTokensWithFundsMap(accounts);
24
- const filteredAccountCurrencyIds = [...accountsWithFundsCurrencies].filter(currency =>
25
- allStakingCurrenciesEnabled.has(currency.id),
26
- );
27
- const filteredTokenWithFunds = [...tokenWithFundsMap.values()].filter(token =>
28
- allStakingCurrenciesEnabled.has(token.id),
29
- );
30
-
31
- const combined = new Map<string, { ticker: string; networkName: string; id: string }>();
32
- for (const currency of filteredAccountCurrencyIds) {
33
- combined.set(currency.id, {
34
- ticker: currency.ticker,
35
- networkName: currency.name,
36
- id: currency.id,
37
- });
38
- }
39
- for (const token of filteredTokenWithFunds) {
40
- combined.set(token.id, token);
41
- }
42
-
43
- return {
44
- combinedIds: new Set(Array.from(combined.values(), details => details.id)),
45
- stakeableAssets: Array.from(combined.values()),
46
- };
47
- }
@@ -1 +0,0 @@
1
- export const floatNumberRegex = /^\d+\.?\d+$/;