@ledgerhq/live-common 34.43.0 → 34.44.0-nightly.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 (218) hide show
  1. package/lib/DataModel.test.js +6 -0
  2. package/lib/DataModel.test.js.map +1 -1
  3. package/lib/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
  4. package/lib/__tests__/accounts/groupPerDay.js +10 -0
  5. package/lib/__tests__/accounts/groupPerDay.js.map +1 -1
  6. package/lib/__tests__/test-helpers/environment.js +1 -0
  7. package/lib/__tests__/test-helpers/environment.js.map +1 -1
  8. package/lib/__tests__/test-helpers/setup.d.ts.map +1 -1
  9. package/lib/__tests__/test-helpers/setup.js +6 -0
  10. package/lib/__tests__/test-helpers/setup.js.map +1 -1
  11. package/lib/account/serialization.test.js +17 -1
  12. package/lib/account/serialization.test.js.map +1 -1
  13. package/lib/appSupportsQuitApp.d.ts +1 -0
  14. package/lib/appSupportsQuitApp.d.ts.map +1 -1
  15. package/lib/appSupportsQuitApp.js +1 -0
  16. package/lib/appSupportsQuitApp.js.map +1 -1
  17. package/lib/appSupportsQuitApp.test.js +28 -3
  18. package/lib/appSupportsQuitApp.test.js.map +1 -1
  19. package/lib/bridge/crypto-assets/index.d.ts.map +1 -1
  20. package/lib/bridge/crypto-assets/index.js +5 -5
  21. package/lib/bridge/crypto-assets/index.js.map +1 -1
  22. package/lib/bridge/generic-alpaca/alpaca/index.d.ts +1 -1
  23. package/lib/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
  24. package/lib/bridge/generic-alpaca/alpaca/index.js.map +1 -1
  25. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +2 -6
  26. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
  27. package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
  28. package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  29. package/lib/bridge/generic-alpaca/getAccountShape.js +5 -6
  30. package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  31. package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
  32. package/lib/bridge/generic-alpaca/utils.d.ts +3 -2
  33. package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
  34. package/lib/bridge/generic-alpaca/utils.js +6 -2
  35. package/lib/bridge/generic-alpaca/utils.js.map +1 -1
  36. package/lib/bridge/generic-alpaca/utils.test.d.ts +2 -0
  37. package/lib/bridge/generic-alpaca/utils.test.d.ts.map +1 -0
  38. package/lib/bridge/generic-alpaca/utils.test.js +20 -0
  39. package/lib/bridge/generic-alpaca/utils.test.js.map +1 -0
  40. package/lib/currencies/sortByMarketcap.test.js +5 -0
  41. package/lib/currencies/sortByMarketcap.test.js.map +1 -1
  42. package/lib/e2e/index.d.ts +3 -0
  43. package/lib/e2e/index.d.ts.map +1 -1
  44. package/lib/e2e/speculos.d.ts.map +1 -1
  45. package/lib/e2e/speculos.js +45 -15
  46. package/lib/e2e/speculos.js.map +1 -1
  47. package/lib/e2e/speculosCI.d.ts.map +1 -1
  48. package/lib/e2e/speculosCI.js +22 -4
  49. package/lib/e2e/speculosCI.js.map +1 -1
  50. package/lib/env.react.d.ts +1 -1
  51. package/lib/env.react.d.ts.map +1 -1
  52. package/lib/families/bitcoin/satstack.test.js +6 -0
  53. package/lib/families/bitcoin/satstack.test.js.map +1 -1
  54. package/lib/families/solana/bridge/mock-data.d.ts.map +1 -1
  55. package/lib/families/solana/bridge/mock-data.js +46 -316
  56. package/lib/families/solana/bridge/mock-data.js.map +1 -1
  57. package/lib/families/solana/bridge/mock.js +2 -2
  58. package/lib/families/solana/bridge/mock.js.map +1 -1
  59. package/lib/families/stellar/ui.d.ts +6 -0
  60. package/lib/families/stellar/ui.d.ts.map +1 -0
  61. package/lib/families/stellar/ui.js +18 -0
  62. package/lib/families/stellar/ui.js.map +1 -0
  63. package/lib/families/tron/data.mock.d.ts.map +1 -1
  64. package/lib/families/tron/data.mock.js +6 -0
  65. package/lib/families/tron/data.mock.js.map +1 -1
  66. package/lib/featureFlags/defaultFeatures.d.ts +1 -0
  67. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
  68. package/lib/featureFlags/defaultFeatures.js +1 -0
  69. package/lib/featureFlags/defaultFeatures.js.map +1 -1
  70. package/lib/modularDrawer/__mocks__/accounts.mock.d.ts +18 -0
  71. package/lib/modularDrawer/__mocks__/accounts.mock.d.ts.map +1 -0
  72. package/lib/modularDrawer/__mocks__/accounts.mock.js +48 -0
  73. package/lib/modularDrawer/__mocks__/accounts.mock.js.map +1 -0
  74. package/lib/utils/__tests__/composeHooks.test.d.ts +2 -0
  75. package/lib/utils/__tests__/composeHooks.test.d.ts.map +1 -0
  76. package/lib/utils/__tests__/composeHooks.test.js +35 -0
  77. package/lib/utils/__tests__/composeHooks.test.js.map +1 -0
  78. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +2 -0
  79. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +1 -0
  80. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js +104 -0
  81. package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -0
  82. package/lib/utils/composeHooks.d.ts +11 -0
  83. package/lib/utils/composeHooks.d.ts.map +1 -0
  84. package/lib/utils/composeHooks.js +25 -0
  85. package/lib/utils/composeHooks.js.map +1 -0
  86. package/lib/utils/getAccountTuplesForCurrency.d.ts +8 -0
  87. package/lib/utils/getAccountTuplesForCurrency.d.ts.map +1 -0
  88. package/lib/utils/getAccountTuplesForCurrency.js +19 -0
  89. package/lib/utils/getAccountTuplesForCurrency.js.map +1 -0
  90. package/lib/wallet-api/helpers.d.ts +1 -0
  91. package/lib/wallet-api/helpers.d.ts.map +1 -1
  92. package/lib/wallet-api/helpers.js +16 -1
  93. package/lib/wallet-api/helpers.js.map +1 -1
  94. package/lib-es/DataModel.test.js +6 -0
  95. package/lib-es/DataModel.test.js.map +1 -1
  96. package/lib-es/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
  97. package/lib-es/__tests__/accounts/groupPerDay.js +10 -0
  98. package/lib-es/__tests__/accounts/groupPerDay.js.map +1 -1
  99. package/lib-es/__tests__/test-helpers/environment.js +1 -0
  100. package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
  101. package/lib-es/__tests__/test-helpers/setup.d.ts.map +1 -1
  102. package/lib-es/__tests__/test-helpers/setup.js +6 -0
  103. package/lib-es/__tests__/test-helpers/setup.js.map +1 -1
  104. package/lib-es/account/serialization.test.js +15 -2
  105. package/lib-es/account/serialization.test.js.map +1 -1
  106. package/lib-es/appSupportsQuitApp.d.ts +1 -0
  107. package/lib-es/appSupportsQuitApp.d.ts.map +1 -1
  108. package/lib-es/appSupportsQuitApp.js +1 -0
  109. package/lib-es/appSupportsQuitApp.js.map +1 -1
  110. package/lib-es/appSupportsQuitApp.test.js +6 -1
  111. package/lib-es/appSupportsQuitApp.test.js.map +1 -1
  112. package/lib-es/bridge/crypto-assets/index.d.ts.map +1 -1
  113. package/lib-es/bridge/crypto-assets/index.js +4 -4
  114. package/lib-es/bridge/crypto-assets/index.js.map +1 -1
  115. package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts +1 -1
  116. package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
  117. package/lib-es/bridge/generic-alpaca/alpaca/index.js.map +1 -1
  118. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +2 -6
  119. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
  120. package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
  121. package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
  122. package/lib-es/bridge/generic-alpaca/getAccountShape.js +6 -7
  123. package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
  124. package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
  125. package/lib-es/bridge/generic-alpaca/utils.d.ts +3 -2
  126. package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
  127. package/lib-es/bridge/generic-alpaca/utils.js +4 -1
  128. package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
  129. package/lib-es/bridge/generic-alpaca/utils.test.d.ts +2 -0
  130. package/lib-es/bridge/generic-alpaca/utils.test.d.ts.map +1 -0
  131. package/lib-es/bridge/generic-alpaca/utils.test.js +18 -0
  132. package/lib-es/bridge/generic-alpaca/utils.test.js.map +1 -0
  133. package/lib-es/currencies/sortByMarketcap.test.js +5 -0
  134. package/lib-es/currencies/sortByMarketcap.test.js.map +1 -1
  135. package/lib-es/e2e/index.d.ts +3 -0
  136. package/lib-es/e2e/index.d.ts.map +1 -1
  137. package/lib-es/e2e/speculos.d.ts.map +1 -1
  138. package/lib-es/e2e/speculos.js +45 -15
  139. package/lib-es/e2e/speculos.js.map +1 -1
  140. package/lib-es/e2e/speculosCI.d.ts.map +1 -1
  141. package/lib-es/e2e/speculosCI.js +22 -4
  142. package/lib-es/e2e/speculosCI.js.map +1 -1
  143. package/lib-es/env.react.d.ts +1 -1
  144. package/lib-es/env.react.d.ts.map +1 -1
  145. package/lib-es/families/bitcoin/satstack.test.js +6 -0
  146. package/lib-es/families/bitcoin/satstack.test.js.map +1 -1
  147. package/lib-es/families/solana/bridge/mock-data.d.ts.map +1 -1
  148. package/lib-es/families/solana/bridge/mock-data.js +46 -316
  149. package/lib-es/families/solana/bridge/mock-data.js.map +1 -1
  150. package/lib-es/families/solana/bridge/mock.js +3 -3
  151. package/lib-es/families/solana/bridge/mock.js.map +1 -1
  152. package/lib-es/families/stellar/ui.d.ts +6 -0
  153. package/lib-es/families/stellar/ui.d.ts.map +1 -0
  154. package/lib-es/families/stellar/ui.js +14 -0
  155. package/lib-es/families/stellar/ui.js.map +1 -0
  156. package/lib-es/families/tron/data.mock.d.ts.map +1 -1
  157. package/lib-es/families/tron/data.mock.js +6 -0
  158. package/lib-es/families/tron/data.mock.js.map +1 -1
  159. package/lib-es/featureFlags/defaultFeatures.d.ts +1 -0
  160. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
  161. package/lib-es/featureFlags/defaultFeatures.js +1 -0
  162. package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
  163. package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts +18 -0
  164. package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts.map +1 -0
  165. package/lib-es/modularDrawer/__mocks__/accounts.mock.js +42 -0
  166. package/lib-es/modularDrawer/__mocks__/accounts.mock.js.map +1 -0
  167. package/lib-es/utils/__tests__/composeHooks.test.d.ts +2 -0
  168. package/lib-es/utils/__tests__/composeHooks.test.d.ts.map +1 -0
  169. package/lib-es/utils/__tests__/composeHooks.test.js +33 -0
  170. package/lib-es/utils/__tests__/composeHooks.test.js.map +1 -0
  171. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +2 -0
  172. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +1 -0
  173. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js +102 -0
  174. package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -0
  175. package/lib-es/utils/composeHooks.d.ts +11 -0
  176. package/lib-es/utils/composeHooks.d.ts.map +1 -0
  177. package/lib-es/utils/composeHooks.js +21 -0
  178. package/lib-es/utils/composeHooks.js.map +1 -0
  179. package/lib-es/utils/getAccountTuplesForCurrency.d.ts +8 -0
  180. package/lib-es/utils/getAccountTuplesForCurrency.d.ts.map +1 -0
  181. package/lib-es/utils/getAccountTuplesForCurrency.js +15 -0
  182. package/lib-es/utils/getAccountTuplesForCurrency.js.map +1 -0
  183. package/lib-es/wallet-api/helpers.d.ts +1 -0
  184. package/lib-es/wallet-api/helpers.d.ts.map +1 -1
  185. package/lib-es/wallet-api/helpers.js +14 -0
  186. package/lib-es/wallet-api/helpers.js.map +1 -1
  187. package/package.json +37 -37
  188. package/src/DataModel.test.ts +8 -0
  189. package/src/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
  190. package/src/__tests__/accounts/groupPerDay.ts +13 -0
  191. package/src/__tests__/test-helpers/environment.ts +1 -0
  192. package/src/__tests__/test-helpers/setup.ts +8 -0
  193. package/src/account/serialization.test.ts +20 -2
  194. package/src/appSupportsQuitApp.test.ts +7 -1
  195. package/src/appSupportsQuitApp.ts +1 -0
  196. package/src/bridge/crypto-assets/index.ts +6 -6
  197. package/src/bridge/generic-alpaca/alpaca/index.ts +3 -3
  198. package/src/bridge/generic-alpaca/alpaca/network/network-alpaca.ts +3 -8
  199. package/src/bridge/generic-alpaca/getAccountShape.ts +6 -7
  200. package/src/bridge/generic-alpaca/signOperation.ts +1 -1
  201. package/src/bridge/generic-alpaca/utils.test.ts +19 -0
  202. package/src/bridge/generic-alpaca/utils.ts +7 -6
  203. package/src/currencies/sortByMarketcap.test.ts +7 -0
  204. package/src/e2e/speculos.ts +77 -21
  205. package/src/e2e/speculosCI.ts +32 -10
  206. package/src/families/bitcoin/satstack.test.ts +7 -0
  207. package/src/families/solana/bridge/mock-data.ts +52 -316
  208. package/src/families/solana/bridge/mock.ts +3 -3
  209. package/src/families/stellar/__snapshots__/bridge.integration.test.ts.snap +1930 -94
  210. package/src/families/stellar/ui.ts +15 -0
  211. package/src/families/tron/data.mock.ts +8 -0
  212. package/src/featureFlags/defaultFeatures.ts +1 -0
  213. package/src/modularDrawer/__mocks__/accounts.mock.ts +43 -0
  214. package/src/utils/__tests__/composeHooks.test.ts +46 -0
  215. package/src/utils/__tests__/getAccountTuplesForCurrency.test.ts +138 -0
  216. package/src/utils/composeHooks.ts +26 -0
  217. package/src/utils/getAccountTuplesForCurrency.ts +34 -0
  218. package/src/wallet-api/helpers.ts +16 -0
