@ledgerhq/live-config 1.0.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (136) hide show
  1. package/.eslintignore +2 -0
  2. package/.eslintrc.js +20 -0
  3. package/.turbo/turbo-build.log +4 -0
  4. package/.unimportedrc.json +5 -0
  5. package/CHANGELOG.md +14 -0
  6. package/LICENSE.txt +21 -0
  7. package/jest.config.js +10 -0
  8. package/lib/featureFlags/FeatureFlagsContext.d.ts +41 -0
  9. package/lib/featureFlags/FeatureFlagsContext.d.ts.map +1 -0
  10. package/lib/featureFlags/FeatureFlagsContext.js +26 -0
  11. package/lib/featureFlags/FeatureFlagsContext.js.map +1 -0
  12. package/lib/featureFlags/FeatureFlagsContext.test.d.ts +2 -0
  13. package/lib/featureFlags/FeatureFlagsContext.test.d.ts.map +1 -0
  14. package/lib/featureFlags/FeatureFlagsContext.test.js +15 -0
  15. package/lib/featureFlags/FeatureFlagsContext.test.js.map +1 -0
  16. package/lib/featureFlags/FeatureToggle.d.ts +10 -0
  17. package/lib/featureFlags/FeatureToggle.d.ts.map +1 -0
  18. package/lib/featureFlags/FeatureToggle.js +16 -0
  19. package/lib/featureFlags/FeatureToggle.js.map +1 -0
  20. package/lib/featureFlags/LiveConfig.d.ts +25 -0
  21. package/lib/featureFlags/LiveConfig.d.ts.map +1 -0
  22. package/lib/featureFlags/LiveConfig.js +30 -0
  23. package/lib/featureFlags/LiveConfig.js.map +1 -0
  24. package/lib/featureFlags/defaultFeatures.d.ts +61 -0
  25. package/lib/featureFlags/defaultFeatures.d.ts.map +1 -0
  26. package/lib/featureFlags/defaultFeatures.js +319 -0
  27. package/lib/featureFlags/defaultFeatures.js.map +1 -0
  28. package/lib/featureFlags/firebaseFeatureFlags.d.ts +109 -0
  29. package/lib/featureFlags/firebaseFeatureFlags.d.ts.map +1 -0
  30. package/lib/featureFlags/firebaseFeatureFlags.js +90 -0
  31. package/lib/featureFlags/firebaseFeatureFlags.js.map +1 -0
  32. package/lib/featureFlags/groupedFeatures.d.ts +6 -0
  33. package/lib/featureFlags/groupedFeatures.d.ts.map +1 -0
  34. package/lib/featureFlags/groupedFeatures.js +22 -0
  35. package/lib/featureFlags/groupedFeatures.js.map +1 -0
  36. package/lib/featureFlags/helper.d.ts +2 -0
  37. package/lib/featureFlags/helper.d.ts.map +1 -0
  38. package/lib/featureFlags/helper.js +10 -0
  39. package/lib/featureFlags/helper.js.map +1 -0
  40. package/lib/featureFlags/index.d.ts +11 -0
  41. package/lib/featureFlags/index.d.ts.map +1 -0
  42. package/lib/featureFlags/index.js +32 -0
  43. package/lib/featureFlags/index.js.map +1 -0
  44. package/lib/featureFlags/mock.d.ts +11 -0
  45. package/lib/featureFlags/mock.d.ts.map +1 -0
  46. package/lib/featureFlags/mock.js +25 -0
  47. package/lib/featureFlags/mock.js.map +1 -0
  48. package/lib/featureFlags/useFeature.d.ts +14 -0
  49. package/lib/featureFlags/useFeature.d.ts.map +1 -0
  50. package/lib/featureFlags/useFeature.js +21 -0
  51. package/lib/featureFlags/useFeature.js.map +1 -0
  52. package/lib/featureFlags/useFeature.test.d.ts +2 -0
  53. package/lib/featureFlags/useFeature.test.d.ts.map +1 -0
  54. package/lib/featureFlags/useFeature.test.js +27 -0
  55. package/lib/featureFlags/useFeature.test.js.map +1 -0
  56. package/lib/featureFlags/useHasOverriddenFeatureFlags.d.ts +6 -0
  57. package/lib/featureFlags/useHasOverriddenFeatureFlags.d.ts.map +1 -0
  58. package/lib/featureFlags/useHasOverriddenFeatureFlags.js +24 -0
  59. package/lib/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -0
  60. package/lib/index.d.ts +2 -0
  61. package/lib/index.d.ts.map +1 -0
  62. package/lib/index.js +18 -0
  63. package/lib/index.js.map +1 -0
  64. package/lib-es/featureFlags/FeatureFlagsContext.d.ts +41 -0
  65. package/lib-es/featureFlags/FeatureFlagsContext.d.ts.map +1 -0
  66. package/lib-es/featureFlags/FeatureFlagsContext.js +22 -0
  67. package/lib-es/featureFlags/FeatureFlagsContext.js.map +1 -0
  68. package/lib-es/featureFlags/FeatureFlagsContext.test.d.ts +2 -0
  69. package/lib-es/featureFlags/FeatureFlagsContext.test.d.ts.map +1 -0
  70. package/lib-es/featureFlags/FeatureFlagsContext.test.js +13 -0
  71. package/lib-es/featureFlags/FeatureFlagsContext.test.js.map +1 -0
  72. package/lib-es/featureFlags/FeatureToggle.d.ts +10 -0
  73. package/lib-es/featureFlags/FeatureToggle.d.ts.map +1 -0
  74. package/lib-es/featureFlags/FeatureToggle.js +11 -0
  75. package/lib-es/featureFlags/FeatureToggle.js.map +1 -0
  76. package/lib-es/featureFlags/LiveConfig.d.ts +25 -0
  77. package/lib-es/featureFlags/LiveConfig.d.ts.map +1 -0
  78. package/lib-es/featureFlags/LiveConfig.js +26 -0
  79. package/lib-es/featureFlags/LiveConfig.js.map +1 -0
  80. package/lib-es/featureFlags/defaultFeatures.d.ts +61 -0
  81. package/lib-es/featureFlags/defaultFeatures.d.ts.map +1 -0
  82. package/lib-es/featureFlags/defaultFeatures.js +314 -0
  83. package/lib-es/featureFlags/defaultFeatures.js.map +1 -0
  84. package/lib-es/featureFlags/firebaseFeatureFlags.d.ts +109 -0
  85. package/lib-es/featureFlags/firebaseFeatureFlags.d.ts.map +1 -0
  86. package/lib-es/featureFlags/firebaseFeatureFlags.js +80 -0
  87. package/lib-es/featureFlags/firebaseFeatureFlags.js.map +1 -0
  88. package/lib-es/featureFlags/groupedFeatures.d.ts +6 -0
  89. package/lib-es/featureFlags/groupedFeatures.d.ts.map +1 -0
  90. package/lib-es/featureFlags/groupedFeatures.js +19 -0
  91. package/lib-es/featureFlags/groupedFeatures.js.map +1 -0
  92. package/lib-es/featureFlags/helper.d.ts +2 -0
  93. package/lib-es/featureFlags/helper.d.ts.map +1 -0
  94. package/lib-es/featureFlags/helper.js +6 -0
  95. package/lib-es/featureFlags/helper.js.map +1 -0
  96. package/lib-es/featureFlags/index.d.ts +11 -0
  97. package/lib-es/featureFlags/index.d.ts.map +1 -0
  98. package/lib-es/featureFlags/index.js +11 -0
  99. package/lib-es/featureFlags/index.js.map +1 -0
  100. package/lib-es/featureFlags/mock.d.ts +11 -0
  101. package/lib-es/featureFlags/mock.d.ts.map +1 -0
  102. package/lib-es/featureFlags/mock.js +17 -0
  103. package/lib-es/featureFlags/mock.js.map +1 -0
  104. package/lib-es/featureFlags/useFeature.d.ts +14 -0
  105. package/lib-es/featureFlags/useFeature.d.ts.map +1 -0
  106. package/lib-es/featureFlags/useFeature.js +19 -0
  107. package/lib-es/featureFlags/useFeature.js.map +1 -0
  108. package/lib-es/featureFlags/useFeature.test.d.ts +2 -0
  109. package/lib-es/featureFlags/useFeature.test.d.ts.map +1 -0
  110. package/lib-es/featureFlags/useFeature.test.js +22 -0
  111. package/lib-es/featureFlags/useFeature.test.js.map +1 -0
  112. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.d.ts +6 -0
  113. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.d.ts.map +1 -0
  114. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js +20 -0
  115. package/lib-es/featureFlags/useHasOverriddenFeatureFlags.js.map +1 -0
  116. package/lib-es/index.d.ts +2 -0
  117. package/lib-es/index.d.ts.map +1 -0
  118. package/lib-es/index.js +2 -0
  119. package/lib-es/index.js.map +1 -0
  120. package/package.json +82 -0
  121. package/src/featureFlags/FeatureFlagsContext.test.tsx +13 -0
  122. package/src/featureFlags/FeatureFlagsContext.tsx +62 -0
  123. package/src/featureFlags/FeatureToggle.tsx +22 -0
  124. package/src/featureFlags/LiveConfig.ts +45 -0
  125. package/src/featureFlags/defaultFeatures.ts +428 -0
  126. package/src/featureFlags/firebaseFeatureFlags.ts +115 -0
  127. package/src/featureFlags/groupedFeatures.ts +25 -0
  128. package/src/featureFlags/helper.tsx +9 -0
  129. package/src/featureFlags/index.ts +12 -0
  130. package/src/featureFlags/mock.tsx +28 -0
  131. package/src/featureFlags/useFeature.test.tsx +23 -0
  132. package/src/featureFlags/useFeature.ts +21 -0
  133. package/src/featureFlags/useHasOverriddenFeatureFlags.ts +24 -0
  134. package/src/index.ts +1 -0
  135. package/tsconfig.json +15 -0
  136. package/types.ts +5 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/featureFlags/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,8DAAsC;AAG7B,qBAHF,oBAAU,CAGE;AAFnB,oEAA4C;AAEvB,wBAFd,uBAAa,CAEc;AAElC,oDAAkC;AAClC,oDAAkC;AAClC,wDAAsC;AACtC,iEAA+C;AAC/C,yDAAuC;AACvC,+CAA6B;AAC7B,2CAAyB"}
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import { Feature, FeatureId } from "@ledgerhq/types-live";
3
+ import { FeatureFlagsContextValue } from "./FeatureFlagsContext";
4
+ export declare function makeMockedContextValue(mockedFeatures: Partial<Record<FeatureId, Feature>>): FeatureFlagsContextValue;
5
+ export declare function makeMockedFeatureFlagsProviderWrapper(mockedContextValue: FeatureFlagsContextValue): React.FC<{
6
+ children: React.ReactNode | null;
7
+ }>;
8
+ export declare const basicMockedFeatureFlagsProviderWrapper: React.FC<{
9
+ children: React.ReactNode | null;
10
+ }>;
11
+ //# sourceMappingURL=mock.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mock.d.ts","sourceRoot":"","sources":["../../src/featureFlags/mock.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAwB,MAAM,uBAAuB,CAAC;AAEvF,wBAAgB,sBAAsB,CACpC,cAAc,EAAE,OAAO,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC,GAClD,wBAAwB,CAQ1B;AAED,wBAAgB,qCAAqC,CACnD,kBAAkB,EAAE,wBAAwB;cAEa,MAAM,SAAS,GAAG,IAAI;GAIhF;AAED,eAAO,MAAM,sCAAsC;cANQ,MAAM,SAAS,GAAG,IAAI;EAQhF,CAAC"}
@@ -0,0 +1,25 @@
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.basicMockedFeatureFlagsProviderWrapper = exports.makeMockedFeatureFlagsProviderWrapper = exports.makeMockedContextValue = void 0;
7
+ const react_1 = __importDefault(require("react"));
8
+ const FeatureFlagsContext_1 = require("./FeatureFlagsContext");
9
+ function makeMockedContextValue(mockedFeatures) {
10
+ return {
11
+ isFeature: () => true,
12
+ getFeature: (featureId) => mockedFeatures[featureId] || null,
13
+ overrideFeature: () => { },
14
+ resetFeature: () => { },
15
+ resetFeatures: () => { },
16
+ };
17
+ }
18
+ exports.makeMockedContextValue = makeMockedContextValue;
19
+ function makeMockedFeatureFlagsProviderWrapper(mockedContextValue) {
20
+ const MockedFeatureProviderWrapper = ({ children, }) => react_1.default.createElement(FeatureFlagsContext_1.FeatureFlagsProvider, { value: mockedContextValue }, children);
21
+ return MockedFeatureProviderWrapper;
22
+ }
23
+ exports.makeMockedFeatureFlagsProviderWrapper = makeMockedFeatureFlagsProviderWrapper;
24
+ exports.basicMockedFeatureFlagsProviderWrapper = makeMockedFeatureFlagsProviderWrapper(makeMockedContextValue({}));
25
+ //# sourceMappingURL=mock.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mock.js","sourceRoot":"","sources":["../../src/featureFlags/mock.tsx"],"names":[],"mappings":";;;;;;AAAA,kDAA0B;AAE1B,+DAAuF;AAEvF,SAAgB,sBAAsB,CACpC,cAAmD;IAEnD,OAAO;QACL,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI;QACrB,UAAU,EAAE,CAAC,SAAoB,EAAE,EAAE,CAAC,cAAc,CAAC,SAAS,CAAC,IAAI,IAAI;QACvE,eAAe,EAAE,GAAG,EAAE,GAAE,CAAC;QACzB,YAAY,EAAE,GAAG,EAAE,GAAE,CAAC;QACtB,aAAa,EAAE,GAAG,EAAE,GAAE,CAAC;KACxB,CAAC;AACJ,CAAC;AAVD,wDAUC;AAED,SAAgB,qCAAqC,CACnD,kBAA4C;IAE5C,MAAM,4BAA4B,GAAmD,CAAC,EACpF,QAAQ,GACT,EAAE,EAAE,CAAC,8BAAC,0CAAoB,IAAC,KAAK,EAAE,kBAAkB,IAAG,QAAQ,CAAwB,CAAC;IACzF,OAAO,4BAA4B,CAAC;AACtC,CAAC;AAPD,sFAOC;AAEY,QAAA,sCAAsC,GAAG,qCAAqC,CACzF,sBAAsB,CAAC,EAAE,CAAC,CAC3B,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { Feature, FeatureParam } from "@ledgerhq/types-live";
2
+ /**
3
+ * Hook that returns the value of a feature flag based on its `featureId`.
4
+ *
5
+ * @dev do not modify this function to make it return a default arbitrary value
6
+ * instead of null, this should not be handled at this level.
7
+ *
8
+ * @param featureId
9
+ * @returns a feature flag value or null if the feature flag is not found
10
+ * (neither in the remote configuration, in the cache or in the local defaults).
11
+ */
12
+ declare const useFeature: <T extends keyof import("@ledgerhq/types-live").CurrencyFeatures | "learn" | "brazePushNotifications" | "brazeLearn" | "llmNewDeviceSelection" | "llmNewFirmwareUpdateUx" | "ratingsPrompt" | "npsRatingsPrompt" | "counterValue" | "deviceInitialApps" | "buyDeviceFromLive" | "ptxEarn" | "depositNetworkBannerMobile" | "depositWithdrawBannerMobile" | "mockFeature" | "multibuyNavigation" | "syncOnboarding" | "walletConnectEntryPoint" | "customImage" | "referralProgramDiscoverCard" | "referralProgramDesktopBanner" | "referralProgramDesktopSidebar" | "referralProgramMobile" | "disableNftSend" | "disableNftLedgerMarket" | "disableNftRaribleOpensea" | "walletNftGallery" | "receiveStakingFlowConfigDesktop" | "ethStakingProviders" | "storyly" | "staxWelcomeScreen" | "postOnboardingClaimNft" | "postOnboardingAssetsTransfer" | "firebaseEnvironmentReadOnly" | "protectServicesMobile" | "protectServicesDesktop" | "ptxServiceCtaExchangeDrawer" | "ptxServiceCtaScreens" | "swapWalletApiPartnerList" | "stakePrograms" | "portfolioExchangeBanner" | "objkt" | "editEvmTx" | "stakeAccountBanner" | "newsfeedPage" | "domainInputResolution" | "discover" | "protectServicesDiscoverDesktop" | "transactionsAlerts" | "listAppsV2minor1" | "llmWalletQuickActions" | "cexDepositEntryPointsDesktop" | "cexDepositEntryPointsMobile" | "fetchAdditionalCoins" | "ptxSwapLiveApp" | "ptxSwapMoonpayProvider">(featureId: T) => Feature<FeatureParam<T>> | null;
13
+ export default useFeature;
14
+ //# sourceMappingURL=useFeature.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeature.d.ts","sourceRoot":"","sources":["../../src/featureFlags/useFeature.ts"],"names":[],"mappings":"AAEA,OAAO,EAAa,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAExE;;;;;;;;;GASG;AACH,QAAA,MAAM,UAAU,05CAIf,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const react_1 = require("react");
4
+ const FeatureFlagsContext_1 = require("./FeatureFlagsContext");
5
+ /**
6
+ * Hook that returns the value of a feature flag based on its `featureId`.
7
+ *
8
+ * @dev do not modify this function to make it return a default arbitrary value
9
+ * instead of null, this should not be handled at this level.
10
+ *
11
+ * @param featureId
12
+ * @returns a feature flag value or null if the feature flag is not found
13
+ * (neither in the remote configuration, in the cache or in the local defaults).
14
+ */
15
+ const useFeature = (featureId) => {
16
+ const featureFlags = (0, FeatureFlagsContext_1.useFeatureFlags)();
17
+ const value = (0, react_1.useMemo)(() => featureFlags.getFeature(featureId), [featureFlags, featureId]);
18
+ return value;
19
+ };
20
+ exports.default = useFeature;
21
+ //# sourceMappingURL=useFeature.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeature.js","sourceRoot":"","sources":["../../src/featureFlags/useFeature.ts"],"names":[],"mappings":";;AAAA,iCAAgC;AAChC,+DAAwD;AAGxD;;;;;;;;;GASG;AACH,MAAM,UAAU,GAAG,CAAsB,SAAY,EAAmC,EAAE;IACxF,MAAM,YAAY,GAAG,IAAA,qCAAe,GAAE,CAAC;IACvC,MAAM,KAAK,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,YAAY,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,YAAY,EAAE,SAAS,CAAC,CAAC,CAAC;IAC3F,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,kBAAe,UAAU,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=useFeature.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeature.test.d.ts","sourceRoot":"","sources":["../../src/featureFlags/useFeature.test.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,27 @@
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
+ const react_hooks_1 = require("@testing-library/react-hooks");
7
+ const useFeature_1 = __importDefault(require("./useFeature"));
8
+ const mock_1 = require("./mock");
9
+ describe("useFeature hook", () => {
10
+ it("should return null if a flag is not defined remotely", () => {
11
+ const mockedFeatures = {};
12
+ const { result } = (0, react_hooks_1.renderHook)(() => (0, useFeature_1.default)("mockFeature"), {
13
+ wrapper: (0, mock_1.makeMockedFeatureFlagsProviderWrapper)((0, mock_1.makeMockedContextValue)(mockedFeatures)),
14
+ });
15
+ expect(result.current).toBeNull();
16
+ });
17
+ it("should return the feature flag value if the feature flag is defined", () => {
18
+ const mockedFeatures = {
19
+ mockFeature: { enabled: true, params: { blabla: "hello" } },
20
+ };
21
+ const { result } = (0, react_hooks_1.renderHook)(() => (0, useFeature_1.default)("mockFeature"), {
22
+ wrapper: (0, mock_1.makeMockedFeatureFlagsProviderWrapper)((0, mock_1.makeMockedContextValue)(mockedFeatures)),
23
+ });
24
+ expect(result.current).toBe(mockedFeatures.mockFeature);
25
+ });
26
+ });
27
+ //# sourceMappingURL=useFeature.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFeature.test.js","sourceRoot":"","sources":["../../src/featureFlags/useFeature.test.tsx"],"names":[],"mappings":";;;;;AAAA,8DAA0D;AAC1D,8DAAsC;AACtC,iCAAuF;AAEvF,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;QAC9D,MAAM,cAAc,GAAG,EAAE,CAAC;QAC1B,MAAM,EAAE,MAAM,EAAE,GAAG,IAAA,wBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,oBAAU,EAAC,aAAa,CAAC,EAAE;YAC7D,OAAO,EAAE,IAAA,4CAAqC,EAAC,IAAA,6BAAsB,EAAC,cAAc,CAAC,CAAC;SACvF,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qEAAqE,EAAE,GAAG,EAAE;QAC7E,MAAM,cAAc,GAAG;YACrB,WAAW,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE;SAC5D,CAAC;QACF,MAAM,EAAE,MAAM,EAAE,GAAG,IAAA,wBAAU,EAAC,GAAG,EAAE,CAAC,IAAA,oBAAU,EAAC,aAAa,CAAC,EAAE;YAC7D,OAAO,EAAE,IAAA,4CAAqC,EAAC,IAAA,6BAAsB,EAAC,cAAc,CAAC,CAAC;SACvF,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ *
3
+ * @returns whether one or more flags are locally overridden
4
+ */
5
+ export declare function useHasLocallyOverriddenFeatureFlags(): boolean;
6
+ //# sourceMappingURL=useHasOverriddenFeatureFlags.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHasOverriddenFeatureFlags.d.ts","sourceRoot":"","sources":["../../src/featureFlags/useHasOverriddenFeatureFlags.ts"],"names":[],"mappings":"AAKA;;;GAGG;AACH,wBAAgB,mCAAmC,IAAI,OAAO,CAc7D"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.useHasLocallyOverriddenFeatureFlags = void 0;
4
+ const react_1 = require("react");
5
+ const FeatureFlagsContext_1 = require("./FeatureFlagsContext");
6
+ const defaultFeatures_1 = require("./defaultFeatures");
7
+ /**
8
+ *
9
+ * @returns whether one or more flags are locally overridden
10
+ */
11
+ function useHasLocallyOverriddenFeatureFlags() {
12
+ const { getFeature } = (0, FeatureFlagsContext_1.useFeatureFlags)();
13
+ return (0, react_1.useMemo)(() => Object.entries(defaultFeatures_1.DEFAULT_FEATURES).some(([featureId]) => {
14
+ try {
15
+ const val = getFeature(featureId);
16
+ return (val === null || val === void 0 ? void 0 : val.overridesRemote) || (val === null || val === void 0 ? void 0 : val.overriddenByEnv);
17
+ }
18
+ catch (e) {
19
+ return false;
20
+ }
21
+ }), [getFeature]);
22
+ }
23
+ exports.useHasLocallyOverriddenFeatureFlags = useHasLocallyOverriddenFeatureFlags;
24
+ //# sourceMappingURL=useHasOverriddenFeatureFlags.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHasOverriddenFeatureFlags.js","sourceRoot":"","sources":["../../src/featureFlags/useHasOverriddenFeatureFlags.ts"],"names":[],"mappings":";;;AAAA,iCAAgC;AAEhC,+DAAwD;AACxD,uDAAqD;AAErD;;;GAGG;AACH,SAAgB,mCAAmC;IACjD,MAAM,EAAE,UAAU,EAAE,GAAG,IAAA,qCAAe,GAAE,CAAC;IACzC,OAAO,IAAA,eAAO,EACZ,GAAG,EAAE,CACH,MAAM,CAAC,OAAO,CAAC,kCAAgB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,EAAE,EAAE;QACpD,IAAI;YACF,MAAM,GAAG,GAAG,UAAU,CAAC,SAAsB,CAAC,CAAC;YAC/C,OAAO,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,eAAe,MAAI,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,eAAe,CAAA,CAAC;SACrD;QAAC,OAAO,CAAC,EAAE;YACV,OAAO,KAAK,CAAC;SACd;IACH,CAAC,CAAC,EACJ,CAAC,UAAU,CAAC,CACb,CAAC;AACJ,CAAC;AAdD,kFAcC"}
package/lib/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from "./featureFlags";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}
package/lib/index.js ADDED
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./featureFlags"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,iDAA+B"}
@@ -0,0 +1,41 @@
1
+ /// <reference types="react" />
2
+ import type { FeatureId, Feature } from "@ledgerhq/types-live";
3
+ export type FeatureFlagsContextValue = {
4
+ /**
5
+ *
6
+ * @param featureId featureId identifying a potential feature flag
7
+ * @returns true if and only if the parameter matches a feature that is configured.
8
+ */
9
+ isFeature: (featureId: string) => boolean;
10
+ /**
11
+ *
12
+ * @param featureId featureId identifying a feature flag
13
+ * @returns the value of the feature flag if it is defined (remotely or through a default value), otherwise returns null
14
+ */
15
+ getFeature: (featureId: FeatureId) => Feature | null;
16
+ /**
17
+ * function that allows to override the value of a feature flag
18
+ *
19
+ * @param featureId featureId identifying a feature flag
20
+ * @param newValue new value of the feature flag
21
+ * @returns undefined
22
+ */
23
+ overrideFeature: (featureId: FeatureId, newValue: Feature) => void;
24
+ /**
25
+ * resets the overridden feature flag value for a given featureId
26
+ * @param featureId featureId identifying a feature flag
27
+ * @returns undefined
28
+ */
29
+ resetFeature: (featureId: FeatureId) => void;
30
+ /**
31
+ * resets all the overridden feature flags
32
+ * @returns undefined
33
+ */
34
+ resetFeatures: () => void;
35
+ };
36
+ export declare const FeatureFlagsProvider: import("react").Provider<FeatureFlagsContextValue>;
37
+ /**
38
+ * Hook to consume a FeatureFlagsContext
39
+ */
40
+ export declare function useFeatureFlags(): FeatureFlagsContextValue;
41
+ //# sourceMappingURL=FeatureFlagsContext.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureFlagsContext.d.ts","sourceRoot":"","sources":["../../src/featureFlags/FeatureFlagsContext.tsx"],"names":[],"mappings":";AACA,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAC;AAE/D,MAAM,MAAM,wBAAwB,GAAG;IACrC;;;;OAIG;IACH,SAAS,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC;IAE1C;;;;OAIG;IACH,UAAU,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,OAAO,GAAG,IAAI,CAAC;IAErD;;;;;;OAMG;IACH,eAAe,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,OAAO,KAAK,IAAI,CAAC;IAEnE;;;;OAIG;IACH,YAAY,EAAE,CAAC,SAAS,EAAE,SAAS,KAAK,IAAI,CAAC;IAC7C;;;OAGG;IACH,aAAa,EAAE,MAAM,IAAI,CAAC;CAC3B,CAAC;AAgBF,eAAO,MAAM,oBAAoB,oDAA+B,CAAC;AAEjE;;GAEG;AACH,wBAAgB,eAAe,IAAI,wBAAwB,CAE1D"}
@@ -0,0 +1,22 @@
1
+ import { createContext, useContext } from "react";
2
+ /**
3
+ * Context used for injecting the feature flagging implementation logic.
4
+ *
5
+ * @dev do not export this, it should be accessed exclusively through
6
+ * useFeatureFlags and FeatureFlagsProvider
7
+ */
8
+ const FeatureFlagsContext = createContext({
9
+ isFeature: _ => false,
10
+ getFeature: _ => null,
11
+ overrideFeature: _ => { },
12
+ resetFeature: _ => { },
13
+ resetFeatures: () => { },
14
+ });
15
+ export const FeatureFlagsProvider = FeatureFlagsContext.Provider;
16
+ /**
17
+ * Hook to consume a FeatureFlagsContext
18
+ */
19
+ export function useFeatureFlags() {
20
+ return useContext(FeatureFlagsContext);
21
+ }
22
+ //# sourceMappingURL=FeatureFlagsContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureFlagsContext.js","sourceRoot":"","sources":["../../src/featureFlags/FeatureFlagsContext.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAwClD;;;;;GAKG;AACH,MAAM,mBAAmB,GAAG,aAAa,CAA2B;IAClE,SAAS,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK;IACrB,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI;IACrB,eAAe,EAAE,CAAC,CAAC,EAAE,GAAE,CAAC;IACxB,YAAY,EAAE,CAAC,CAAC,EAAE,GAAE,CAAC;IACrB,aAAa,EAAE,GAAG,EAAE,GAAE,CAAC;CACxB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,mBAAmB,CAAC,QAAQ,CAAC;AAEjE;;GAEG;AACH,MAAM,UAAU,eAAe;IAC7B,OAAO,UAAU,CAAC,mBAAmB,CAAC,CAAC;AACzC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=FeatureFlagsContext.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureFlagsContext.test.d.ts","sourceRoot":"","sources":["../../src/featureFlags/FeatureFlagsContext.test.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,13 @@
1
+ import { renderHook } from "@testing-library/react-hooks";
2
+ import { makeMockedContextValue, makeMockedFeatureFlagsProviderWrapper } from "./mock";
3
+ import { useFeatureFlags } from "./FeatureFlagsContext";
4
+ describe("useFeatureFlags hook", () => {
5
+ it("should return the context value if it is used inside a context provider", () => {
6
+ const mockedContextValue = makeMockedContextValue({});
7
+ const { result } = renderHook(() => useFeatureFlags(), {
8
+ wrapper: makeMockedFeatureFlagsProviderWrapper(mockedContextValue),
9
+ });
10
+ expect(result === null || result === void 0 ? void 0 : result.current).toStrictEqual(mockedContextValue);
11
+ });
12
+ });
13
+ //# sourceMappingURL=FeatureFlagsContext.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureFlagsContext.test.js","sourceRoot":"","sources":["../../src/featureFlags/FeatureFlagsContext.test.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,8BAA8B,CAAC;AAC1D,OAAO,EAAE,sBAAsB,EAAE,qCAAqC,EAAE,MAAM,QAAQ,CAAC;AACvF,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD,QAAQ,CAAC,sBAAsB,EAAE,GAAG,EAAE;IACpC,EAAE,CAAC,yEAAyE,EAAE,GAAG,EAAE;QACjF,MAAM,kBAAkB,GAAG,sBAAsB,CAAC,EAAE,CAAC,CAAC;QACtD,MAAM,EAAE,MAAM,EAAE,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,eAAe,EAAE,EAAE;YACrD,OAAO,EAAE,qCAAqC,CAAC,kBAAkB,CAAC;SACnE,CAAC,CAAC;QACH,MAAM,CAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,CAAC,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { ReactNode } from "react";
2
+ import type { FeatureId } from "@ledgerhq/types-live";
3
+ type Props = {
4
+ featureId: FeatureId;
5
+ fallback?: ReactNode;
6
+ children?: ReactNode;
7
+ };
8
+ declare const FeatureToggle: ({ featureId, fallback, children }: Props) => JSX.Element;
9
+ export default FeatureToggle;
10
+ //# sourceMappingURL=FeatureToggle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureToggle.d.ts","sourceRoot":"","sources":["../../src/featureFlags/FeatureToggle.tsx"],"names":[],"mappings":"AAAA,OAAc,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAGzC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEtD,KAAK,KAAK,GAAG;IACX,SAAS,EAAE,SAAS,CAAC;IACrB,QAAQ,CAAC,EAAE,SAAS,CAAC;IACrB,QAAQ,CAAC,EAAE,SAAS,CAAC;CACtB,CAAC;AAEF,QAAA,MAAM,aAAa,sCAAuC,KAAK,KAAG,WAQjE,CAAC;AAEF,eAAe,aAAa,CAAC"}
@@ -0,0 +1,11 @@
1
+ import React from "react";
2
+ import useFeature from "./useFeature";
3
+ const FeatureToggle = ({ featureId, fallback, children }) => {
4
+ const feature = useFeature(featureId);
5
+ if (!feature || !feature.enabled) {
6
+ return React.createElement(React.Fragment, null, fallback || null);
7
+ }
8
+ return React.createElement(React.Fragment, null, children || null);
9
+ };
10
+ export default FeatureToggle;
11
+ //# sourceMappingURL=FeatureToggle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FeatureToggle.js","sourceRoot":"","sources":["../../src/featureFlags/FeatureToggle.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AAEzC,OAAO,UAAU,MAAM,cAAc,CAAC;AAStC,MAAM,aAAa,GAAG,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAS,EAAe,EAAE;IAC9E,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC;IAEtC,IAAI,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;QAChC,OAAO,0CAAG,QAAQ,IAAI,IAAI,CAAI,CAAC;KAChC;IAED,OAAO,0CAAG,QAAQ,IAAI,IAAI,CAAI,CAAC;AACjC,CAAC,CAAC;AAEF,eAAe,aAAa,CAAC"}
@@ -0,0 +1,25 @@
1
+ export declare interface Value {
2
+ asBoolean(): boolean;
3
+ asNumber(): number;
4
+ asString(): string;
5
+ }
6
+ export declare class LiveConfig {
7
+ appVersion?: string;
8
+ platform?: string;
9
+ environment?: string;
10
+ providerGetvalueMethod?: {
11
+ [provider: string]: (key: string) => Value;
12
+ };
13
+ private static instance;
14
+ private constructor();
15
+ static init(config: {
16
+ appVersion: string;
17
+ platform: string;
18
+ environment: string;
19
+ }): void;
20
+ static setProviderGetValueMethod(provider2Method: {
21
+ [provider: string]: (key: string) => Value;
22
+ }): void;
23
+ static getInstance(): LiveConfig;
24
+ }
25
+ //# sourceMappingURL=LiveConfig.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveConfig.d.ts","sourceRoot":"","sources":["../../src/featureFlags/LiveConfig.ts"],"names":[],"mappings":"AACA,MAAM,CAAC,OAAO,WAAW,KAAK;IAC5B,SAAS,IAAI,OAAO,CAAC;IACrB,QAAQ,IAAI,MAAM,CAAC;IACnB,QAAQ,IAAI,MAAM,CAAC;CACpB;AAED,qBAAa,UAAU;IACd,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,sBAAsB,CAAC,EAAE;QAAE,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,GAAG,EAAE,MAAM,KAAK,KAAK,CAAA;KAAE,CAAC;IAE/E,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAa;IACpC,OAAO;WACO,IAAI,CAAC,MAAM,EAAE;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;WAQ1E,yBAAyB,CAAC,eAAe,EAAE;QACvD,CAAC,QAAQ,EAAE,MAAM,GAAG,CAAC,GAAG,EAAE,MAAM,KAAK,KAAK,CAAC;KAC5C;WAaa,WAAW,IAAI,UAAU;CAMxC"}
@@ -0,0 +1,26 @@
1
+ export class LiveConfig {
2
+ constructor() { }
3
+ static init(config) {
4
+ if (!LiveConfig.instance) {
5
+ LiveConfig.instance = new LiveConfig();
6
+ LiveConfig.instance.appVersion = config.appVersion;
7
+ LiveConfig.instance.platform = config.platform;
8
+ }
9
+ }
10
+ static setProviderGetValueMethod(provider2Method) {
11
+ if (!LiveConfig.instance) {
12
+ throw new Error("LiveConfig instance is not initialized. Call init() first.");
13
+ }
14
+ if (!LiveConfig.instance.providerGetvalueMethod) {
15
+ LiveConfig.instance.providerGetvalueMethod = {};
16
+ }
17
+ LiveConfig.instance.providerGetvalueMethod = Object.assign(Object.assign({}, LiveConfig.instance.providerGetvalueMethod), provider2Method);
18
+ }
19
+ static getInstance() {
20
+ if (!LiveConfig.instance) {
21
+ throw new Error("LiveConfig instance is not initialized. Call init() first.");
22
+ }
23
+ return LiveConfig.instance;
24
+ }
25
+ }
26
+ //# sourceMappingURL=LiveConfig.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveConfig.js","sourceRoot":"","sources":["../../src/featureFlags/LiveConfig.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,UAAU;IAOrB,gBAAuB,CAAC;IACjB,MAAM,CAAC,IAAI,CAAC,MAAqE;QACtF,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACxB,UAAU,CAAC,QAAQ,GAAG,IAAI,UAAU,EAAE,CAAC;YACvC,UAAU,CAAC,QAAQ,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC;YACnD,UAAU,CAAC,QAAQ,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;SAChD;IACH,CAAC;IAEM,MAAM,CAAC,yBAAyB,CAAC,eAEvC;QACC,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;SAC/E;QACD,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,sBAAsB,EAAE;YAC/C,UAAU,CAAC,QAAQ,CAAC,sBAAsB,GAAG,EAAE,CAAC;SACjD;QACD,UAAU,CAAC,QAAQ,CAAC,sBAAsB,mCACrC,UAAU,CAAC,QAAQ,CAAC,sBAAsB,GAC1C,eAAe,CACnB,CAAC;IACJ,CAAC;IAEM,MAAM,CAAC,WAAW;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE;YACxB,MAAM,IAAI,KAAK,CAAC,4DAA4D,CAAC,CAAC;SAC/E;QACD,OAAO,UAAU,CAAC,QAAQ,CAAC;IAC7B,CAAC;CACF"}
@@ -0,0 +1,61 @@
1
+ import { DefaultFeature, Feature, Features, FeatureMap } from "@ledgerhq/types-live";
2
+ /**
3
+ * Util function that create a default feature and type its return.
4
+ *
5
+ * @dev needed for proper type infering.
6
+ *
7
+ * @param opts
8
+ * @returns typed `opts` parameter or the default feature.
9
+ */
10
+ export declare const initFeature: <T>(opts?: Feature<T> | undefined) => Feature<T>;
11
+ /**
12
+ * Currency Features.
13
+ */
14
+ export declare const CURRENCY_DEFAULT_FEATURES: {
15
+ currencyArbitrum: DefaultFeature;
16
+ currencyArbitrumGoerli: DefaultFeature;
17
+ currencyAstar: DefaultFeature;
18
+ currencyAvalancheCChain: DefaultFeature;
19
+ currencyAxelar: DefaultFeature;
20
+ currencyBase: DefaultFeature;
21
+ currencyBaseGoerli: DefaultFeature;
22
+ currencyBittorrent: DefaultFeature;
23
+ currencyBoba: DefaultFeature;
24
+ currencyCoreum: DefaultFeature;
25
+ currencyDesmos: DefaultFeature;
26
+ currencyDydx: DefaultFeature;
27
+ currencyEnergyWeb: DefaultFeature;
28
+ currencyEvmosEvm: DefaultFeature;
29
+ currencyInjective: DefaultFeature;
30
+ currencyInternetComputer: DefaultFeature;
31
+ currencyKavaEvm: DefaultFeature;
32
+ currencyKlaytn: DefaultFeature;
33
+ currencyLukso: DefaultFeature;
34
+ currencyMetis: DefaultFeature;
35
+ currencyMoonriver: DefaultFeature;
36
+ currencyOnomy: DefaultFeature;
37
+ currencyOptimism: DefaultFeature;
38
+ currencyOptimismGoerli: DefaultFeature;
39
+ currencyPersistence: DefaultFeature;
40
+ currencyPolygonZkEvm: DefaultFeature;
41
+ currencyPolygonZkEvmTestnet: DefaultFeature;
42
+ currencyQuicksilver: DefaultFeature;
43
+ currencyRsk: DefaultFeature;
44
+ currencySecretNetwork: DefaultFeature;
45
+ currencySeiNetwork: DefaultFeature;
46
+ currencyStacks: DefaultFeature;
47
+ currencyStargaze: DefaultFeature;
48
+ currencySyscoin: DefaultFeature;
49
+ currencyTelosEvm: DefaultFeature;
50
+ currencyUmee: DefaultFeature;
51
+ currencyVechain: DefaultFeature;
52
+ currencyVelasEvm: DefaultFeature;
53
+ currencyCasper: DefaultFeature;
54
+ currencyNeonEvm: DefaultFeature;
55
+ };
56
+ /**
57
+ * Default Features.
58
+ */
59
+ export declare const DEFAULT_FEATURES: Features;
60
+ export declare const formatDefaultFeatures: (config: FeatureMap) => {};
61
+ //# sourceMappingURL=defaultFeatures.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaultFeatures.d.ts","sourceRoot":"","sources":["../../src/featureFlags/defaultFeatures.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AAWrF;;;;;;;GAOG;AACH,eAAO,MAAM,WAAW,kDAGvB,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,yBAAyB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAyCrC,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,gBAAgB,EAAE,QAuV9B,CAAC;AAGF,eAAO,MAAM,qBAAqB,WAAY,UAAU,OAQrD,CAAC"}