@ledgerhq/live-common 34.43.0-nightly.1 → 34.43.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.
- package/lib/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.d.ts +2 -0
- package/lib/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.d.ts.map +1 -0
- package/lib/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.js +114 -0
- package/lib/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.js.map +1 -0
- package/lib/deviceSDK/hooks/filterIgnoredFirmwareUpdates.d.ts +11 -0
- package/lib/deviceSDK/hooks/filterIgnoredFirmwareUpdates.d.ts.map +1 -0
- package/lib/deviceSDK/hooks/filterIgnoredFirmwareUpdates.js +26 -0
- package/lib/deviceSDK/hooks/filterIgnoredFirmwareUpdates.js.map +1 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.d.ts +12 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.d.ts.map +1 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.js +24 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.js.map +1 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.d.ts +2 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.d.ts.map +1 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.js +118 -0
- package/lib/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.js.map +1 -0
- package/lib/deviceSDK/hooks/useGetLatestAvailableFirmware.d.ts +3 -1
- package/lib/deviceSDK/hooks/useGetLatestAvailableFirmware.d.ts.map +1 -1
- package/lib/deviceSDK/hooks/useGetLatestAvailableFirmware.js +7 -3
- package/lib/deviceSDK/hooks/useGetLatestAvailableFirmware.js.map +1 -1
- package/lib/e2e/index.d.ts +2 -1
- package/lib/e2e/index.d.ts.map +1 -1
- package/lib/e2e/speculos.d.ts.map +1 -1
- package/lib/e2e/speculos.js +15 -45
- package/lib/e2e/speculos.js.map +1 -1
- package/lib/e2e/speculosCI.d.ts.map +1 -1
- package/lib/e2e/speculosCI.js +4 -22
- 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/solana/bridge/mock-data.d.ts.map +1 -1
- package/lib/families/solana/bridge/mock-data.js +316 -46
- 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/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib/featureFlags/defaultFeatures.js +4 -0
- package/lib/featureFlags/defaultFeatures.js.map +1 -1
- package/lib/featureFlags/useFeature.d.ts +1 -1
- package/lib/featureFlags/useFeature.d.ts.map +1 -1
- package/lib-es/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.d.ts +2 -0
- package/lib-es/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.d.ts.map +1 -0
- package/lib-es/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.js +112 -0
- package/lib-es/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.js.map +1 -0
- package/lib-es/deviceSDK/hooks/filterIgnoredFirmwareUpdates.d.ts +11 -0
- package/lib-es/deviceSDK/hooks/filterIgnoredFirmwareUpdates.d.ts.map +1 -0
- package/lib-es/deviceSDK/hooks/filterIgnoredFirmwareUpdates.js +22 -0
- package/lib-es/deviceSDK/hooks/filterIgnoredFirmwareUpdates.js.map +1 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.d.ts +12 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.d.ts.map +1 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.js +20 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.js.map +1 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.d.ts +2 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.d.ts.map +1 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.js +116 -0
- package/lib-es/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.js.map +1 -0
- package/lib-es/deviceSDK/hooks/useGetLatestAvailableFirmware.d.ts +3 -1
- package/lib-es/deviceSDK/hooks/useGetLatestAvailableFirmware.d.ts.map +1 -1
- package/lib-es/deviceSDK/hooks/useGetLatestAvailableFirmware.js +7 -3
- package/lib-es/deviceSDK/hooks/useGetLatestAvailableFirmware.js.map +1 -1
- package/lib-es/e2e/index.d.ts +2 -1
- 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 +15 -45
- 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 +4 -22
- 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/solana/bridge/mock-data.d.ts.map +1 -1
- package/lib-es/families/solana/bridge/mock-data.js +316 -46
- 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/featureFlags/defaultFeatures.d.ts.map +1 -1
- package/lib-es/featureFlags/defaultFeatures.js +4 -0
- package/lib-es/featureFlags/defaultFeatures.js.map +1 -1
- package/lib-es/featureFlags/useFeature.d.ts +1 -1
- package/lib-es/featureFlags/useFeature.d.ts.map +1 -1
- package/package.json +47 -47
- package/src/deviceSDK/hooks/__tests__/filterIgnoredFirmwareUpdates.test.ts +132 -0
- package/src/deviceSDK/hooks/filterIgnoredFirmwareUpdates.ts +27 -0
- package/src/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.test.ts +192 -0
- package/src/deviceSDK/hooks/getIgnoredOSUpdatesForDeviceModelAndPlatform.ts +28 -0
- package/src/deviceSDK/hooks/useGetLatestAvailableFirmware.ts +9 -2
- package/src/e2e/speculos.ts +21 -77
- package/src/e2e/speculosCI.ts +10 -32
- package/src/families/solana/bridge/mock-data.ts +316 -52
- package/src/families/solana/bridge/mock.ts +3 -3
- package/src/featureFlags/defaultFeatures.ts +4 -0
- package/lib/modularDrawer/__mocks__/accounts.mock.d.ts +0 -18
- package/lib/modularDrawer/__mocks__/accounts.mock.d.ts.map +0 -1
- package/lib/modularDrawer/__mocks__/accounts.mock.js +0 -48
- package/lib/modularDrawer/__mocks__/accounts.mock.js.map +0 -1
- package/lib/utils/__tests__/composeHooks.test.d.ts +0 -2
- package/lib/utils/__tests__/composeHooks.test.d.ts.map +0 -1
- package/lib/utils/__tests__/composeHooks.test.js +0 -35
- package/lib/utils/__tests__/composeHooks.test.js.map +0 -1
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +0 -2
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +0 -1
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js +0 -104
- package/lib/utils/__tests__/getAccountTuplesForCurrency.test.js.map +0 -1
- package/lib/utils/composeHooks.d.ts +0 -11
- package/lib/utils/composeHooks.d.ts.map +0 -1
- package/lib/utils/composeHooks.js +0 -25
- package/lib/utils/composeHooks.js.map +0 -1
- package/lib/utils/getAccountTuplesForCurrency.d.ts +0 -8
- package/lib/utils/getAccountTuplesForCurrency.d.ts.map +0 -1
- package/lib/utils/getAccountTuplesForCurrency.js +0 -19
- package/lib/utils/getAccountTuplesForCurrency.js.map +0 -1
- package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts +0 -18
- package/lib-es/modularDrawer/__mocks__/accounts.mock.d.ts.map +0 -1
- package/lib-es/modularDrawer/__mocks__/accounts.mock.js +0 -42
- package/lib-es/modularDrawer/__mocks__/accounts.mock.js.map +0 -1
- package/lib-es/utils/__tests__/composeHooks.test.d.ts +0 -2
- package/lib-es/utils/__tests__/composeHooks.test.d.ts.map +0 -1
- package/lib-es/utils/__tests__/composeHooks.test.js +0 -33
- package/lib-es/utils/__tests__/composeHooks.test.js.map +0 -1
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts +0 -2
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.d.ts.map +0 -1
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js +0 -102
- package/lib-es/utils/__tests__/getAccountTuplesForCurrency.test.js.map +0 -1
- package/lib-es/utils/composeHooks.d.ts +0 -11
- package/lib-es/utils/composeHooks.d.ts.map +0 -1
- package/lib-es/utils/composeHooks.js +0 -21
- package/lib-es/utils/composeHooks.js.map +0 -1
- package/lib-es/utils/getAccountTuplesForCurrency.d.ts +0 -8
- package/lib-es/utils/getAccountTuplesForCurrency.d.ts.map +0 -1
- package/lib-es/utils/getAccountTuplesForCurrency.js +0 -15
- package/lib-es/utils/getAccountTuplesForCurrency.js.map +0 -1
- package/src/modularDrawer/__mocks__/accounts.mock.ts +0 -43
- package/src/utils/__tests__/composeHooks.test.ts +0 -46
- package/src/utils/__tests__/getAccountTuplesForCurrency.test.ts +0 -138
- package/src/utils/composeHooks.ts +0 -26
- package/src/utils/getAccountTuplesForCurrency.ts +0 -34
@@ -1,48 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
4
|
-
};
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
6
|
-
exports.SCROLL_ACCOUNT = exports.BASE_ACCOUNT = exports.ETH_ACCOUNT_WITH_USDC = exports.ARB_ACCOUNT = exports.BTC_ACCOUNT = exports.ETH_ACCOUNT_2 = exports.ETH_ACCOUNT = exports.MOCKED_ARB_ACCOUNT = void 0;
|
7
|
-
const account_1 = require("@ledgerhq/coin-framework/lib/mocks/account");
|
8
|
-
const bignumber_js_1 = __importDefault(require("bignumber.js"));
|
9
|
-
const currencies_mock_1 = require("./currencies.mock");
|
10
|
-
const currencies_mock_2 = require("./currencies.mock");
|
11
|
-
const currencies_mock_3 = require("./currencies.mock");
|
12
|
-
const currencies_mock_4 = require("./currencies.mock");
|
13
|
-
const currencies_mock_5 = require("./currencies.mock");
|
14
|
-
exports.MOCKED_ARB_ACCOUNT = {
|
15
|
-
type: "Account",
|
16
|
-
id: "arbitrum1",
|
17
|
-
balance: new bignumber_js_1.default(34455),
|
18
|
-
creationDate: "2024-12-10T09:27:22.000Z",
|
19
|
-
currency: currencies_mock_2.mockArbitrumCryptoCurrency,
|
20
|
-
derivationMode: "",
|
21
|
-
freshAddress: "s37rhmi7hsm3i73hsm7i3hm83m8h87hsm87h3s8h33",
|
22
|
-
};
|
23
|
-
exports.ETH_ACCOUNT = (0, account_1.genAccount)("ethereum-1", {
|
24
|
-
currency: currencies_mock_3.mockEthCryptoCurrency,
|
25
|
-
});
|
26
|
-
exports.ETH_ACCOUNT_2 = (0, account_1.genAccount)("ethereum-2", {
|
27
|
-
currency: currencies_mock_3.mockEthCryptoCurrency,
|
28
|
-
});
|
29
|
-
exports.BTC_ACCOUNT = (0, account_1.genAccount)("bitcoin-1", {
|
30
|
-
currency: currencies_mock_1.mockBtcCryptoCurrency,
|
31
|
-
});
|
32
|
-
exports.ARB_ACCOUNT = (0, account_1.genAccount)("arbitrum-1", {
|
33
|
-
currency: currencies_mock_2.mockArbitrumCryptoCurrency,
|
34
|
-
tokenIds: ["arbitrum/erc20/arbitrum"],
|
35
|
-
});
|
36
|
-
exports.ETH_ACCOUNT_WITH_USDC = (0, account_1.genAccount)("ethereum-usdc", {
|
37
|
-
currency: currencies_mock_3.mockEthCryptoCurrency,
|
38
|
-
tokenIds: ["ethereum/erc20/usdc"],
|
39
|
-
});
|
40
|
-
exports.BASE_ACCOUNT = (0, account_1.genAccount)("base-1", {
|
41
|
-
currency: currencies_mock_4.mockBaseCryptoCurrency,
|
42
|
-
operationsSize: 100,
|
43
|
-
});
|
44
|
-
exports.SCROLL_ACCOUNT = (0, account_1.genAccount)("scroll-1", {
|
45
|
-
currency: currencies_mock_5.mockScrollCryptoCurrency,
|
46
|
-
operationsSize: 100,
|
47
|
-
});
|
48
|
-
//# sourceMappingURL=accounts.mock.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"accounts.mock.js","sourceRoot":"","sources":["../../../src/modularDrawer/__mocks__/accounts.mock.ts"],"names":[],"mappings":";;;;;;AAAA,wEAAwE;AACxE,gEAAqC;AACrC,uDAA0D;AAC1D,uDAA+D;AAC/D,uDAA0D;AAC1D,uDAA2D;AAC3D,uDAA6D;AAEhD,QAAA,kBAAkB,GAAG;IAChC,IAAI,EAAE,SAAS;IACf,EAAE,EAAE,WAAW;IACf,OAAO,EAAE,IAAI,sBAAS,CAAC,KAAK,CAAC;IAC7B,YAAY,EAAE,0BAA0B;IACxC,QAAQ,EAAE,4CAA0B;IACpC,cAAc,EAAE,EAAE;IAClB,YAAY,EAAE,4CAA4C;CAC3D,CAAC;AAEW,QAAA,WAAW,GAAG,IAAA,oBAAU,EAAC,YAAY,EAAE;IAClD,QAAQ,EAAE,uCAAqB;CAChC,CAAC,CAAC;AACU,QAAA,aAAa,GAAG,IAAA,oBAAU,EAAC,YAAY,EAAE;IACpD,QAAQ,EAAE,uCAAqB;CAChC,CAAC,CAAC;AACU,QAAA,WAAW,GAAG,IAAA,oBAAU,EAAC,WAAW,EAAE;IACjD,QAAQ,EAAE,uCAAqB;CAChC,CAAC,CAAC;AACU,QAAA,WAAW,GAAG,IAAA,oBAAU,EAAC,YAAY,EAAE;IAClD,QAAQ,EAAE,4CAA0B;IACpC,QAAQ,EAAE,CAAC,yBAAyB,CAAC;CACtC,CAAC,CAAC;AACU,QAAA,qBAAqB,GAAG,IAAA,oBAAU,EAAC,eAAe,EAAE;IAC/D,QAAQ,EAAE,uCAAqB;IAC/B,QAAQ,EAAE,CAAC,qBAAqB,CAAC;CAClC,CAAC,CAAC;AACU,QAAA,YAAY,GAAG,IAAA,oBAAU,EAAC,QAAQ,EAAE;IAC/C,QAAQ,EAAE,wCAAsB;IAChC,cAAc,EAAE,GAAG;CACpB,CAAC,CAAC;AACU,QAAA,cAAc,GAAG,IAAA,oBAAU,EAAC,UAAU,EAAE;IACnD,QAAQ,EAAE,0CAAwB;IAClC,cAAc,EAAE,GAAG;CACpB,CAAC,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"composeHooks.test.d.ts","sourceRoot":"","sources":["../../../src/utils/__tests__/composeHooks.test.ts"],"names":[],"mappings":""}
|
@@ -1,35 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
const composeHooks_1 = require("../composeHooks");
|
4
|
-
describe("composeHooks", () => {
|
5
|
-
it("should compose hooks and merge their results", () => {
|
6
|
-
const hook1 = (items) => items.map(item => ({ id: item.id, extra: item.id * 2 }));
|
7
|
-
const hook2 = (items) => items.map(item => ({ ...item, final: item.extra + 1 }));
|
8
|
-
const composed = (0, composeHooks_1.composeHooks)(hook1, hook2);
|
9
|
-
const input = [{ id: 1 }, { id: 2 }];
|
10
|
-
const processedInput = input.map(item => ({ id: item.id, extra: item.id * 2 }));
|
11
|
-
const result = composed(processedInput);
|
12
|
-
expect(result).toEqual([
|
13
|
-
{ id: 1, extra: 2, final: 3 },
|
14
|
-
{ id: 2, extra: 4, final: 5 },
|
15
|
-
]);
|
16
|
-
});
|
17
|
-
it("should handle hooks that return undefined", () => {
|
18
|
-
const hook1 = (items) => items.map(item => ({ id: item.id, extra: item.id * 2 }));
|
19
|
-
const hook2 = () => undefined;
|
20
|
-
const composed = (0, composeHooks_1.composeHooks)(hook1, hook2);
|
21
|
-
const input = [{ id: 1 }, { id: 2 }];
|
22
|
-
const result = composed(input);
|
23
|
-
expect(result).toEqual([
|
24
|
-
{ id: 1, extra: 2 },
|
25
|
-
{ id: 2, extra: 4 },
|
26
|
-
]);
|
27
|
-
});
|
28
|
-
it("should return the original items if no hooks are provided", () => {
|
29
|
-
const composed = (0, composeHooks_1.composeHooks)();
|
30
|
-
const input = [{ id: 1 }, { id: 2 }];
|
31
|
-
const result = composed(input);
|
32
|
-
expect(result).toEqual(input);
|
33
|
-
});
|
34
|
-
});
|
35
|
-
//# sourceMappingURL=composeHooks.test.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"composeHooks.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/composeHooks.test.ts"],"names":[],"mappings":";;AAAA,kDAA+C;AAE/C,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,KAAK,GAAG,CAAC,KAA4B,EAAE,EAAE,CAC7C,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,CAAC,KAA2C,EAAE,EAAE,CAC5D,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1D,MAAM,QAAQ,GAAG,IAAA,2BAAY,EAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5C,MAAM,KAAK,GAA0B,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QAC5D,MAAM,cAAc,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAChF,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC;QAExC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;YAC7B,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;SAC9B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,KAAK,GAAG,CAAC,KAA4B,EAAE,EAAE,CAC7C,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC;QAE9B,MAAM,QAAQ,GAAG,IAAA,2BAAY,EAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5C,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;QAE/B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;YACnB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;SACpB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,QAAQ,GAAG,IAAA,2BAAY,GAAE,CAAC;QAEhC,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;QAE/B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAccountTuplesForCurrency.test.d.ts","sourceRoot":"","sources":["../../../src/utils/__tests__/getAccountTuplesForCurrency.test.ts"],"names":[],"mappings":""}
|
@@ -1,104 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
const cryptoassets_1 = require("@ledgerhq/cryptoassets");
|
4
|
-
const account_1 = require("@ledgerhq/live-common/mock/account");
|
5
|
-
const getAccountTuplesForCurrency_1 = require("../getAccountTuplesForCurrency");
|
6
|
-
function* accountGenerator(currency) {
|
7
|
-
let id = 0;
|
8
|
-
while (true) {
|
9
|
-
id += 1;
|
10
|
-
yield (0, account_1.genAccount)(`mocked-account-${id}`, { currency, operationsSize: 0 });
|
11
|
-
}
|
12
|
-
}
|
13
|
-
const getAccountCreator = (currencyId) => {
|
14
|
-
const generator = accountGenerator((0, cryptoassets_1.getCryptoCurrencyById)(currencyId));
|
15
|
-
return () => generator.next().value;
|
16
|
-
};
|
17
|
-
describe("getAccountTuplesForCurrency", () => {
|
18
|
-
const getEthAccount = getAccountCreator("ethereum");
|
19
|
-
const getBtcAccount = getAccountCreator("bitcoin");
|
20
|
-
const getPolkadotAccount = getAccountCreator("polkadot");
|
21
|
-
const getCosmosAccount = getAccountCreator("cosmos");
|
22
|
-
describe("CryptoCurrency", () => {
|
23
|
-
test("returns all accounts associated to the CryptoCurrency", () => {
|
24
|
-
const ethCurrency = (0, cryptoassets_1.getCryptoCurrencyById)("ethereum");
|
25
|
-
const ethAccounts = [getEthAccount(), getEthAccount()];
|
26
|
-
const allAccounts = [
|
27
|
-
getCosmosAccount(),
|
28
|
-
...ethAccounts,
|
29
|
-
getBtcAccount(),
|
30
|
-
getPolkadotAccount(),
|
31
|
-
];
|
32
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(ethCurrency, allAccounts);
|
33
|
-
expect(results).toHaveLength(2);
|
34
|
-
results.forEach((result, index) => {
|
35
|
-
expect(result.account).toEqual(ethAccounts[index]);
|
36
|
-
expect(result.subAccount).toBeNull();
|
37
|
-
});
|
38
|
-
});
|
39
|
-
test("returns an empty array if the CryptoCurrency passed has no associated account", () => {
|
40
|
-
const ethCurrency = (0, cryptoassets_1.getCryptoCurrencyById)("ethereum");
|
41
|
-
const allAccounts = [getCosmosAccount(), getBtcAccount(), getPolkadotAccount()];
|
42
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(ethCurrency, allAccounts);
|
43
|
-
expect(results).toHaveLength(0);
|
44
|
-
});
|
45
|
-
test("filters based on the accountId map", () => {
|
46
|
-
const ethCurrency = (0, cryptoassets_1.getCryptoCurrencyById)("ethereum");
|
47
|
-
const ethAccounts = [getEthAccount(), getEthAccount(), getEthAccount(), getEthAccount()];
|
48
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(ethCurrency, ethAccounts, new Map([[ethAccounts[0].id, true]]));
|
49
|
-
expect(results).toHaveLength(1);
|
50
|
-
});
|
51
|
-
});
|
52
|
-
describe("TokenCurrency", () => {
|
53
|
-
const aaveToken = (0, cryptoassets_1.getTokenById)("ethereum/erc20/aave");
|
54
|
-
test("returns correct parent accounts including a new subAccount when a TokenCurrency is provided", () => {
|
55
|
-
const ethAccounts = [
|
56
|
-
{ ...getEthAccount(), subAccounts: [] },
|
57
|
-
{ ...getEthAccount(), subAccounts: [] },
|
58
|
-
];
|
59
|
-
const allAccounts = [
|
60
|
-
getCosmosAccount(),
|
61
|
-
...ethAccounts,
|
62
|
-
getBtcAccount(),
|
63
|
-
getPolkadotAccount(),
|
64
|
-
];
|
65
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(aaveToken, allAccounts);
|
66
|
-
expect(results).toHaveLength(ethAccounts.length);
|
67
|
-
results.forEach((result, index) => {
|
68
|
-
expect(result.account).toEqual(ethAccounts[index]);
|
69
|
-
expect(result.subAccount.token).toEqual(aaveToken);
|
70
|
-
});
|
71
|
-
});
|
72
|
-
test("returns correct parent accounts including already existing subAccounts when a TokenCurrency is provided", () => {
|
73
|
-
const ethAccounts = [{ ...getEthAccount(), subAccounts: [aaveToken] }];
|
74
|
-
const allAccounts = [
|
75
|
-
getCosmosAccount(),
|
76
|
-
...ethAccounts,
|
77
|
-
getBtcAccount(),
|
78
|
-
getPolkadotAccount(),
|
79
|
-
];
|
80
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(aaveToken, allAccounts);
|
81
|
-
expect(results).toHaveLength(ethAccounts.length);
|
82
|
-
results.forEach((result, index) => {
|
83
|
-
expect(result.account).toEqual(ethAccounts[index]);
|
84
|
-
expect(result.subAccount.token).toEqual(aaveToken);
|
85
|
-
});
|
86
|
-
});
|
87
|
-
test("returns an empty array when a TokenCurrency is provided but the accounts list is empty", () => {
|
88
|
-
const allAccounts = [];
|
89
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(aaveToken, allAccounts);
|
90
|
-
expect(results).toHaveLength(0);
|
91
|
-
});
|
92
|
-
test("does not filter based on the accountId map", () => {
|
93
|
-
const aaveAccounts = [
|
94
|
-
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
95
|
-
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
96
|
-
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
97
|
-
{ ...getEthAccount(), subAccounts: [aaveToken] },
|
98
|
-
];
|
99
|
-
const results = (0, getAccountTuplesForCurrency_1.getAccountTuplesForCurrency)(aaveToken, aaveAccounts, new Map([[aaveAccounts[0].id, true]]));
|
100
|
-
expect(results).toHaveLength(4);
|
101
|
-
});
|
102
|
-
});
|
103
|
-
});
|
104
|
-
//# sourceMappingURL=getAccountTuplesForCurrency.test.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAccountTuplesForCurrency.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/getAccountTuplesForCurrency.test.ts"],"names":[],"mappings":"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"}
|
@@ -1,11 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|
@@ -1,25 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
/**
|
3
|
-
*
|
4
|
-
* @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.
|
5
|
-
* @template T - The type of the items in the input array.
|
6
|
-
* @template U - The type of the items in the output array.
|
7
|
-
* @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.
|
8
|
-
* @returns A function that takes an array of items of type T and returns an array of items of type T & U.
|
9
|
-
*
|
10
|
-
*/
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
12
|
-
exports.composeHooks = void 0;
|
13
|
-
function composeHooks(...hooks) {
|
14
|
-
return (items) => {
|
15
|
-
return hooks.reduce((acc, hook) => {
|
16
|
-
const result = hook?.(acc) ?? [];
|
17
|
-
return acc.map((item, i) => ({
|
18
|
-
...item,
|
19
|
-
...result[i],
|
20
|
-
}));
|
21
|
-
}, items);
|
22
|
-
};
|
23
|
-
}
|
24
|
-
exports.composeHooks = composeHooks;
|
25
|
-
//# sourceMappingURL=composeHooks.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"composeHooks.js","sourceRoot":"","sources":["../../src/utils/composeHooks.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;;AAEH,SAAgB,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;AAfD,oCAeC"}
|
@@ -1,8 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|
@@ -1,19 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
-
exports.getAccountTuplesForCurrency = void 0;
|
4
|
-
const helpers_1 = require("@ledgerhq/coin-framework/account/helpers");
|
5
|
-
function getAccountTuplesForCurrency(currency, allAccounts, accountIds) {
|
6
|
-
const isToken = currency.type === "TokenCurrency";
|
7
|
-
const targetCurrencyId = isToken ? currency.parentCurrency.id : currency.id;
|
8
|
-
return allAccounts
|
9
|
-
.filter(account => account.currency.id === targetCurrencyId &&
|
10
|
-
(isToken ? true : accountIds ? accountIds.has(account.id) : true))
|
11
|
-
.map(account => {
|
12
|
-
const subAccount = isToken
|
13
|
-
? account.subAccounts?.find((subAcc) => subAcc.type === "TokenAccount" && subAcc.token.id === currency.id) || (0, helpers_1.makeEmptyTokenAccount)(account, currency)
|
14
|
-
: null;
|
15
|
-
return { account, subAccount };
|
16
|
-
});
|
17
|
-
}
|
18
|
-
exports.getAccountTuplesForCurrency = getAccountTuplesForCurrency;
|
19
|
-
//# sourceMappingURL=getAccountTuplesForCurrency.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAccountTuplesForCurrency.js","sourceRoot":"","sources":["../../src/utils/getAccountTuplesForCurrency.ts"],"names":[],"mappings":";;;AAEA,sEAAiF;AAOjF,SAAgB,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,IAAA,+BAAqB,EAAC,OAAO,EAAE,QAAQ,CAAC;YAC/C,CAAC,CAAC,IAAI,CAAC;QAET,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,CAAC;IACjC,CAAC,CAAC,CAAC;AACP,CAAC;AAxBD,kEAwBC"}
|
@@ -1,18 +0,0 @@
|
|
1
|
-
import BigNumber from "bignumber.js";
|
2
|
-
export declare const MOCKED_ARB_ACCOUNT: {
|
3
|
-
type: string;
|
4
|
-
id: string;
|
5
|
-
balance: BigNumber;
|
6
|
-
creationDate: string;
|
7
|
-
currency: import("@ledgerhq/types-cryptoassets").CryptoCurrency;
|
8
|
-
derivationMode: string;
|
9
|
-
freshAddress: string;
|
10
|
-
};
|
11
|
-
export declare const ETH_ACCOUNT: import("@ledgerhq/types-live").Account;
|
12
|
-
export declare const ETH_ACCOUNT_2: import("@ledgerhq/types-live").Account;
|
13
|
-
export declare const BTC_ACCOUNT: import("@ledgerhq/types-live").Account;
|
14
|
-
export declare const ARB_ACCOUNT: import("@ledgerhq/types-live").Account;
|
15
|
-
export declare const ETH_ACCOUNT_WITH_USDC: import("@ledgerhq/types-live").Account;
|
16
|
-
export declare const BASE_ACCOUNT: import("@ledgerhq/types-live").Account;
|
17
|
-
export declare const SCROLL_ACCOUNT: import("@ledgerhq/types-live").Account;
|
18
|
-
//# sourceMappingURL=accounts.mock.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"accounts.mock.d.ts","sourceRoot":"","sources":["../../../src/modularDrawer/__mocks__/accounts.mock.ts"],"names":[],"mappings":"AACA,OAAO,SAAS,MAAM,cAAc,CAAC;AAOrC,eAAO,MAAM,kBAAkB;;;;;;;;CAQ9B,CAAC;AAEF,eAAO,MAAM,WAAW,wCAEtB,CAAC;AACH,eAAO,MAAM,aAAa,wCAExB,CAAC;AACH,eAAO,MAAM,WAAW,wCAEtB,CAAC;AACH,eAAO,MAAM,WAAW,wCAGtB,CAAC;AACH,eAAO,MAAM,qBAAqB,wCAGhC,CAAC;AACH,eAAO,MAAM,YAAY,wCAGvB,CAAC;AACH,eAAO,MAAM,cAAc,wCAGzB,CAAC"}
|
@@ -1,42 +0,0 @@
|
|
1
|
-
import { genAccount } from "@ledgerhq/coin-framework/lib/mocks/account";
|
2
|
-
import BigNumber from "bignumber.js";
|
3
|
-
import { mockBtcCryptoCurrency } from "./currencies.mock";
|
4
|
-
import { mockArbitrumCryptoCurrency } from "./currencies.mock";
|
5
|
-
import { mockEthCryptoCurrency } from "./currencies.mock";
|
6
|
-
import { mockBaseCryptoCurrency } from "./currencies.mock";
|
7
|
-
import { mockScrollCryptoCurrency } from "./currencies.mock";
|
8
|
-
export const MOCKED_ARB_ACCOUNT = {
|
9
|
-
type: "Account",
|
10
|
-
id: "arbitrum1",
|
11
|
-
balance: new BigNumber(34455),
|
12
|
-
creationDate: "2024-12-10T09:27:22.000Z",
|
13
|
-
currency: mockArbitrumCryptoCurrency,
|
14
|
-
derivationMode: "",
|
15
|
-
freshAddress: "s37rhmi7hsm3i73hsm7i3hm83m8h87hsm87h3s8h33",
|
16
|
-
};
|
17
|
-
export const ETH_ACCOUNT = genAccount("ethereum-1", {
|
18
|
-
currency: mockEthCryptoCurrency,
|
19
|
-
});
|
20
|
-
export const ETH_ACCOUNT_2 = genAccount("ethereum-2", {
|
21
|
-
currency: mockEthCryptoCurrency,
|
22
|
-
});
|
23
|
-
export const BTC_ACCOUNT = genAccount("bitcoin-1", {
|
24
|
-
currency: mockBtcCryptoCurrency,
|
25
|
-
});
|
26
|
-
export const ARB_ACCOUNT = genAccount("arbitrum-1", {
|
27
|
-
currency: mockArbitrumCryptoCurrency,
|
28
|
-
tokenIds: ["arbitrum/erc20/arbitrum"],
|
29
|
-
});
|
30
|
-
export const ETH_ACCOUNT_WITH_USDC = genAccount("ethereum-usdc", {
|
31
|
-
currency: mockEthCryptoCurrency,
|
32
|
-
tokenIds: ["ethereum/erc20/usdc"],
|
33
|
-
});
|
34
|
-
export const BASE_ACCOUNT = genAccount("base-1", {
|
35
|
-
currency: mockBaseCryptoCurrency,
|
36
|
-
operationsSize: 100,
|
37
|
-
});
|
38
|
-
export const SCROLL_ACCOUNT = genAccount("scroll-1", {
|
39
|
-
currency: mockScrollCryptoCurrency,
|
40
|
-
operationsSize: 100,
|
41
|
-
});
|
42
|
-
//# sourceMappingURL=accounts.mock.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"accounts.mock.js","sourceRoot":"","sources":["../../../src/modularDrawer/__mocks__/accounts.mock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,4CAA4C,CAAC;AACxE,OAAO,SAAS,MAAM,cAAc,CAAC;AACrC,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAC;AAC/D,OAAO,EAAE,qBAAqB,EAAE,MAAM,mBAAmB,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAE7D,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,IAAI,EAAE,SAAS;IACf,EAAE,EAAE,WAAW;IACf,OAAO,EAAE,IAAI,SAAS,CAAC,KAAK,CAAC;IAC7B,YAAY,EAAE,0BAA0B;IACxC,QAAQ,EAAE,0BAA0B;IACpC,cAAc,EAAE,EAAE;IAClB,YAAY,EAAE,4CAA4C;CAC3D,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAG,UAAU,CAAC,YAAY,EAAE;IAClD,QAAQ,EAAE,qBAAqB;CAChC,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,aAAa,GAAG,UAAU,CAAC,YAAY,EAAE;IACpD,QAAQ,EAAE,qBAAqB;CAChC,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,UAAU,CAAC,WAAW,EAAE;IACjD,QAAQ,EAAE,qBAAqB;CAChC,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,UAAU,CAAC,YAAY,EAAE;IAClD,QAAQ,EAAE,0BAA0B;IACpC,QAAQ,EAAE,CAAC,yBAAyB,CAAC;CACtC,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,qBAAqB,GAAG,UAAU,CAAC,eAAe,EAAE;IAC/D,QAAQ,EAAE,qBAAqB;IAC/B,QAAQ,EAAE,CAAC,qBAAqB,CAAC;CAClC,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,YAAY,GAAG,UAAU,CAAC,QAAQ,EAAE;IAC/C,QAAQ,EAAE,sBAAsB;IAChC,cAAc,EAAE,GAAG;CACpB,CAAC,CAAC;AACH,MAAM,CAAC,MAAM,cAAc,GAAG,UAAU,CAAC,UAAU,EAAE;IACnD,QAAQ,EAAE,wBAAwB;IAClC,cAAc,EAAE,GAAG;CACpB,CAAC,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"composeHooks.test.d.ts","sourceRoot":"","sources":["../../../src/utils/__tests__/composeHooks.test.ts"],"names":[],"mappings":""}
|
@@ -1,33 +0,0 @@
|
|
1
|
-
import { composeHooks } from "../composeHooks";
|
2
|
-
describe("composeHooks", () => {
|
3
|
-
it("should compose hooks and merge their results", () => {
|
4
|
-
const hook1 = (items) => items.map(item => ({ id: item.id, extra: item.id * 2 }));
|
5
|
-
const hook2 = (items) => items.map(item => ({ ...item, final: item.extra + 1 }));
|
6
|
-
const composed = composeHooks(hook1, hook2);
|
7
|
-
const input = [{ id: 1 }, { id: 2 }];
|
8
|
-
const processedInput = input.map(item => ({ id: item.id, extra: item.id * 2 }));
|
9
|
-
const result = composed(processedInput);
|
10
|
-
expect(result).toEqual([
|
11
|
-
{ id: 1, extra: 2, final: 3 },
|
12
|
-
{ id: 2, extra: 4, final: 5 },
|
13
|
-
]);
|
14
|
-
});
|
15
|
-
it("should handle hooks that return undefined", () => {
|
16
|
-
const hook1 = (items) => items.map(item => ({ id: item.id, extra: item.id * 2 }));
|
17
|
-
const hook2 = () => undefined;
|
18
|
-
const composed = composeHooks(hook1, hook2);
|
19
|
-
const input = [{ id: 1 }, { id: 2 }];
|
20
|
-
const result = composed(input);
|
21
|
-
expect(result).toEqual([
|
22
|
-
{ id: 1, extra: 2 },
|
23
|
-
{ id: 2, extra: 4 },
|
24
|
-
]);
|
25
|
-
});
|
26
|
-
it("should return the original items if no hooks are provided", () => {
|
27
|
-
const composed = composeHooks();
|
28
|
-
const input = [{ id: 1 }, { id: 2 }];
|
29
|
-
const result = composed(input);
|
30
|
-
expect(result).toEqual(input);
|
31
|
-
});
|
32
|
-
});
|
33
|
-
//# sourceMappingURL=composeHooks.test.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"composeHooks.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/composeHooks.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE/C,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACtD,MAAM,KAAK,GAAG,CAAC,KAA4B,EAAE,EAAE,CAC7C,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,CAAC,KAA2C,EAAE,EAAE,CAC5D,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAE1D,MAAM,QAAQ,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5C,MAAM,KAAK,GAA0B,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QAC5D,MAAM,cAAc,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAChF,MAAM,MAAM,GAAG,QAAQ,CAAC,cAAc,CAAC,CAAC;QAExC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;YAC7B,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;SAC9B,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,KAAK,GAAG,CAAC,KAA4B,EAAE,EAAE,CAC7C,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,KAAK,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3D,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,SAAS,CAAC;QAE9B,MAAM,QAAQ,GAAG,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAE5C,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;QAE/B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC;YACrB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;YACnB,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE;SACpB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2DAA2D,EAAE,GAAG,EAAE;QACnE,MAAM,QAAQ,GAAG,YAAY,EAAE,CAAC;QAEhC,MAAM,KAAK,GAAG,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,CAAC;QACrC,MAAM,MAAM,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;QAE/B,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAccountTuplesForCurrency.test.d.ts","sourceRoot":"","sources":["../../../src/utils/__tests__/getAccountTuplesForCurrency.test.ts"],"names":[],"mappings":""}
|
@@ -1,102 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"getAccountTuplesForCurrency.test.js","sourceRoot":"","sources":["../../../src/utils/__tests__/getAccountTuplesForCurrency.test.ts"],"names":[],"mappings":"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"}
|
@@ -1,11 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|
@@ -1,21 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|
@@ -1,8 +0,0 @@
|
|
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
|
@@ -1 +0,0 @@
|
|
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"}
|