@@ -0,0 +1,15 @@
1
+ import { makeEmptyTokenAccount } from "@ledgerhq/coin-framework/account/helpers";
2
+ export function getAccountTuplesForCurrency(currency, allAccounts, accountIds) {
3
+ const isToken = currency.type === "TokenCurrency";
4
+ const targetCurrencyId = isToken ? currency.parentCurrency.id : currency.id;
5
+ return allAccounts
6
+ .filter(account => account.currency.id === targetCurrencyId &&
7
+ (isToken ? true : accountIds ? accountIds.has(account.id) : true))
8
+ .map(account => {
9
+ const subAccount = isToken
10
+ ? account.subAccounts?.find((subAcc) => subAcc.type === "TokenAccount" && subAcc.token.id === currency.id) || makeEmptyTokenAccount(account, currency)
11
+ : null;
12
+ return { account, subAccount };
13
+ });
14
+ }
15
+ //# sourceMappingURL=getAccountTuplesForCurrency.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getAccountTuplesForCurrency.js","sourceRoot":"","sources":["../../src/utils/getAccountTuplesForCurrency.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,qBAAqB,EAAE,MAAM,0CAA0C,CAAC;AAOjF,MAAM,UAAU,2BAA2B,CACzC,QAAwC,EACxC,WAAsB,EACtB,UAAiC;IAEjC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,KAAK,eAAe,CAAC;IAClD,MAAM,gBAAgB,GAAG,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;IAE5E,OAAO,WAAW;SACf,MAAM,CACL,OAAO,CAAC,EAAE,CACR,OAAO,CAAC,QAAQ,CAAC,EAAE,KAAK,gBAAgB;QACxC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CACpE;SACA,GAAG,CAAC,OAAO,CAAC,EAAE;QACb,MAAM,UAAU,GAAG,OAAO;YACxB,CAAC,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CACvB,CAAC,MAAM,EAA0B,EAAE,CACjC,MAAM,CAAC,IAAI,KAAK,cAAc,IAAI,MAAM,CAAC,KAAK,CAAC,EAAE,KAAK,QAAQ,CAAC,EAAE,CACpE,IAAI,qBAAqB,CAAC,OAAO,EAAE,QAAQ,CAAC;YAC/C,CAAC,CAAC,IAAI,CAAC;QAET,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -14,5 +14,6 @@ export declare const getInitialURL: (inputs: any, manifest: any) => any;
14
14
  export declare const safeUrl: (url: string) => URL | null;
