@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,147 +0,0 @@
1
- /**
2
- * @jest-environment jsdom
3
- */
4
-
5
- // Mock the bridge to avoid loading all bridge implementations with ESM dependencies
6
- jest.mock("../../bridge", () => ({
7
- getCurrencyBridge: jest.fn(),
8
- }));
9
-
10
- import { renderHook, act } from "@testing-library/react";
11
- import { getRemainingTime, useTimeRemaining } from "./react";
12
-
13
- const MILLISECOND = 1000;
14
- const SECOND = 1 * MILLISECOND;
15
- const MINUTE = 60 * SECOND;
16
- const HOUR = 60 * MINUTE;
17
- const DAY = 24 * HOUR;
18
-
19
- describe("getRemainingTime", () => {
20
- test("should return empty string for negative or zero diff", () => {
21
- expect(getRemainingTime(0)).toBe("");
22
- expect(getRemainingTime(-1000)).toBe("");
23
- expect(getRemainingTime(-100000)).toBe("");
24
- });
25
-
26
- test("should format seconds only", () => {
27
- expect(getRemainingTime(30 * SECOND)).toBe("30s");
28
- expect(getRemainingTime(59 * SECOND)).toBe("59s");
29
- expect(getRemainingTime(1 * SECOND)).toBe("1s");
30
- });
31
-
32
- test("should format minutes and seconds", () => {
33
- expect(getRemainingTime(1 * MINUTE + 30 * SECOND)).toBe("1m 30s");
34
- expect(getRemainingTime(5 * MINUTE + 15 * SECOND)).toBe("5m 15s");
35
- expect(getRemainingTime(59 * MINUTE + 59 * SECOND)).toBe("59m 59s");
36
- });
37
-
38
- test("should format hours, minutes and seconds", () => {
39
- expect(getRemainingTime(1 * HOUR + 30 * MINUTE + 15 * SECOND)).toBe("1h 30m 15s");
40
- expect(getRemainingTime(2 * HOUR + 5 * MINUTE + 10 * SECOND)).toBe("2h 5m 10s");
41
- expect(getRemainingTime(23 * HOUR + 59 * MINUTE + 59 * SECOND)).toBe("23h 59m 59s");
42
- });
43
-
44
- test("should format days, hours, minutes and seconds", () => {
45
- expect(getRemainingTime(1 * DAY + 2 * HOUR + 30 * MINUTE + 15 * SECOND)).toBe("1d 2h 30m 15s");
46
- expect(getRemainingTime(5 * DAY + 10 * HOUR + 5 * MINUTE + 10 * SECOND)).toBe("5d 10h 5m 10s");
47
- expect(getRemainingTime(10 * DAY + 23 * HOUR + 59 * MINUTE + 59 * SECOND)).toBe(
48
- "10d 23h 59m 59s",
49
- );
50
- });
51
-
52
- test("should skip zero values", () => {
53
- expect(getRemainingTime(1 * DAY)).toBe("1d 0s");
54
- expect(getRemainingTime(1 * HOUR)).toBe("1h 0s");
55
- expect(getRemainingTime(1 * MINUTE)).toBe("1m 0s");
56
- expect(getRemainingTime(1 * DAY + 1 * MINUTE)).toBe("1d 1m 0s");
57
- expect(getRemainingTime(1 * DAY + 1 * HOUR)).toBe("1d 1h 0s");
58
- });
59
- });
60
-
61
- describe("useTimeRemaining", () => {
62
- beforeAll(() => {
63
- jest.useFakeTimers();
64
- });
65
-
66
- afterAll(() => {
67
- jest.runOnlyPendingTimers();
68
- jest.useRealTimers();
69
- });
70
-
71
- beforeEach(() => {
72
- jest.setSystemTime(new Date("2024-01-01T12:00:00Z"));
73
- });
74
-
75
- test("should return empty string when proposal is null", () => {
76
- const { result } = renderHook(() => useTimeRemaining());
77
- expect(result.current).toBe("");
78
- });
79
-
80
- test("should return empty string when proposal is expired", () => {
81
- const proposal = {
82
- expiresAt: (Date.now() - 1000) * 1000, // 1 second ago
83
- isExpired: true,
84
- };
85
- const { result } = renderHook(() => useTimeRemaining(proposal.expiresAt, proposal.isExpired));
86
- expect(result.current).toBe("");
87
- });
88
-
89
- test("should return formatted time remaining for valid proposal", () => {
90
- const expiresAt = Date.now() + 2 * HOUR + 30 * MINUTE + 15 * SECOND;
91
- const { result } = renderHook(() => useTimeRemaining(expiresAt * 1000));
92
- expect(result.current).toBe("2h 30m 15s");
93
- });
94
-
95
- test("should update time remaining every second", () => {
96
- const expiresAt = Date.now() + 2 * MINUTE + 30 * SECOND;
97
- const { result } = renderHook(() => useTimeRemaining(expiresAt * 1000));
98
-
99
- expect(result.current).toBe("2m 30s");
100
-
101
- act(() => {
102
- jest.advanceTimersByTime(1 * SECOND);
103
- });
104
- expect(result.current).toBe("2m 29s");
105
-
106
- act(() => {
107
- jest.advanceTimersByTime(1 * SECOND);
108
- });
109
- expect(result.current).toBe("2m 28s");
110
-
111
- act(() => {
112
- jest.advanceTimersByTime(30 * SECOND);
113
- });
114
- expect(result.current).toBe("1m 58s");
115
- });
116
-
117
- test("should return empty string when time expires", () => {
118
- const expiresAt = Date.now() + 2 * SECOND;
119
- const { result } = renderHook(() => useTimeRemaining(expiresAt * 1000));
120
-
121
- expect(result.current).toBe("2s");
122
-
123
- act(() => {
124
- jest.advanceTimersByTime(1 * SECOND);
125
- });
126
- expect(result.current).toBe("1s");
127
-
128
- act(() => {
129
- jest.advanceTimersByTime(1 * SECOND);
130
- });
131
- expect(result.current).toBe("");
132
- });
133
-
134
- test("should clear interval on unmount", () => {
135
- const expiresAt = Date.now() + 1 * HOUR;
136
- const { result, unmount } = renderHook(() => useTimeRemaining(expiresAt * 1000));
137
-
138
- expect(result.current).toBe("1h 0s");
139
-
140
- unmount();
141
-
142
- // Advance time after unmount - should not cause errors
143
- act(() => {
144
- jest.advanceTimersByTime(1 * SECOND);
145
- });
146
- });
147
- });
@@ -1,272 +0,0 @@
1
- /**
2
- * @jest-environment jsdom
3
- */
4
- import "../../__tests__/test-helpers/dom-polyfill";
5
- import BigNumber from "bignumber.js";
6
- import invariant from "invariant";
7
- import { getCurrentHederaPreloadData } from "@ledgerhq/coin-hedera/preload-data";
8
- import { apiClient } from "@ledgerhq/coin-hedera/network/api";
9
- import { LiveConfig } from "@ledgerhq/live-config/LiveConfig";
10
- import { renderHook } from "@testing-library/react";
11
- import { makeBridgeCacheSystem } from "../../bridge/cache";
12
- import { liveConfig } from "../../config/sharedConfig";
13
- import { getCryptoCurrencyById } from "../../currencies";
14
- import * as hooks from "./react";
15
- import type { HederaAccount, HederaDelegation } from "./types";
16
-
17
- const localCache: Record<string, unknown> = {};
18
- const cache = makeBridgeCacheSystem({
19
- saveData(c, d) {
20
- localCache[c.id] = d;
21
- return Promise.resolve();
22
- },
23
- getData(c) {
24
- return Promise.resolve(localCache[c.id]);
25
- },
26
- });
27
-
28
- describe("hedera/react", () => {
29
- const currency = getCryptoCurrencyById("hedera");
30
-
31
- beforeAll(() => {
32
- LiveConfig.setConfig(liveConfig);
33
- jest.spyOn(apiClient, "getNodes").mockResolvedValue([
34
- {
35
- description: "Hosted by LG | Seoul, South Korea",
36
- node_id: 0,
37
- node_account_id: "0.0.3",
38
- stake: 45000000000000000,
39
- stake_rewarded: 86596417100000000,
40
- min_stake: 0,
41
- max_stake: 45000000000000000,
42
- reward_rate_start: 3500,
43
- },
44
- {
45
- description: "Hosted by Swirlds | Iowa, USA",
46
- node_id: 1,
47
- node_account_id: "0.0.4",
48
- stake: 45000000000000000,
49
- stake_rewarded: 88990261300000000,
50
- min_stake: 0,
51
- max_stake: 45000000000000000,
52
- reward_rate_start: 4000,
53
- },
54
- {
55
- description: "Hosted for Wipro | Amsterdam, Netherlands",
56
- node_id: 3,
57
- node_account_id: "0.0.6",
58
- stake: 45000000000000000,
59
- stake_rewarded: 21477855400000000,
60
- min_stake: 0,
61
- max_stake: 45000000000000000,
62
- reward_rate_start: 5000,
63
- },
64
- ]);
65
- });
66
-
67
- describe("useHederaPreloadData", () => {
68
- beforeEach(async () => {
69
- const { prepare } = setup();
70
- await prepare();
71
- });
72
-
73
- it("should return preloaded data", async () => {
74
- const { result } = renderHook(() => hooks.useHederaPreloadData(currency));
75
- const data = getCurrentHederaPreloadData(currency);
76
-
77
- expect(result.current).toStrictEqual(data);
78
- });
79
- });
80
-
81
- describe("useHederaValidators", () => {
82
- beforeEach(async () => {
83
- const { prepare } = setup();
84
- await prepare();
85
- });
86
-
87
- it("should return all validators when no search query", () => {
88
- const { result } = renderHook(() => hooks.useHederaValidators(currency));
89
- const data = getCurrentHederaPreloadData(currency);
90
-
91
- expect(result.current).toEqual(data.validators);
92
- });
93
-
94
- it("should return all validators when search query is empty string", () => {
95
- const { result } = renderHook(() => hooks.useHederaValidators(currency, ""));
96
- const data = getCurrentHederaPreloadData(currency);
97
-
98
- expect(result.current).toEqual(data.validators);
99
- });
100
-
101
- it("should filter validators by name", () => {
102
- const { result } = renderHook(() => hooks.useHederaValidators(currency, "Swirlds"));
103
-
104
- expect(result.current.length).toBeGreaterThan(0);
105
- result.current.forEach(validator => {
106
- expect(validator.name.toLowerCase()).toContain("swirlds");
107
- });
108
- });
109
-
110
- it("should filter validators by node ID", () => {
111
- const data = getCurrentHederaPreloadData(currency);
112
- const firstValidator = data.validators[0];
113
-
114
- if (firstValidator) {
115
- const { result } = renderHook(() =>
116
- hooks.useHederaValidators(currency, firstValidator.nodeId.toString()),
117
- );
118
-
119
- expect(result.current.length).toBeGreaterThan(0);
120
- expect(result.current.some(v => v.nodeId === firstValidator.nodeId)).toBe(true);
121
- }
122
- });
123
-
124
- it("should return empty array when no validators match search", () => {
125
- const { result } = renderHook(() =>
126
- hooks.useHederaValidators(currency, "nonexistingvalidator"),
127
- );
128
-
129
- expect(result.current).toEqual([]);
130
- });
131
-
132
- it("should be case insensitive when filtering", () => {
133
- const { result: upperResult } = renderHook(() =>
134
- hooks.useHederaValidators(currency, "SWIRLDS"),
135
- );
136
- const { result: lowerResult } = renderHook(() =>
137
- hooks.useHederaValidators(currency, "swirlds"),
138
- );
139
-
140
- expect(upperResult.current.length).toEqual(lowerResult.current.length);
141
- });
142
- });
143
-
144
- describe("useHederaEnrichedDelegation", () => {
145
- const mockAccount = {
146
- type: "Account",
147
- id: "mock-account-id",
148
- currency,
149
- balance: new BigNumber(1000000),
150
- spendableBalance: new BigNumber(1000000),
151
- hederaResources: {
152
- delegation: null,
153
- },
154
- } as HederaAccount;
155
-
156
- beforeEach(async () => {
157
- const { prepare } = setup();
158
- await prepare();
159
- });
160
-
161
- it("should enrich delegation with validator data", () => {
162
- const data = getCurrentHederaPreloadData(currency);
163
- const validator = data.validators[0];
164
- invariant(validator, "No validators available for test");
165
-
166
- const delegation: HederaDelegation = {
167
- nodeId: validator.nodeId,
168
- delegated: new BigNumber(100000),
169
- pendingReward: new BigNumber(500),
170
- };
171
-
172
- const { result } = renderHook(() =>
173
- hooks.useHederaEnrichedDelegation(mockAccount, delegation),
174
- );
175
-
176
- expect(result.current).toEqual({
177
- nodeId: validator.nodeId,
178
- delegated: delegation.delegated,
179
- pendingReward: delegation.pendingReward,
180
- status: "overstaked",
181
- validator: {
182
- name: validator.name,
183
- address: validator.address,
184
- addressChecksum: validator.addressChecksum,
185
- nodeId: validator.nodeId,
186
- minStake: validator.minStake,
187
- maxStake: validator.maxStake,
188
- activeStake: validator.activeStake,
189
- activeStakePercentage: validator.activeStakePercentage,
190
- overstaked: validator.overstaked,
191
- },
192
- });
193
- });
194
-
195
- it("should handle delegation with non-existent validator", () => {
196
- const delegation: HederaDelegation = {
197
- nodeId: 999999,
198
- delegated: new BigNumber(100000),
199
- pendingReward: new BigNumber(500),
200
- };
201
-
202
- const { result } = renderHook(() =>
203
- hooks.useHederaEnrichedDelegation(mockAccount, delegation),
204
- );
205
-
206
- expect(result.current).toEqual({
207
- nodeId: delegation.nodeId,
208
- delegated: delegation.delegated,
209
- pendingReward: delegation.pendingReward,
210
- status: "inactive",
211
- validator: {
212
- name: "",
213
- address: "",
214
- addressChecksum: null,
215
- nodeId: delegation.nodeId,
216
- minStake: new BigNumber(0),
217
- maxStake: new BigNumber(0),
218
- activeStake: new BigNumber(0),
219
- activeStakePercentage: new BigNumber(0),
220
- overstaked: false,
221
- },
222
- });
223
- });
224
-
225
- it("should handle delegation with zero staked amount", () => {
226
- const data = getCurrentHederaPreloadData(currency);
227
- const validator = data.validators[0];
228
- invariant(validator, "No validators available for test");
229
-
230
- const delegation: HederaDelegation = {
231
- nodeId: validator.nodeId,
232
- delegated: new BigNumber(0),
233
- pendingReward: new BigNumber(0),
234
- };
235
-
236
- const { result } = renderHook(() =>
237
- hooks.useHederaEnrichedDelegation(mockAccount, delegation),
238
- );
239
-
240
- expect(result.current.delegated).toEqual(new BigNumber(0));
241
- expect(result.current.validator.nodeId).toEqual(validator.nodeId);
242
- });
243
-
244
- it("should handle delegation with pending rewards", () => {
245
- const data = getCurrentHederaPreloadData(currency);
246
- const validator = data.validators[0];
247
- invariant(validator, "No validators available for test");
248
-
249
- const delegation: HederaDelegation = {
250
- nodeId: validator.nodeId,
251
- delegated: new BigNumber(100000),
252
- pendingReward: new BigNumber(1500),
253
- };
254
-
255
- const { result } = renderHook(() =>
256
- hooks.useHederaEnrichedDelegation(mockAccount, delegation),
257
- );
258
-
259
- expect(result.current.pendingReward).toEqual(new BigNumber(1500));
260
- });
261
- });
262
- });
263
-
264
- function setup(): {
265
- prepare: () => Promise<unknown>;
266
- } {
267
- const currency = getCryptoCurrencyById("hedera");
268
-
269
- return {
270
- prepare: async () => cache.prepareCurrency(currency),
271
- };
272
- }
@@ -1,63 +0,0 @@
1
- import BigNumber from "bignumber.js";
2
- import type { CryptoCurrency } from "@ledgerhq/types-cryptoassets";
3
- import { useMemo } from "react";
4
- import {
5
- getCurrentHederaPreloadData,
6
- getHederaPreloadData,
7
- } from "@ledgerhq/coin-hedera/preload-data";
8
- import { getDelegationStatus, filterValidatorBySearchTerm } from "./utils";
9
- import { useObservable } from "../../observable";
10
- import type {
11
- HederaAccount,
12
- HederaPreloadData,
13
- HederaValidator,
14
- HederaDelegation,
15
- HederaEnrichedDelegation,
16
- } from "./types";
17
-
18
- export function useHederaPreloadData(
19
- currency: CryptoCurrency,
20
- ): HederaPreloadData | undefined | null {
21
- return useObservable(getHederaPreloadData(currency), getCurrentHederaPreloadData(currency));
22
- }
23
-
24
- export function useHederaValidators(currency: CryptoCurrency, search?: string): HederaValidator[] {
25
- const data = useHederaPreloadData(currency);
26
-
27
- return useMemo(() => {
28
- const validators = data?.validators ?? [];
29
-
30
- if (validators.length === 0 || !search || search === "") {
31
- return validators;
32
- }
33
-
34
- return validators.filter(validator => {
35
- return filterValidatorBySearchTerm(validator, search);
36
- });
37
- }, [data, search]);
38
- }
39
-
40
- export function useHederaEnrichedDelegation(
41
- account: HederaAccount,
42
- delegation: HederaDelegation,
43
- ): HederaEnrichedDelegation {
44
- const validators = useHederaValidators(account.currency);
45
- const validatorByNodeId = new Map(validators.map(v => [v.nodeId, v]));
46
- const validator = validatorByNodeId.get(delegation.nodeId) ?? null;
47
-
48
- return {
49
- ...delegation,
50
- status: getDelegationStatus(validator),
51
- validator: {
52
- name: validator?.name ?? "",
53
- address: validator?.address ?? "",
54
- addressChecksum: validator?.addressChecksum ?? null,
55
- nodeId: delegation.nodeId,
56
- minStake: validator?.minStake ?? new BigNumber(0),
57
- maxStake: validator?.maxStake ?? new BigNumber(0),
58
- activeStake: validator?.activeStake ?? new BigNumber(0),
59
- activeStakePercentage: validator?.activeStakePercentage ?? new BigNumber(0),
60
- overstaked: validator?.overstaked ?? false,
61
- },
62
- };
63
- }
@@ -1,25 +0,0 @@
1
- // Utility to map any size to valid crypto-icons sizes
2
- // For React Native (returns numbers)
3
- export const getValidCryptoIconSizeNative = (size: number): 16 | 20 | 24 | 32 | 40 | 48 | 56 => {
4
- if (size <= 16) return 16;
5
- if (size <= 20) return 20;
6
- if (size <= 24) return 24;
7
- if (size <= 32) return 32;
8
- if (size <= 40) return 40;
9
- if (size <= 48) return 48;
10
- return 56;
11
- };
12
-
13
- // Utility to map any size to valid crypto-icons sizes
14
- // For React/Web (returns strings with "px")
15
- export const getValidCryptoIconSize = (
16
- size: number,
17
- ): "16px" | "20px" | "24px" | "32px" | "40px" | "48px" | "56px" => {
18
- if (size <= 16) return "16px";
19
- if (size <= 20) return "20px";
20
- if (size <= 24) return "24px";
21
- if (size <= 32) return "32px";
22
- if (size <= 40) return "40px";
23
- if (size <= 48) return "48px";
24
- return "56px";
25
- };
@@ -1,105 +0,0 @@
1
- import {
2
- buildHtmlDisplaySegments,
3
- splitHtmlLinkSegments,
4
- validateLedgerUrl,
5
- } from "../useHtmlLinkSegments";
6
-
7
- describe("splitHtmlLinkSegments", () => {
8
- it("returns an empty array when input is empty", () => {
9
- expect(splitHtmlLinkSegments("")).toEqual([]);
10
- });
11
-
12
- it("returns only text segments when there are no anchors", () => {
13
- const segments = splitHtmlLinkSegments("simple text without links");
14
- expect(segments).toEqual([{ type: "text", content: "simple text without links" }]);
15
- });
16
-
17
- it("splits text into text and link segments", () => {
18
- const segments = splitHtmlLinkSegments('Hello <a href="https://ledger.com">Ledger</a> !');
19
-
20
- expect(segments).toEqual([
21
- { type: "text", content: "Hello " },
22
- { type: "link", label: "Ledger", href: "https://ledger.com" },
23
- { type: "text", content: " !" },
24
- ]);
25
- });
26
-
27
- it("keeps whitespace-only text segments", () => {
28
- const segments = splitHtmlLinkSegments(
29
- '<a href="https://ledger.com">Ledger</a> <a href="https://support.ledger.com">Support</a>',
30
- );
31
-
32
- expect(segments).toEqual([
33
- { type: "link", label: "Ledger", href: "https://ledger.com" },
34
- { type: "text", content: " " },
35
- { type: "link", label: "Support", href: "https://support.ledger.com" },
36
- ]);
37
- });
38
- });
39
-
40
- describe("buildHtmlDisplaySegments", () => {
41
- it("keeps valid ledger links clickable", () => {
42
- const segments = buildHtmlDisplaySegments(
43
- 'Visit <a href="https://support.ledger.com">support</a> docs',
44
- );
45
-
46
- expect(segments).toEqual([
47
- { type: "text", content: "Visit " },
48
- { type: "link", href: "https://support.ledger.com", label: "support" },
49
- { type: "text", content: " docs" },
50
- ]);
51
- });
52
-
53
- it("falls back to text segments for non-ledger links", () => {
54
- const segments = buildHtmlDisplaySegments('Check <a href="https://example.com">here</a>');
55
-
56
- expect(segments).toEqual([
57
- { type: "text", content: "Check " },
58
- { type: "text", content: "here" },
59
- ]);
60
- });
61
-
62
- it("ignores invalid protocols", () => {
63
- const segments = buildHtmlDisplaySegments('Bad <a href="javascript:alert(1)">click</a>');
64
-
65
- expect(segments).toEqual([
66
- { type: "text", content: "Bad " },
67
- { type: "text", content: "click" },
68
- ]);
69
- });
70
- });
71
-
72
- describe("validateLedgerUrl", () => {
73
- it("accepts ledger http(s) URLs", () => {
74
- expect(validateLedgerUrl("https://ledger.com")).toEqual({
75
- isHttp: true,
76
- isAllowedLedgerDomain: true,
77
- });
78
-
79
- expect(validateLedgerUrl("https://support.ledger.com/hc/en-us")).toEqual({
80
- isHttp: true,
81
- isAllowedLedgerDomain: true,
82
- });
83
- });
84
-
85
- it("rejects non-http protocols", () => {
86
- expect(validateLedgerUrl("ledgerlive://settings")).toEqual({
87
- isHttp: false,
88
- isAllowedLedgerDomain: false,
89
- });
90
- });
91
-
92
- it("rejects non-ledger domains", () => {
93
- expect(validateLedgerUrl("https://example.com")).toEqual({
94
- isHttp: true,
95
- isAllowedLedgerDomain: false,
96
- });
97
- });
98
-
99
- it("rejects invalid URLs", () => {
100
- expect(validateLedgerUrl("not a url")).toEqual({
101
- isHttp: false,
102
- isAllowedLedgerDomain: false,
103
- });
104
- });
105
- });