@ledgerhq/live-common 34.43.0 → 34.44.0-nightly.1
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.
- package/lib/DataModel.test.js +6 -0
- package/lib/DataModel.test.js.map +1 -1
- package/lib/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
- package/lib/__tests__/accounts/groupPerDay.js +10 -0
- package/lib/__tests__/accounts/groupPerDay.js.map +1 -1
- package/lib/__tests__/test-helpers/environment.js +1 -0
- package/lib/__tests__/test-helpers/environment.js.map +1 -1
- package/lib/__tests__/test-helpers/setup.d.ts.map +1 -1
- package/lib/__tests__/test-helpers/setup.js +6 -0
- package/lib/__tests__/test-helpers/setup.js.map +1 -1
- package/lib/account/serialization.test.js +17 -1
- package/lib/account/serialization.test.js.map +1 -1
- package/lib/appSupportsQuitApp.d.ts +1 -0
- package/lib/appSupportsQuitApp.d.ts.map +1 -1
- package/lib/appSupportsQuitApp.js +1 -0
- package/lib/appSupportsQuitApp.js.map +1 -1
- package/lib/appSupportsQuitApp.test.js +28 -3
- package/lib/appSupportsQuitApp.test.js.map +1 -1
- package/lib/bridge/crypto-assets/index.d.ts.map +1 -1
- package/lib/bridge/crypto-assets/index.js +5 -5
- package/lib/bridge/crypto-assets/index.js.map +1 -1
- package/lib/bridge/generic-alpaca/alpaca/index.d.ts +1 -1
- package/lib/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/alpaca/index.js.map +1 -1
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +2 -6
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
- package/lib/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/getAccountShape.js +5 -6
- package/lib/bridge/generic-alpaca/getAccountShape.js.map +1 -1
- package/lib/bridge/generic-alpaca/signOperation.js.map +1 -1
- package/lib/bridge/generic-alpaca/utils.d.ts +3 -2
- package/lib/bridge/generic-alpaca/utils.d.ts.map +1 -1
- package/lib/bridge/generic-alpaca/utils.js +6 -2
- package/lib/bridge/generic-alpaca/utils.js.map +1 -1
- package/lib/bridge/generic-alpaca/utils.test.d.ts +2 -0
- package/lib/bridge/generic-alpaca/utils.test.d.ts.map +1 -0
- package/lib/bridge/generic-alpaca/utils.test.js +20 -0
- package/lib/bridge/generic-alpaca/utils.test.js.map +1 -0
- package/lib/currencies/sortByMarketcap.test.js +5 -0
- package/lib/currencies/sortByMarketcap.test.js.map +1 -1
- package/lib/e2e/enum/Currency.js +1 -1
- package/lib/e2e/enum/Currency.js.map +1 -1
- package/lib/e2e/enum/Provider.d.ts +1 -0
- package/lib/e2e/enum/Provider.d.ts.map +1 -1
- package/lib/e2e/enum/Provider.js +1 -0
- package/lib/e2e/enum/Provider.js.map +1 -1
- package/lib/e2e/index.d.ts +3 -0
- package/lib/e2e/index.d.ts.map +1 -1
- package/lib/e2e/speculos.d.ts.map +1 -1
- package/lib/e2e/speculos.js +45 -15
- package/lib/e2e/speculos.js.map +1 -1
- package/lib/e2e/speculosCI.d.ts.map +1 -1
- package/lib/e2e/speculosCI.js +22 -4
- package/lib/e2e/speculosCI.js.map +1 -1
- package/lib/env.react.d.ts +1 -1
- package/lib/env.react.d.ts.map +1 -1
- package/lib/families/bitcoin/satstack.test.js +6 -0
- package/lib/families/bitcoin/satstack.test.js.map +1 -1
- package/lib/families/canton/bridge.integration.test.d.ts +2 -0
- package/lib/families/canton/bridge.integration.test.d.ts.map +1 -0
- package/lib/families/canton/bridge.integration.test.js +7 -0
- package/lib/families/canton/bridge.integration.test.js.map +1 -0
- package/lib/families/canton/config.d.ts +3 -0
- package/lib/families/canton/config.d.ts.map +1 -0
- package/lib/families/canton/config.js +14 -0
- package/lib/families/canton/config.js.map +1 -0
- package/lib/families/canton/logic.d.ts +2 -0
- package/lib/families/canton/logic.d.ts.map +1 -0
- package/lib/families/canton/logic.js +19 -0
- package/lib/families/canton/logic.js.map +1 -0
- package/lib/families/canton/setup.d.ts +27 -0
- package/lib/families/canton/setup.d.ts.map +1 -0
- package/lib/families/canton/setup.js +27 -0
- package/lib/families/canton/setup.js.map +1 -0
- package/lib/families/canton/types.d.ts +2 -0
- package/lib/families/canton/types.d.ts.map +1 -0
- package/lib/families/canton/types.js +19 -0
- package/lib/families/canton/types.js.map +1 -0
- package/lib/families/solana/bridge/mock-data.d.ts.map +1 -1
- package/lib/families/solana/bridge/mock-data.js +46 -316
- package/lib/families/solana/bridge/mock-data.js.map +1 -1
- package/lib/families/solana/bridge/mock.js +2 -2
- package/lib/families/solana/bridge/mock.js.map +1 -1
- package/lib/families/stellar/ui.d.ts +6 -0
- package/lib/families/stellar/ui.d.ts.map +1 -0
- package/lib/families/stellar/ui.js +18 -0
- package/lib/families/stellar/ui.js.map +1 -0
- package/lib/families/tron/data.mock.d.ts.map +1 -1
- package/lib/families/tron/data.mock.js +6 -0
- package/lib/families/tron/data.mock.js.map +1 -1
- package/lib/featureFlags/defaultFeatures.d.ts +1 -0
- package/lib/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib/featureFlags/defaultFeatures.js +1 -0
- package/lib/featureFlags/defaultFeatures.js.map +1 -1
- package/lib/generated/bridge/js.d.ts +1 -0
- package/lib/generated/bridge/js.d.ts.map +1 -1
- package/lib/generated/bridge/js.js +40 -38
- package/lib/generated/bridge/js.js.map +1 -1
- package/lib/generated/cli-transaction.d.ts +20 -0
- package/lib/generated/cli-transaction.d.ts.map +1 -1
- package/lib/generated/cli-transaction.js +42 -40
- package/lib/generated/cli-transaction.js.map +1 -1
- package/lib/generated/deviceTransactionConfig.d.ts +2 -0
- package/lib/generated/deviceTransactionConfig.d.ts.map +1 -1
- package/lib/generated/deviceTransactionConfig.js +38 -36
- package/lib/generated/deviceTransactionConfig.js.map +1 -1
- package/lib/generated/hw-getAddress.d.ts +1 -0
- package/lib/generated/hw-getAddress.d.ts.map +1 -1
- package/lib/generated/hw-getAddress.js +42 -40
- package/lib/generated/hw-getAddress.js.map +1 -1
- package/lib/generated/specs.d.ts +2 -0
- package/lib/generated/specs.d.ts.map +1 -1
- package/lib/generated/specs.js +40 -38
- package/lib/generated/specs.js.map +1 -1
- package/lib/generated/transaction.d.ts +8 -0
- package/lib/generated/transaction.d.ts.map +1 -1
- package/lib/generated/transaction.js +42 -40
- package/lib/generated/transaction.js.map +1 -1
- package/lib/generated/types.d.ts +5 -4
- package/lib/generated/types.d.ts.map +1 -1
- package/lib/modularDrawer/__mocks__/accounts.mock.d.ts +18 -0
- package/lib/modularDrawer/__mocks__/accounts.mock.d.ts.map +1 -0
- package/lib/modularDrawer/__mocks__/accounts.mock.js +48 -0
- package/lib/modularDrawer/__mocks__/accounts.mock.js.map +1 -0
- package/lib/modularDrawer/utils/__tests__/currencyUtils.test.d.ts +2 -0
- package/lib/modularDrawer/utils/__tests__/currencyUtils.test.d.ts.map +1 -0
- package/lib/modularDrawer/utils/__tests__/currencyUtils.test.js +100 -0
- package/lib/modularDrawer/utils/__tests__/currencyUtils.test.js.map +1 -0
- package/lib/modularDrawer/utils/currencyUtils.d.ts +10 -0
- package/lib/modularDrawer/utils/currencyUtils.d.ts.map +1 -0
- package/lib/modularDrawer/utils/currencyUtils.js +74 -0
- package/lib/modularDrawer/utils/currencyUtils.js.map +1 -0
- package/lib/modularDrawer/utils/haveOneCommonProvider.d.ts +1 -1
- package/lib/modularDrawer/utils/haveOneCommonProvider.d.ts.map +1 -1
- package/lib/utils/__tests__/composeHooks.test.d.ts +2 -0
- package/lib/utils/__tests__/composeHooks.test.d.ts.map +1 -0
- package/lib/utils/__tests__/composeHooks.test.js +35 -0
- package/lib/utils/__tests__/composeHooks.test.js.map +1 -0
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +2 -0
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +1 -0
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js +104 -0
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -0
- package/lib/utils/composeHooks.d.ts +11 -0
- package/lib/utils/composeHooks.d.ts.map +1 -0
- package/lib/utils/composeHooks.js +25 -0
- package/lib/utils/composeHooks.js.map +1 -0
- package/lib/utils/getAccountTuplesForCurrency.d.ts +8 -0
- package/lib/utils/getAccountTuplesForCurrency.d.ts.map +1 -0
- package/lib/utils/getAccountTuplesForCurrency.js +19 -0
- package/lib/utils/getAccountTuplesForCurrency.js.map +1 -0
- package/lib/wallet-api/helpers.d.ts +1 -0
- package/lib/wallet-api/helpers.d.ts.map +1 -1
- package/lib/wallet-api/helpers.js +16 -1
- package/lib/wallet-api/helpers.js.map +1 -1
- package/lib-es/DataModel.test.js +6 -0
- package/lib-es/DataModel.test.js.map +1 -1
- package/lib-es/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
- package/lib-es/__tests__/accounts/groupPerDay.js +10 -0
- package/lib-es/__tests__/accounts/groupPerDay.js.map +1 -1
- package/lib-es/__tests__/test-helpers/environment.js +1 -0
- package/lib-es/__tests__/test-helpers/environment.js.map +1 -1
- package/lib-es/__tests__/test-helpers/setup.d.ts.map +1 -1
- package/lib-es/__tests__/test-helpers/setup.js +6 -0
- package/lib-es/__tests__/test-helpers/setup.js.map +1 -1
- package/lib-es/account/serialization.test.js +15 -2
- package/lib-es/account/serialization.test.js.map +1 -1
- package/lib-es/appSupportsQuitApp.d.ts +1 -0
- package/lib-es/appSupportsQuitApp.d.ts.map +1 -1
- package/lib-es/appSupportsQuitApp.js +1 -0
- package/lib-es/appSupportsQuitApp.js.map +1 -1
- package/lib-es/appSupportsQuitApp.test.js +6 -1
- package/lib-es/appSupportsQuitApp.test.js.map +1 -1
- package/lib-es/bridge/crypto-assets/index.d.ts.map +1 -1
- package/lib-es/bridge/crypto-assets/index.js +4 -4
- package/lib-es/bridge/crypto-assets/index.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts +1 -1
- package/lib-es/bridge/generic-alpaca/alpaca/index.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/alpaca/index.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts +2 -6
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/alpaca/network/network-alpaca.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/getAccountShape.js +6 -7
- package/lib-es/bridge/generic-alpaca/getAccountShape.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/signOperation.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/utils.d.ts +3 -2
- package/lib-es/bridge/generic-alpaca/utils.d.ts.map +1 -1
- package/lib-es/bridge/generic-alpaca/utils.js +4 -1
- package/lib-es/bridge/generic-alpaca/utils.js.map +1 -1
- package/lib-es/bridge/generic-alpaca/utils.test.d.ts +2 -0
- package/lib-es/bridge/generic-alpaca/utils.test.d.ts.map +1 -0
- package/lib-es/bridge/generic-alpaca/utils.test.js +18 -0
- package/lib-es/bridge/generic-alpaca/utils.test.js.map +1 -0
- package/lib-es/currencies/sortByMarketcap.test.js +5 -0
- package/lib-es/currencies/sortByMarketcap.test.js.map +1 -1
- package/lib-es/e2e/enum/Currency.js +1 -1
- package/lib-es/e2e/enum/Currency.js.map +1 -1
- package/lib-es/e2e/enum/Provider.d.ts +1 -0
- package/lib-es/e2e/enum/Provider.d.ts.map +1 -1
- package/lib-es/e2e/enum/Provider.js +1 -0
- package/lib-es/e2e/enum/Provider.js.map +1 -1
- package/lib-es/e2e/index.d.ts +3 -0
- package/lib-es/e2e/index.d.ts.map +1 -1
- package/lib-es/e2e/speculos.d.ts.map +1 -1
- package/lib-es/e2e/speculos.js +45 -15
- package/lib-es/e2e/speculos.js.map +1 -1
- package/lib-es/e2e/speculosCI.d.ts.map +1 -1
- package/lib-es/e2e/speculosCI.js +22 -4
- package/lib-es/e2e/speculosCI.js.map +1 -1
- package/lib-es/env.react.d.ts +1 -1
- package/lib-es/env.react.d.ts.map +1 -1
- package/lib-es/families/bitcoin/satstack.test.js +6 -0
- package/lib-es/families/bitcoin/satstack.test.js.map +1 -1
- package/lib-es/families/canton/bridge.integration.test.d.ts +2 -0
- package/lib-es/families/canton/bridge.integration.test.d.ts.map +1 -0
- package/lib-es/families/canton/bridge.integration.test.js +5 -0
- package/lib-es/families/canton/bridge.integration.test.js.map +1 -0
- package/lib-es/families/canton/config.d.ts +3 -0
- package/lib-es/families/canton/config.d.ts.map +1 -0
- package/lib-es/families/canton/config.js +11 -0
- package/lib-es/families/canton/config.js.map +1 -0
- package/lib-es/families/canton/logic.d.ts +2 -0
- package/lib-es/families/canton/logic.d.ts.map +1 -0
- package/lib-es/families/canton/logic.js +3 -0
- package/lib-es/families/canton/logic.js.map +1 -0
- package/lib-es/families/canton/setup.d.ts +27 -0
- package/lib-es/families/canton/setup.d.ts.map +1 -0
- package/lib-es/families/canton/setup.js +19 -0
- package/lib-es/families/canton/setup.js.map +1 -0
- package/lib-es/families/canton/types.d.ts +2 -0
- package/lib-es/families/canton/types.d.ts.map +1 -0
- package/lib-es/families/canton/types.js +3 -0
- package/lib-es/families/canton/types.js.map +1 -0
- package/lib-es/families/solana/bridge/mock-data.d.ts.map +1 -1
- package/lib-es/families/solana/bridge/mock-data.js +46 -316
- package/lib-es/families/solana/bridge/mock-data.js.map +1 -1
- package/lib-es/families/solana/bridge/mock.js +3 -3
- package/lib-es/families/solana/bridge/mock.js.map +1 -1
- package/lib-es/families/stellar/ui.d.ts +6 -0
- package/lib-es/families/stellar/ui.d.ts.map +1 -0
- package/lib-es/families/stellar/ui.js +14 -0
- package/lib-es/families/stellar/ui.js.map +1 -0
- package/lib-es/families/tron/data.mock.d.ts.map +1 -1
- package/lib-es/families/tron/data.mock.js +6 -0
- package/lib-es/families/tron/data.mock.js.map +1 -1
- package/lib-es/featureFlags/defaultFeatures.d.ts +1 -0
- package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib-es/featureFlags/defaultFeatures.js +1 -0
- package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
- package/lib-es/generated/bridge/js.d.ts +1 -0
- package/lib-es/generated/bridge/js.d.ts.map +1 -1
- package/lib-es/generated/bridge/js.js +2 -0
- package/lib-es/generated/bridge/js.js.map +1 -1
- package/lib-es/generated/cli-transaction.d.ts +20 -0
- package/lib-es/generated/cli-transaction.d.ts.map +1 -1
- package/lib-es/generated/cli-transaction.js +2 -0
- package/lib-es/generated/cli-transaction.js.map +1 -1
- package/lib-es/generated/deviceTransactionConfig.d.ts +2 -0
- package/lib-es/generated/deviceTransactionConfig.d.ts.map +1 -1
- package/lib-es/generated/deviceTransactionConfig.js +2 -0
- package/lib-es/generated/deviceTransactionConfig.js.map +1 -1
- package/lib-es/generated/hw-getAddress.d.ts +1 -0
- package/lib-es/generated/hw-getAddress.d.ts.map +1 -1
- package/lib-es/generated/hw-getAddress.js +2 -0
- package/lib-es/generated/hw-getAddress.js.map +1 -1
- package/lib-es/generated/specs.d.ts +2 -0
- package/lib-es/generated/specs.d.ts.map +1 -1
- package/lib-es/generated/specs.js +2 -0
- package/lib-es/generated/specs.js.map +1 -1
- package/lib-es/generated/transaction.d.ts +8 -0
- package/lib-es/generated/transaction.d.ts.map +1 -1
- package/lib-es/generated/transaction.js +2 -0
- package/lib-es/generated/transaction.js.map +1 -1
- package/lib-es/generated/types.d.ts +5 -4
- package/lib-es/generated/types.d.ts.map +1 -1
- package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts +18 -0
- package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts.map +1 -0
- package/lib-es/modularDrawer/__mocks__/accounts.mock.js +42 -0
- package/lib-es/modularDrawer/__mocks__/accounts.mock.js.map +1 -0
- package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.d.ts +2 -0
- package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.d.ts.map +1 -0
- package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js +98 -0
- package/lib-es/modularDrawer/utils/__tests__/currencyUtils.test.js.map +1 -0
- package/lib-es/modularDrawer/utils/currencyUtils.d.ts +10 -0
- package/lib-es/modularDrawer/utils/currencyUtils.d.ts.map +1 -0
- package/lib-es/modularDrawer/utils/currencyUtils.js +65 -0
- package/lib-es/modularDrawer/utils/currencyUtils.js.map +1 -0
- package/lib-es/modularDrawer/utils/haveOneCommonProvider.d.ts +1 -1
- package/lib-es/modularDrawer/utils/haveOneCommonProvider.d.ts.map +1 -1
- package/lib-es/utils/__tests__/composeHooks.test.d.ts +2 -0
- package/lib-es/utils/__tests__/composeHooks.test.d.ts.map +1 -0
- package/lib-es/utils/__tests__/composeHooks.test.js +33 -0
- package/lib-es/utils/__tests__/composeHooks.test.js.map +1 -0
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +2 -0
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +1 -0
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js +102 -0
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js.map +1 -0
- package/lib-es/utils/composeHooks.d.ts +11 -0
- package/lib-es/utils/composeHooks.d.ts.map +1 -0
- package/lib-es/utils/composeHooks.js +21 -0
- package/lib-es/utils/composeHooks.js.map +1 -0
- package/lib-es/utils/getAccountTuplesForCurrency.d.ts +8 -0
- package/lib-es/utils/getAccountTuplesForCurrency.d.ts.map +1 -0
- package/lib-es/utils/getAccountTuplesForCurrency.js +15 -0
- package/lib-es/utils/getAccountTuplesForCurrency.js.map +1 -0
- package/lib-es/wallet-api/helpers.d.ts +1 -0
- package/lib-es/wallet-api/helpers.d.ts.map +1 -1
- package/lib-es/wallet-api/helpers.js +14 -0
- package/lib-es/wallet-api/helpers.js.map +1 -1
- package/package.json +40 -38
- package/src/DataModel.test.ts +8 -0
- package/src/__fixtures__/solana-spl-epjfwdd5aufqssqem2qn1xzybapc8g4weggkzwytdt1v.json +53 -0
- package/src/__tests__/accounts/groupPerDay.ts +13 -0
- package/src/__tests__/test-helpers/environment.ts +1 -0
- package/src/__tests__/test-helpers/setup.ts +8 -0
- package/src/account/serialization.test.ts +20 -2
- package/src/appSupportsQuitApp.test.ts +7 -1
- package/src/appSupportsQuitApp.ts +1 -0
- package/src/bridge/crypto-assets/index.ts +6 -6
- package/src/bridge/generic-alpaca/alpaca/index.ts +3 -3
- package/src/bridge/generic-alpaca/alpaca/network/network-alpaca.ts +3 -8
- package/src/bridge/generic-alpaca/getAccountShape.ts +6 -7
- package/src/bridge/generic-alpaca/signOperation.ts +1 -1
- package/src/bridge/generic-alpaca/utils.test.ts +19 -0
- package/src/bridge/generic-alpaca/utils.ts +7 -6
- package/src/currencies/sortByMarketcap.test.ts +7 -0
- package/src/e2e/enum/Currency.ts +1 -1
- package/src/e2e/enum/Provider.ts +1 -0
- package/src/e2e/speculos.ts +77 -21
- package/src/e2e/speculosCI.ts +32 -10
- package/src/families/bitcoin/satstack.test.ts +7 -0
- package/src/families/canton/bridge.integration.test.ts +6 -0
- package/src/families/canton/config.ts +12 -0
- package/src/families/canton/logic.ts +2 -0
- package/src/families/canton/setup.ts +34 -0
- package/src/families/canton/types.ts +2 -0
- package/src/families/solana/bridge/mock-data.ts +52 -316
- package/src/families/solana/bridge/mock.ts +3 -3
- package/src/families/stellar/__snapshots__/bridge.integration.test.ts.snap +1930 -94
- package/src/families/stellar/ui.ts +15 -0
- package/src/families/tron/data.mock.ts +8 -0
- package/src/featureFlags/defaultFeatures.ts +1 -0
- package/src/generated/bridge/js.ts +2 -0
- package/src/generated/cli-transaction.ts +2 -0
- package/src/generated/deviceTransactionConfig.ts +2 -0
- package/src/generated/hw-getAddress.ts +2 -0
- package/src/generated/specs.ts +2 -0
- package/src/generated/transaction.ts +2 -0
- package/src/generated/types.ts +10 -0
- package/src/modularDrawer/__mocks__/accounts.mock.ts +43 -0
- package/src/modularDrawer/utils/__tests__/currencyUtils.test.ts +126 -0
- package/src/modularDrawer/utils/currencyUtils.ts +95 -0
- package/src/modularDrawer/utils/haveOneCommonProvider.ts +1 -1
- package/src/utils/__tests__/composeHooks.test.ts +46 -0
- package/src/utils/__tests__/getAccountTuplesForCurrency.test.ts +138 -0
- package/src/utils/composeHooks.ts +26 -0
- package/src/utils/getAccountTuplesForCurrency.ts +34 -0
- package/src/wallet-api/helpers.ts +16 -0
@@ -0,0 +1,102 @@
|
|
1
|
+
import { getCryptoCurrencyById, getTokenById } from "@ledgerhq/cryptoassets";
|
2
|
+
import { genAccount } from "@ledgerhq/live-common/mock/account";
|
3
|
+
import { getAccountTuplesForCurrency } from "../getAccountTuplesForCurrency";
|
4
|
+
function* accountGenerator(currency) {
|
5
|
+
let id = 0;
|
6
|
+
while (true) {
|
7
|
+
id += 1;
|
8
|
+
yield genAccount(`mocked-account-${id}`, { currency, operationsSize: 0 });
|
9
|
+
}
|
10
|
+
}
|
11
|
+
const getAccountCreator = (currencyId) => {
|
12
|
+
const generator = accountGenerator(getCryptoCurrencyById(currencyId));
|
13
|
+
return () => generator.next().value;
|
14
|
+
};
|
15
|
+
describe("getAccountTuplesForCurrency", () => {
|
16
|
+
const getEthAccount = getAccountCreator("ethereum");
|
17
|
+
const getBtcAccount = getAccountCreator("bitcoin");
|
18
|
+
const getPolkadotAccount = getAccountCreator("polkadot");
|
19
|
+
const getCosmosAccount = getAccountCreator("cosmos");
|
20
|
+
describe("CryptoCurrency", () => {
|
21
|
+
test("returns all accounts associated to the CryptoCurrency", () => {
|
22
|
+
const ethCurrency = getCryptoCurrencyById("ethereum");
|
23
|
+
const ethAccounts = [getEthAccount(), getEthAccount()];
|
24
|
+
const allAccounts = [
|
25
|
+
getCosmosAccount(),
|
26
|
+
...ethAccounts,
|
27
|
+
getBtcAccount(),
|
28
|
+
getPolkadotAccount(),
|
29
|
+
];
|
30
|
+
const results = getAccountTuplesForCurrency(ethCurrency, allAccounts);
|
31
|
+
expect(results).toHaveLength(2);
|
32
|
+
results.forEach((result, index) => {
|
33
|
+
expect(result.account).toEqual(ethAccounts[index]);
|
34
|
+
expect(result.subAccount).toBeNull();
|
35
|
+
});
|
36
|
+
});
|
37
|
+
test("returns an empty array if the CryptoCurrency passed has no associated account", () => {
|
38
|
+
const ethCurrency = getCryptoCurrencyById("ethereum");
|
39
|
+
const allAccounts = [getCosmosAccount(), getBtcAccount(), getPolkadotAccount()];
|
40
|
+
const results = getAccountTuplesForCurrency(ethCurrency, allAccounts);
|
41
|
+
expect(results).toHaveLength(0);
|
42
|
+
});
|
43
|
+
test("filters based on the accountId map", () => {
|
44
|
+
const ethCurrency = getCryptoCurrencyById("ethereum");
|
45
|
+
const ethAccounts = [getEthAccount(), getEthAccount(), getEthAccount(), getEthAccount()];
|
46
|
+
const results = getAccountTuplesForCurrency(ethCurrency, ethAccounts, new Map([[ethAccounts[0].id, true]]));
|
47
|
+
expect(results).toHaveLength(1);
|
48
|
+
});
|
49
|
+
});
|
50
|
+
describe("TokenCurrency", () => {
|
51
|
+
const aaveToken = getTokenById("ethereum/erc20/aave");
|
52
|
+
test("returns correct parent accounts including a new subAccount when a TokenCurrency is provided", () => {
|
53
|
+
const ethAccounts = [
|
54
|
+
{ ...getEthAccount(), subAccounts: [] },
|
55
|
+
{ ...getEthAccount(), subAccounts: [] },
|
56
|
+
];
|
57
|
+
const allAccounts = [
|
58
|
+
getCosmosAccount(),
|
59
|
+
...ethAccounts,
|
60
|
+
getBtcAccount(),
|
61
|
+
getPolkadotAccount(),
|
62
|
+
];
|
63
|
+
const results = getAccountTuplesForCurrency(aaveToken, allAccounts);
|
64
|
+
expect(results).toHaveLength(ethAccounts.length);
|
65
|
+
results.forEach((result, index) => {
|
66
|
+
expect(result.account).toEqual(ethAccounts[index]);
|
67
|
+
expect(result.subAccount.token).toEqual(aaveToken);
|
68
|
+
});
|
69
|
+
});
|
70
|
+
test("returns correct parent accounts including already existing subAccounts when a TokenCurrency is provided", () => {
|
71
|
+
const ethAccounts = [{ ...getEthAccount(), subAccounts: [aaveToken] }];
|
72
|
+
const allAccounts = [
|
73
|
+
getCosmosAccount(),
|
74
|
+
...ethAccounts,
|
75
|
+
getBtcAccount(),
|
76
|
+
getPolkadotAccount(),
|
77
|
+
];
|
78
|
+
const results = getAccountTuplesForCurrency(aaveToken, allAccounts);
|
79
|
+
expect(results).toHaveLength(ethAccounts.length);
|
80
|
+
results.forEach((result, index) => {
|
81
|
+
expect(result.account).toEqual(ethAccounts[index]);
|
82
|
+
expect(result.subAccount.token).toEqual(aaveToken);
|
83
|
+
});
|
84
|
+
});
|
85
|
+
test("returns an empty array when a TokenCurrency is provided but the accounts list is empty", () => {
|
86
|
+
const allAccounts = [];
|
87
|
+
const results = getAccountTuplesForCurrency(aaveToken, allAccounts);
|
88
|
+
expect(results).toHaveLength(0);
|
89
|
+
});
|
90
|
+
test("does not filter based on the accountId map", () => {
|
91
|
+
const aaveAccounts = [
|
92
|
+
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
93
|
+
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
94
|
+
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
95
|
+
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
96
|
+
];
|
97
|
+
const results = getAccountTuplesForCurrency(aaveToken, aaveAccounts, new Map([[aaveAccounts[0].id, true]]));
|
98
|
+
expect(results).toHaveLength(4);
|
99
|
+
});
|
100
|
+
});
|
101
|
+
});
|
102
|
+
//# sourceMappingURL=getAccountTuplesForCurrency.test.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"getAccountTuplesForCurrency.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/getAccountTuplesForCurrency.test.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
/**
|
2
|
+
*
|
3
|
+
* @param hooks - An array of functions that take an array of items of type T and return an array of items of type U or undefined.
|
4
|
+
* @template T - The type of the items in the input array.
|
5
|
+
* @template U - The type of the items in the output array.
|
6
|
+
* @description This function composes multiple hooks into a single hook that processes an array of items of type T and returns an array of items of type T & U.
|
7
|
+
* @returns A function that takes an array of items of type T and returns an array of items of type T & U.
|
8
|
+
*
|
9
|
+
*/
|
10
|
+
export declare function composeHooks<T, U>(...hooks: Array<(items: T[]) => U[] | undefined>): (items: T[]) => (T & U)[];
|
11
|
+
//# sourceMappingURL=composeHooks.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"composeHooks.d.ts","sourceRoot":"","sources":["../../src/utils/composeHooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,wBAAgB,YAAY,CAAC,CAAC,EAAE,CAAC,EAC/B,GAAG,KAAK,EAAE,KAAK,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,EAAE,GAAG,SAAS,CAAC,GAC/C,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAa3B"}
|
@@ -0,0 +1,21 @@
|
|
1
|
+
/**
|
2
|
+
*
|
3
|
+
* @param hooks - An array of functions that take an array of items of type T and return an array of items of type U or undefined.
|
4
|
+
* @template T - The type of the items in the input array.
|
5
|
+
* @template U - The type of the items in the output array.
|
6
|
+
* @description This function composes multiple hooks into a single hook that processes an array of items of type T and returns an array of items of type T & U.
|
7
|
+
* @returns A function that takes an array of items of type T and returns an array of items of type T & U.
|
8
|
+
*
|
9
|
+
*/
|
10
|
+
export function composeHooks(...hooks) {
|
11
|
+
return (items) => {
|
12
|
+
return hooks.reduce((acc, hook) => {
|
13
|
+
const result = hook?.(acc) ?? [];
|
14
|
+
return acc.map((item, i) => ({
|
15
|
+
...item,
|
16
|
+
...result[i],
|
17
|
+
}));
|
18
|
+
}, items);
|
19
|
+
};
|
20
|
+
}
|
21
|
+
//# sourceMappingURL=composeHooks.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"composeHooks.js","sourceRoot":"","sources":["../../src/utils/composeHooks.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,MAAM,UAAU,YAAY,CAC1B,GAAG,KAA6C;IAEhD,OAAO,CAAC,KAAU,EAAa,EAAE;QAC/B,OAAO,KAAK,CAAC,MAAM,CACjB,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;YACZ,MAAM,MAAM,GAAG,IAAI,EAAE,CAAC,GAAU,CAAC,IAAI,EAAE,CAAC;YACxC,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;gBAC3B,GAAG,IAAI;gBACP,GAAG,MAAM,CAAC,CAAC,CAAC;aACb,CAAC,CAAC,CAAC;QACN,CAAC,EACD,KAAkB,CACnB,CAAC;IACJ,CAAC,CAAC;AACJ,CAAC"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
import type { Account, TokenAccount } from "@ledgerhq/types-live";
|
2
|
+
import { CryptoCurrency, TokenCurrency } from "@ledgerhq/types-cryptoassets";
|
3
|
+
export type AccountTuple = {
|
4
|
+
account: Account;
|
5
|
+
subAccount: TokenAccount | null;
|
6
|
+
};
|
7
|
+
export declare function getAccountTuplesForCurrency(currency: CryptoCurrency | TokenCurrency, allAccounts: Account[], accountIds?: Map<string, boolean>): AccountTuple[];
|
8
|
+
//# sourceMappingURL=getAccountTuplesForCurrency.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"getAccountTuplesForCurrency.d.ts","sourceRoot":"","sources":["../../src/utils/getAccountTuplesForCurrency.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,8BAA8B,CAAC;AAG7E,MAAM,MAAM,YAAY,GAAG;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,UAAU,EAAE,YAAY,GAAG,IAAI,CAAC;CACjC,CAAC;AAEF,wBAAgB,2BAA2B,CACzC,QAAQ,EAAE,cAAc,GAAG,aAAa,EACxC,WAAW,EAAE,OAAO,EAAE,EACtB,UAAU,CAAC,EAAE,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,GAChC,YAAY,EAAE,CAoBhB"}
|
@@ -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.
|
4
|
+
"version": "34.44.0-nightly.1",
|
5
5
|
"repository": {
|
6
6
|
"type": "git",
|
7
7
|
"url": "https://github.com/LedgerHQ/ledger-live.git"
|
@@ -162,32 +162,33 @@
|
|
162
162
|
"xstate": "^5.19.2",
|
163
163
|
"yargs": "^17.0.0",
|
164
164
|
"zod": "^3.22.4",
|
165
|
-
"@ledgerhq/coin-algorand": "^0.9.
|
166
|
-
"@ledgerhq/coin-aptos": "^2.7.0",
|
167
|
-
"@ledgerhq/coin-bitcoin": "^0.
|
168
|
-
"@ledgerhq/coin-
|
169
|
-
"@ledgerhq/coin-
|
170
|
-
"@ledgerhq/coin-
|
171
|
-
"@ledgerhq/coin-
|
172
|
-
"@ledgerhq/coin-
|
173
|
-
"@ledgerhq/coin-
|
174
|
-
"@ledgerhq/coin-
|
175
|
-
"@ledgerhq/coin-
|
176
|
-
"@ledgerhq/coin-
|
177
|
-
"@ledgerhq/coin-
|
178
|
-
"@ledgerhq/coin-
|
179
|
-
"@ledgerhq/coin-
|
180
|
-
"@ledgerhq/coin-
|
181
|
-
"@ledgerhq/coin-
|
182
|
-
"@ledgerhq/coin-
|
183
|
-
"@ledgerhq/coin-
|
184
|
-
"@ledgerhq/coin-
|
185
|
-
"@ledgerhq/coin-
|
186
|
-
"@ledgerhq/coin-
|
187
|
-
"@ledgerhq/coin-
|
188
|
-
"@ledgerhq/coin-
|
189
|
-
"@ledgerhq/coin-
|
190
|
-
"@ledgerhq/coin-
|
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-canton": "^0.2.0-nightly.2",
|
169
|
+
"@ledgerhq/coin-cardano": "^0.10.2-nightly.0",
|
170
|
+
"@ledgerhq/coin-casper": "^2.0.7-nightly.0",
|
171
|
+
"@ledgerhq/coin-celo": "^1.1.14-nightly.0",
|
172
|
+
"@ledgerhq/coin-cosmos": "^0.16.5-nightly.0",
|
173
|
+
"@ledgerhq/coin-evm": "^2.26.0-nightly.0",
|
174
|
+
"@ledgerhq/coin-filecoin": "^1.9.16-nightly.0",
|
175
|
+
"@ledgerhq/coin-framework": "^5.9.0-nightly.0",
|
176
|
+
"@ledgerhq/coin-hedera": "^1.9.2-nightly.0",
|
177
|
+
"@ledgerhq/coin-icon": "^0.11.3-nightly.0",
|
178
|
+
"@ledgerhq/coin-internet_computer": "^1.7.16-nightly.0",
|
179
|
+
"@ledgerhq/coin-mina": "^1.1.15-nightly.0",
|
180
|
+
"@ledgerhq/coin-multiversx": "^0.4.16-nightly.0",
|
181
|
+
"@ledgerhq/coin-near": "^0.11.16-nightly.0",
|
182
|
+
"@ledgerhq/coin-polkadot": "^6.5.1-nightly.0",
|
183
|
+
"@ledgerhq/coin-solana": "^0.29.1-nightly.0",
|
184
|
+
"@ledgerhq/coin-stacks": "^0.8.16-nightly.0",
|
185
|
+
"@ledgerhq/coin-stellar": "^5.5.0-nightly.0",
|
186
|
+
"@ledgerhq/coin-sui": "^0.8.1-nightly.0",
|
187
|
+
"@ledgerhq/coin-tezos": "^5.7.1-nightly.0",
|
188
|
+
"@ledgerhq/coin-ton": "^0.13.5-nightly.0",
|
189
|
+
"@ledgerhq/coin-tron": "^4.5.1-nightly.0",
|
190
|
+
"@ledgerhq/coin-vechain": "^2.7.16-nightly.0",
|
191
|
+
"@ledgerhq/coin-xrp": "^6.5.1-nightly.0",
|
191
192
|
"@ledgerhq/crypto-icons-ui": "^1.16.0",
|
192
193
|
"@ledgerhq/cryptoassets": "^13.23.0",
|
193
194
|
"@ledgerhq/device-core": "^0.5.4",
|
@@ -213,21 +214,22 @@
|
|
213
214
|
"@ledgerhq/hw-app-xrp": "^6.32.2",
|
214
215
|
"@ledgerhq/hw-transport": "^6.31.8",
|
215
216
|
"@ledgerhq/hw-transport-mocker": "^6.29.8",
|
216
|
-
"@ledgerhq/ledger-cal-service": "^1.2.
|
217
|
+
"@ledgerhq/ledger-cal-service": "^1.2.2-nightly.0",
|
217
218
|
"@ledgerhq/live-config": "^3.1.0",
|
218
|
-
"@ledgerhq/live-countervalues": "^0.
|
219
|
-
"@ledgerhq/live-countervalues-react": "^0.2.
|
220
|
-
"@ledgerhq/live-
|
221
|
-
"@ledgerhq/live-env": "^2.12.0",
|
219
|
+
"@ledgerhq/live-countervalues": "^0.6.0-nightly.0",
|
220
|
+
"@ledgerhq/live-countervalues-react": "^0.2.45-nightly.0",
|
221
|
+
"@ledgerhq/live-env": "^2.13.0-nightly.0",
|
222
222
|
"@ledgerhq/live-hooks": "0.1.0",
|
223
|
-
"@ledgerhq/live-network": "^2.0.
|
224
|
-
"@ledgerhq/live-nft": "^0.8.
|
223
|
+
"@ledgerhq/live-network": "^2.0.14-nightly.0",
|
224
|
+
"@ledgerhq/live-nft": "^0.8.16-nightly.0",
|
225
|
+
"@ledgerhq/live-dmk-shared": "^0.11.1",
|
225
226
|
"@ledgerhq/live-promise": "^0.1.1",
|
226
|
-
"@ledgerhq/live-signer-evm": "^0.6.
|
227
|
-
"@ledgerhq/live-signer-solana": "^0.5.0",
|
228
|
-
"@ledgerhq/live-
|
227
|
+
"@ledgerhq/live-signer-evm": "^0.6.3-nightly.0",
|
228
|
+
"@ledgerhq/live-signer-solana": "^0.5.1-nightly.0",
|
229
|
+
"@ledgerhq/live-signer-canton": "^0.2.0-nightly.0",
|
230
|
+
"@ledgerhq/live-wallet": "^0.12.0-nightly.0",
|
229
231
|
"@ledgerhq/logs": "^6.13.0",
|
230
|
-
"@ledgerhq/speculos-transport": "^0.2.
|
232
|
+
"@ledgerhq/speculos-transport": "^0.2.7-nightly.0",
|
231
233
|
"@ledgerhq/wallet-api-acre-module": "^0.5.0",
|
232
234
|
"@ledgerhq/wallet-api-exchange-module": "^0.14.0"
|
233
235
|
},
|
package/src/DataModel.test.ts
CHANGED
@@ -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",
|
@@ -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,
|
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
|
-
|
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
|
+
});
|
@@ -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
|
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
|
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
|
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
|
117
|
-
const { data } = await network<Balance
|
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
|
189
|
+
getBlock(_height): Promise<Block> {
|
195
190
|
throw new Error("getBlock is not supported");
|
196
191
|
},
|
197
192
|
getBlockInfo(_height: number): Promise<BlockInfo> {
|