15
15
  export declare const isHexPrefixed: (str: string) => boolean;
16
16
  export declare const stripHexPrefix: (str: string) => string;
17
+ export declare function objectToURLSearchParams(obj: Record<string, unknown>): URLSearchParams;
17
18
  export {};
18
19
  //# sourceMappingURL=helpers.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/wallet-api/helpers.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EACL,iBAAiB,EACjB,0BAA0B,EAC1B,2BAA2B,EAC3B,uBAAuB,EACxB,MAAM,SAAS,CAAC;AAIjB,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,QAAQ,GACjB,QAAQ,IAAI,0BAA0B,CASxC;AAED,wBAAgB,yBAAyB,CACvC,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,uBAAuB,CAErC;AAED,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,2BAA2B,CAEzC;AAED,wBAAgB,6BAA6B,CAC3C,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,2BAA2B,CAEzC;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,GAAG,IAAI,CAa1F;AAED,KAAK,oBAAoB,GAAG;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC;CACzB,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,oBAAoB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAKrF;AAgBD,eAAO,MAAM,aAAa,qCAoBzB,CAAC;AAEF,eAAO,MAAM,OAAO,QAAS,MAAM,eAMlC,CAAC;AAGF,eAAO,MAAM,aAAa,QAAS,MAAM,KAAG,OAM3C,CAAC;AAGF,eAAO,MAAM,cAAc,QAAS,MAAM,KAAG,MAK5C,CAAC"}
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/wallet-api/helpers.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,8BAA8B,CAAC;AACxD,OAAO,EACL,iBAAiB,EACjB,0BAA0B,EAC1B,2BAA2B,EAC3B,uBAAuB,EACxB,MAAM,SAAS,CAAC;AAIjB,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,QAAQ,GACjB,QAAQ,IAAI,0BAA0B,CASxC;AAED,wBAAgB,yBAAyB,CACvC,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,uBAAuB,CAErC;AAED,wBAAgB,wBAAwB,CACtC,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,2BAA2B,CAEzC;AAED,wBAAgB,6BAA6B,CAC3C,QAAQ,EAAE,iBAAiB,GAC1B,QAAQ,IAAI,2BAA2B,CAEzC;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAAC,GAAG,IAAI,CAa1F;AAED,KAAK,oBAAoB,GAAG;IAC1B,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC;CACzB,CAAC;AAEF,wBAAgB,gBAAgB,CAAC,MAAM,EAAE,oBAAoB,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAKrF;AAgBD,eAAO,MAAM,aAAa,qCAoBzB,CAAC;AAEF,eAAO,MAAM,OAAO,QAAS,MAAM,eAMlC,CAAC;AAGF,eAAO,MAAM,aAAa,QAAS,MAAM,KAAG,OAM3C,CAAC;AAGF,eAAO,MAAM,cAAc,QAAS,MAAM,KAAG,MAK5C,CAAC;AAEF,wBAAgB,uBAAuB,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,eAAe,CAcrF"}
@@ -83,4 +83,18 @@ export const stripHexPrefix = (str) => {
83
83
  throw new Error(`[stripHexPrefix] input must be type 'string', received ${typeof str}`);
84
84
  return isHexPrefixed(str) ? str.slice(2) : str;
85
85
  };
86
+ export function objectToURLSearchParams(obj) {
87
+ const searchParams = new URLSearchParams();
88
+ Object.entries(obj).forEach(([key, value]) => {
89
+ if (value !== undefined && value !== null) {
90
+ if (typeof value === "object") {
91
+ searchParams.append(key, JSON.stringify(value));
92
+ }
93
+ else {
94
+ searchParams.append(key, String(value));
95
+ }
96
+ }
97
+ });
98
+ return searchParams;
99
+ }
86
100
  //# sourceMappingURL=helpers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/wallet-api/helpers.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../src/wallet-api/helpers.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@ledgerhq/live-common",
3
3
  "description": "Common ground for the Ledger Live apps",
4
- "version": "34.43.0",
4
+ "version": "34.44.0-nightly.0",
5
5
  "repository": {
6
6
  "type": "git",
7
7
  "url": "https://github.com/LedgerHQ/ledger-live.git"
@@ -162,32 +162,32 @@
162
162
  "xstate": "^5.19.2",
163
163
  "yargs": "^17.0.0",
164
164
  "zod": "^3.22.4",
165
- "@ledgerhq/coin-algorand": "^0.9.15",
166
- "@ledgerhq/coin-aptos": "^2.7.0",
167
- "@ledgerhq/coin-bitcoin": "^0.19.0",
168
- "@ledgerhq/coin-cardano": "^0.10.1",
169
- "@ledgerhq/coin-casper": "^2.0.6",
170
- "@ledgerhq/coin-celo": "^1.1.13",
171
- "@ledgerhq/coin-cosmos": "^0.16.4",
172
- "@ledgerhq/coin-evm": "^2.25.0",
173
- "@ledgerhq/coin-filecoin": "^1.9.15",
174
- "@ledgerhq/coin-framework": "^5.8.0",
175
- "@ledgerhq/coin-hedera": "^1.9.1",
176
- "@ledgerhq/coin-icon": "^0.11.2",
177
- "@ledgerhq/coin-internet_computer": "^1.7.15",
178
- "@ledgerhq/coin-mina": "^1.1.14",
179
- "@ledgerhq/coin-multiversx": "^0.4.15",
180
- "@ledgerhq/coin-near": "^0.11.15",
181
- "@ledgerhq/coin-polkadot": "^6.5.0",
182
- "@ledgerhq/coin-solana": "^0.29.0",
183
- "@ledgerhq/coin-stacks": "^0.8.15",
184
- "@ledgerhq/coin-stellar": "^5.4.0",
185
- "@ledgerhq/coin-sui": "^0.8.0",
186
- "@ledgerhq/coin-tezos": "^5.7.0",
187
- "@ledgerhq/coin-ton": "^0.13.4",
188
- "@ledgerhq/coin-tron": "^4.5.0",
189
- "@ledgerhq/coin-vechain": "^2.7.15",
190
- "@ledgerhq/coin-xrp": "^6.5.0",
165
+ "@ledgerhq/coin-algorand": "^0.9.16-nightly.0",
166
+ "@ledgerhq/coin-aptos": "^2.7.1-nightly.0",
167
+ "@ledgerhq/coin-bitcoin": "^0.20.0-nightly.0",
168
+ "@ledgerhq/coin-cardano": "^0.10.2-nightly.0",
169
+ "@ledgerhq/coin-casper": "^2.0.7-nightly.0",
170
+ "@ledgerhq/coin-celo": "^1.1.14-nightly.0",
171
+ "@ledgerhq/coin-cosmos": "^0.16.5-nightly.0",
172
+ "@ledgerhq/coin-evm": "^2.26.0-nightly.0",
173
+ "@ledgerhq/coin-filecoin": "^1.9.16-nightly.0",
174
+ "@ledgerhq/coin-framework": "^5.9.0-nightly.0",
175
+ "@ledgerhq/coin-hedera": "^1.9.2-nightly.0",
176
+ "@ledgerhq/coin-icon": "^0.11.3-nightly.0",
177
+ "@ledgerhq/coin-internet_computer": "^1.7.16-nightly.0",
178
+ "@ledgerhq/coin-mina": "^1.1.15-nightly.0",
179
+ "@ledgerhq/coin-multiversx": "^0.4.16-nightly.0",
180
+ "@ledgerhq/coin-near": "^0.11.16-nightly.0",
181
+ "@ledgerhq/coin-polkadot": "^6.5.1-nightly.0",
182
+ "@ledgerhq/coin-solana": "^0.29.1-nightly.0",
183
+ "@ledgerhq/coin-stacks": "^0.8.16-nightly.0",
184
+ "@ledgerhq/coin-stellar": "^5.5.0-nightly.0",
185
+ "@ledgerhq/coin-sui": "^0.8.1-nightly.0",
186
+ "@ledgerhq/coin-tezos": "^5.7.1-nightly.0",
187
+ "@ledgerhq/coin-ton": "^0.13.5-nightly.0",
188
+ "@ledgerhq/coin-tron": "^4.5.1-nightly.0",
189
+ "@ledgerhq/coin-vechain": "^2.7.16-nightly.0",
190
+ "@ledgerhq/coin-xrp": "^6.5.1-nightly.0",
191
191
  "@ledgerhq/crypto-icons-ui": "^1.16.0",
192
192
  "@ledgerhq/cryptoassets": "^13.23.0",
193
193
  "@ledgerhq/device-core": "^0.5.4",
@@ -213,21 +213,21 @@
213
213
  "@ledgerhq/hw-app-xrp": "^6.32.2",
214
214
  "@ledgerhq/hw-transport": "^6.31.8",
215
215
  "@ledgerhq/hw-transport-mocker": "^6.29.8",
216
- "@ledgerhq/ledger-cal-service": "^1.2.1",
216
+ "@ledgerhq/ledger-cal-service": "^1.2.2-nightly.0",
217
217
  "@ledgerhq/live-config": "^3.1.0",
218
- "@ledgerhq/live-countervalues": "^0.5.15",
219
- "@ledgerhq/live-countervalues-react": "^0.2.44",
218
+ "@ledgerhq/live-countervalues": "^0.6.0-nightly.0",
219
+ "@ledgerhq/live-countervalues-react": "^0.2.45-nightly.0",
220
220
  "@ledgerhq/live-dmk-shared": "^0.11.1",
221
- "@ledgerhq/live-env": "^2.12.0",
221
+ "@ledgerhq/live-env": "^2.13.0-nightly.0",
222
222
  "@ledgerhq/live-hooks": "0.1.0",
223
- "@ledgerhq/live-network": "^2.0.13",
224
- "@ledgerhq/live-nft": "^0.8.15",
223
+ "@ledgerhq/live-network": "^2.0.14-nightly.0",
224
+ "@ledgerhq/live-nft": "^0.8.16-nightly.0",
225
225
  "@ledgerhq/live-promise": "^0.1.1",
226
- "@ledgerhq/live-signer-evm": "^0.6.2",
227
- "@ledgerhq/live-signer-solana": "^0.5.0",
228
- "@ledgerhq/live-wallet": "^0.11.6",
226
+ "@ledgerhq/live-signer-evm": "^0.6.3-nightly.0",
227
+ "@ledgerhq/live-signer-solana": "^0.5.1-nightly.0",
228
+ "@ledgerhq/live-wallet": "^0.12.0-nightly.0",
229
229
  "@ledgerhq/logs": "^6.13.0",
230
- "@ledgerhq/speculos-transport": "^0.2.6",
230
+ "@ledgerhq/speculos-transport": "^0.2.7-nightly.0",
231
231
  "@ledgerhq/wallet-api-acre-module": "^0.5.0",
232
232
  "@ledgerhq/wallet-api-exchange-module": "^0.14.0"
233
233
  },
@@ -7,6 +7,8 @@ import { accountRawToAccountUserData } from "@ledgerhq/live-wallet/store";
7
7
  import { createDataModel } from "./DataModel";
8
8
  import { fromAccountRaw, toAccountRaw } from "./account";
9
9
  import { getCurrencyConfiguration } from "./config";
10
+ import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
11
+ import { setCryptoAssetsStore as setCryptoAssetsStoreForCoinFramework } from "@ledgerhq/coin-framework/crypto-assets/index";
10
12
 
11
13
  jest.mock("./config", () => ({
12
14
  getCurrencyConfiguration: jest.fn(),
@@ -62,6 +64,12 @@ const evmAccount = {
62
64
  };
63
65
 
64
66
  describe("DataModel", () => {
67
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
68
+ setCryptoAssetsStoreForCoinFramework({
69
+ findTokenById: (_: string) => undefined,
70
+ findTokenByAddressInCurrency: (_: string, __: string) => undefined,
71
+ } as CryptoAssetsStore);
72
+
65
73
  test("createDataModel for crypto.org account", () => {
66
74
  const migratedCryptoOrgAccount = createDataModel(schema).decode(cryptoOrgAccount);
67
75
  expect(migratedCryptoOrgAccount.length).toBeGreaterThan(0);
@@ -0,0 +1,53 @@
1
+ {
2
+ "type": "TokenCurrency",
3
+ "id": "solana/spl/epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v",
4
+ "contractAddress": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
5
+ "parentCurrency": {
6
+ "type": "CryptoCurrency",
7
+ "id": "solana",
8
+ "coinType": 501,
9
+ "name": "Solana",
10
+ "managerAppName": "Solana",
11
+ "ticker": "SOL",
12
+ "scheme": "solana",
13
+ "color": "#000",
14
+ "family": "solana",
15
+ "units": [
16
+ {
17
+ "name": "SOL",
18
+ "code": "SOL",
19
+ "magnitude": 9
20
+ },
21
+ {
22
+ "name": "lamports",
23
+ "code": "lamports",
24
+ "magnitude": 0
25
+ }
26
+ ],
27
+ "explorerViews": [
28
+ {
29
+ "address": "https://explorer.solana.com/address/$address",
30
+ "tx": "https://explorer.solana.com/tx/$hash"
31
+ },
32
+ {
33
+ "address": "https://solanabeach.io/address/$address",
34
+ "tx": "https://solanabeach.io/transaction/$hash"
35
+ }
36
+ ],
37
+ "keywords": [
38
+ "sol",
39
+ "solana"
40
+ ]
41
+ },
42
+ "name": "USD Coin",
43
+ "tokenType": "spl",
44
+ "ticker": "USDC",
45
+ "disableCountervalue": false,
46
+ "units": [
47
+ {
48
+ "name": "USD Coin",
49
+ "code": "USDC",
50
+ "magnitude": 6
51
+ }
52
+ ]
53
+ }
@@ -2,8 +2,21 @@ import flatMap from "lodash/flatMap";
2
2
  import { fromAccountRaw, groupAccountOperationsByDay } from "../../account";
3
3
  import { TezosAccountRaw } from "../../families/tezos/types";
4
4
  import { setSupportedCurrencies } from "../../currencies";
5
+ import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
6
+ import { setup } from "../../bridge/impl";
7
+ import { LiveConfig } from "@ledgerhq/live-config/LiveConfig";
5
8
  setSupportedCurrencies(["tezos"]);
6
9
 
10
+ LiveConfig.setConfig({
11
+ feature_cal_lazy_loading: {
12
+ type: "boolean",
13
+ default: true,
14
+ },
15
+ });
16
+
17
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
18
+ setup({} as CryptoAssetsStore);
19
+
7
20
  const account = fromAccountRaw({
8
21
  id: "libcore:1:tezos:A:tezbox",
9
22
  seedIdentifier: "B",
@@ -116,6 +116,7 @@ setSupportedCurrencies([
116
116
  "sonic_blaze",
117
117
  "mina",
118
118
  "babylon",
119
+ "canton_network",
119
120
  ]);
120
121
  LiveConfig.setConfig(liveConfig);
121
122
 
@@ -1,3 +1,5 @@
1
+ import { setCryptoAssetsStore as setCryptoAssetsStoreForCoinFramework } from "@ledgerhq/coin-framework/crypto-assets/index";
2
+ import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
1
3
  import "./environment";
2
4
  import BigNumber from "bignumber.js";
3
5
 
@@ -11,3 +13,9 @@ expect.extend({
11
13
  return { message, pass };
12
14
  },
13
15
  });
16
+
17
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
18
+ setCryptoAssetsStoreForCoinFramework({
19
+ findTokenById: (_: string) => undefined,
20
+ findTokenByAddressInCurrency: (_: string, __: string) => undefined,
21
+ } as CryptoAssetsStore);
@@ -1,14 +1,32 @@
1
- import { getCryptoCurrencyById, getTokenById, setSupportedCurrencies } from "../currencies";
1
+ import { getCryptoCurrencyById, setSupportedCurrencies } from "../currencies";
2
2
  import { genAccount, genTokenAccount } from "@ledgerhq/coin-framework/mocks/account";
3
3
  import { toAccountRaw, fromAccountRaw } from "./serialization";
4
4
  import { setWalletAPIVersion } from "../wallet-api/version";
5
5
  import { WALLET_API_VERSION } from "../wallet-api/constants";
6
+ import { setCryptoAssetsStore as setCryptoAssetsStoreForCoinFramework } from "@ledgerhq/coin-framework/crypto-assets/index";
7
+ import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
8
+ import solanaSplTokenData from "../__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json";
9
+ import { TokenCurrency } from "@ledgerhq/types-cryptoassets";
6
10
 
7
11
  setWalletAPIVersion(WALLET_API_VERSION);
8
12
 
9
13
  setSupportedCurrencies(["solana"]);
10
14
  const Solana = getCryptoCurrencyById("solana");
11
- const USDC = getTokenById("solana/spl/epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v");
15
+
16
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
17
+ const USDC = solanaSplTokenData as TokenCurrency;
18
+
19
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
20
+ setCryptoAssetsStoreForCoinFramework({
21
+ findTokenById: (id: string) => {
22
+ if (id === "solana/spl/epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v") {
23
+ return USDC;
24
+ }
25
+
26
+ return undefined;
27
+ },
28
+ findTokenByAddressInCurrency: (_: string, __: string) => undefined,
29
+ } as CryptoAssetsStore);
12
30
 
13
31
  describe("serialization", () => {
14
32
  test("TokenAccount extra fields should be serialized/deserialized", () => {
@@ -1,4 +1,5 @@
1
- import appSupportsQuitApp from "./appSupportsQuitApp";
1
+ import appSupportsQuitApp, { minAppVersion } from "./appSupportsQuitApp";
2
+
2
3
  test("appSupportsQuitApp - Apps that are listed fail if version is lt", () => {
3
4
  expect(
4
5
  appSupportsQuitApp({
@@ -26,3 +27,8 @@ test("appSupportsQuitApp - Apps that are not listed pass the test", () => {
26
27
  }),
27
28
  ).toBeTruthy();
28
29
  });
30
+ test("minAppVersion - Sonic and Ethereum have the same min app version", () => {
31
+ expect(minAppVersion["Sonic"]).toBeDefined();
32
+ expect(minAppVersion["Ethereum"]).toBeDefined();
33
+ expect(minAppVersion["Sonic"]).toBe(minAppVersion["Ethereum"]);
34
+ });
@@ -122,6 +122,7 @@ export const minAppVersion = {
122
122
  "SSH/PGP Agent": "0.0.7",
123
123
  Sia: "0.4.2",
124
124
  Solana: "1.0.1",
125
+ Sonic: "1.4.0",
125
126
  Stacks: "0.0.0",
126
127
  Stellar: "3.2.2",
127
128
  Stratis: "1.5.0",
@@ -2,12 +2,6 @@ import { LiveConfig } from "@ledgerhq/live-config/LiveConfig";
2
2
  import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
3
3
  import * as legacy from "@ledgerhq/cryptoassets/tokens";
4
4
 
5
- let cryptoAssetsStore: CryptoAssetsStore | undefined = undefined;
6
-
7
- export function setCryptoAssetsStore(store: CryptoAssetsStore) {
8
- cryptoAssetsStore = store;
9
- }
10
-
11
5
  const legacyStore: CryptoAssetsStore = {
12
6
  findTokenByAddress: legacy.findTokenByAddress,
13
7
  getTokenById: legacy.getTokenById,
@@ -16,6 +10,12 @@ const legacyStore: CryptoAssetsStore = {
16
10
  findTokenByTicker: legacy.findTokenByTicker,
17
11
  };
18
12
 
13
+ let cryptoAssetsStore: CryptoAssetsStore | undefined = undefined;
14
+
15
+ export function setCryptoAssetsStore(store: CryptoAssetsStore) {
16
+ cryptoAssetsStore = store;
17
+ }
18
+
19
19
  export function getCryptoAssetsStore(): CryptoAssetsStore {
20
20
  const featureEnabled = LiveConfig.getValueByKey("feature_cal_lazy_loading");
21
21
  if (!featureEnabled) {
@@ -5,16 +5,16 @@ import { getNetworkAlpacaApi } from "./network/network-alpaca";
5
5
  import { Api } from "@ledgerhq/coin-framework/api/types";
6
6
  import { XrpCoinConfig } from "@ledgerhq/coin-xrp/config";
7
7
 
8
- export function getAlpacaApi(network: string, kind: "local" | "remote"): Api<any, any> {
8
+ export function getAlpacaApi(network: string, kind: "local" | "remote"): Api<any> {
9
9
  if (kind === "local") {
10
10
  switch (network) {
11
11
  case "ripple":
12
12
  case "xrp":
13
13
  return createXrpApi(
14
14
  getCurrencyConfiguration<XrpCoinConfig>(getCryptoCurrencyById("ripple")),
15
- ) as Api<any, any>;
15
+ ) as Api<any>;
16
16
  // as unknown as Api<any>; // FIXME: createXrpApi returns a strongly typed Api<XrpSender>, fix Api<any> to allow it
17
17
  }
18
18
  }
19
- return getNetworkAlpacaApi(network) satisfies Partial<Api<any, any>> as Api<any, any>;
19
+ return getNetworkAlpacaApi(network) satisfies Partial<Api<any>> as Api<any>;
20
20
  }
@@ -107,14 +107,9 @@ const buildValidateIntent = (networkFamily: string) =>
107
107
  return data;
108
108
  };
109
109
 
110
- // FIXME: shouldn't hardcode
111
- type AssetInfo = {
112
- type: "native"; // or "token" if applicable
113
- };
114
-
115
110
  const buildGetBalance = (networkFamily: string) =>
116
- async function getBalance(address: string): Promise<Balance<AssetInfo>[]> {
117
- const { data } = await network<Balance<AssetInfo>, unknown>({
111
+ async function getBalance(address: string): Promise<Balance[]> {
112
+ const { data } = await network<Balance, unknown>({
118
113
  method: "GET",
119
114
  url: `${ALPACA_URL}/${networkFamily}/account/${address}/balance`,
120
115
  });
@@ -191,7 +186,7 @@ export const getNetworkAlpacaApi = (networkFamily: string) =>
191
186
  listOperations: buildListOperations(networkFamily),
192
187
  lastBlock: buildLastBlock(networkFamily),
193
188
  craftTransaction: buildCraftTransaction(networkFamily),
194
- getBlock(_height): Promise<Block<any>> {
189
+ getBlock(_height): Promise<Block> {
195
190
  throw new Error("getBlock is not supported");
196
191
  },
197
192
  getBlockInfo(_height: number): Promise<BlockInfo> {
@@ -2,7 +2,7 @@ import { encodeAccountId } from "@ledgerhq/coin-framework/account/index";
2
2
  import { GetAccountShape, mergeOps } from "@ledgerhq/coin-framework/bridge/jsHelpers";
3
3
  import BigNumber from "bignumber.js";
4
4
  import { getAlpacaApi } from "./alpaca";
5
- import { adaptCoreOperationToLiveOperation } from "./utils";
5
+ import { adaptCoreOperationToLiveOperation, extractBalance } from "./utils";
6
6
 
7
7
  export function genericGetAccountShape(network: string, kind: "local" | "remote"): GetAccountShape {
8
8
  return async info => {
@@ -18,15 +18,14 @@ export function genericGetAccountShape(network: string, kind: "local" | "remote"
18
18
 
19
19
  const blockInfo = await getAlpacaApi(network, kind).lastBlock();
20
20
 
21
- const balanceRes = await getAlpacaApi(network, kind).getBalance(address);
22
- // FIXME: fix type Balance -> check "native" balance
23
- // is balance[0] always the native ?
24
- const balance = BigNumber(balanceRes[0].value.toString());
21
+ const balances = await getAlpacaApi(network, kind).getBalance(address);
22
+ const nativeBalance = extractBalance(balances, "native");
23
+ const balance = BigNumber(nativeBalance.value.toString());
25
24
 
26
25
  let spendableBalance: BigNumber;
27
- if (balanceRes[0]?.locked) {
26
+ if (nativeBalance.locked) {
28
27
  spendableBalance = BigNumber.max(
29
- balance.minus(BigNumber(balanceRes[0].locked.toString())),
28
+ balance.minus(BigNumber(nativeBalance.locked.toString())),
30
29
  BigNumber(0),
31
30
  );
32
31
  } else {
@@ -40,7 +40,7 @@ export const genericSignOperation =
40
40
  const transactionIntent = transactionToIntent(account, transaction);
41
41
  transactionIntent.senderPublicKey = publicKey;
42
42
  // NOTE: is setting the memo here instead of transactionToIntent sensible?
43
- const txWithMemo = transactionIntent as TransactionIntent<any, MapMemo<string, string>>;
43
+ const txWithMemo = transactionIntent as TransactionIntent<MapMemo<string, string>>;
44
44
  if (transaction["tag"]) {
45
45
  const txMemo = String(transaction["tag"]);
46
46
  txWithMemo.memo = {
@@ -0,0 +1,19 @@
1
+ import { extractBalance } from "./utils";
2
+
3
+ describe("Alpaca utils", () => {
4
+ describe("extractBalance", () => {
5
+ it("extracts an existing balance", () => {
6
+ expect(extractBalance([{ value: 4n, asset: { type: "type1" } }], "type1")).toEqual({
7
+ value: 4n,
8
+ asset: { type: "type1" },
9
+ });
10
+ });
11
+
12
+ it("generates an empty balance for a missing type", () => {
13
+ expect(extractBalance([{ value: 4n, asset: { type: "type1" } }], "type2")).toEqual({
14
+ value: 0n,
15
+ asset: { type: "type2" },
16
+ });
17
+ });
18
+ });
19
+ });
@@ -1,17 +1,18 @@
1
1
  import { encodeOperationId } from "@ledgerhq/coin-framework/operation";
2
2
  import { Account, Operation, OperationType, TransactionCommon } from "@ledgerhq/types-live";
3
3
  import {
4
+ Balance,
4
5
  Operation as CoreOperation,
5
- Asset,
6
6
  TransactionIntent,
7
7
  } from "@ledgerhq/coin-framework/api/types";
8
8
  import BigNumber from "bignumber.js";
9
9
  import { fromBigNumberToBigInt } from "@ledgerhq/coin-framework/utils";
10
10
 
11
- export function adaptCoreOperationToLiveOperation(
12
- accountId: string,
13
- op: CoreOperation<Asset>,
14
- ): Operation {
11
+ export function extractBalance(balances: Balance[], type: string): Balance {
12
+ return balances.find(balance => balance.asset.type === type) ?? { asset: { type }, value: 0n };
13
+ }
14
+
15
+ export function adaptCoreOperationToLiveOperation(accountId: string, op: CoreOperation): Operation {
15
16
  return {
16
17
  id: encodeOperationId(accountId, op.tx.hash, op.type),
17
18
  hash: op.tx.hash,
@@ -38,7 +39,7 @@ export function transactionToIntent(
38
39
  sender: account.freshAddress,
39
40
  recipient: transaction.recipient,
40
41
  amount: fromBigNumberToBigInt(transaction.amount, BigInt(0)),
41
- asset: null,
42
+ asset: { type: "native" },
42
43
  };
43
44
  }
44
45
 
@@ -2,6 +2,13 @@ import { sortCurrenciesByIds } from "./sortByMarketcap";
2
2
  import { findCurrencyByTicker, listCryptoCurrencies, listTokens } from ".";
3
3
  import { getBTCValues } from "@ledgerhq/live-countervalues/mock";
4
4
  import { CURRENCIES_LIST, IDS } from "./mock";
5
+ import { setCryptoAssetsStore as setCryptoAssetsStoreForCoinFramework } from "@ledgerhq/coin-framework/crypto-assets/index";
6
+ import { CryptoAssetsStore } from "@ledgerhq/coin-framework/crypto-assets/type";
7
+
8
+ // eslint-disable-next-line @typescript-eslint/consistent-type-assertions
9
+ setCryptoAssetsStoreForCoinFramework({
10
+ findTokenByTicker: (_: string) => undefined,
11
+ } as CryptoAssetsStore);
5
12
 
6
13
  test("sortCurrenciesByIds snapshot", () => {
7
14
  const list = [...listCryptoCurrencies(), ...listTokens()];