2020-05-28 18:10:26 +00:00
|
|
|
import { FeatureFlagConfig, FeatureFlagsEnum } from "configs/types";
|
|
|
|
|
const optimizelySDK = require("@optimizely/optimizely-sdk");
|
|
|
|
|
|
|
|
|
|
class FeatureFlag {
|
|
|
|
|
static isInitialized = false;
|
|
|
|
|
static remote = undefined;
|
2020-07-07 10:22:17 +00:00
|
|
|
static initialize(featureFlagConfig?: FeatureFlagConfig) {
|
|
|
|
|
if (featureFlagConfig) {
|
|
|
|
|
Object.keys(featureFlagConfig.default).forEach((flag: any) => {
|
|
|
|
|
// This is required because otherwise it will reset the values
|
|
|
|
|
// every time the application is loaded. We need the application to load
|
|
|
|
|
// remote values the second time.
|
|
|
|
|
if (localStorage.getItem(flag) === null) {
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
flag,
|
|
|
|
|
featureFlagConfig.default[flag as FeatureFlagsEnum].toString(),
|
|
|
|
|
);
|
|
|
|
|
}
|
2020-05-28 18:10:26 +00:00
|
|
|
});
|
2020-07-07 10:22:17 +00:00
|
|
|
|
|
|
|
|
if (featureFlagConfig.remoteConfig) {
|
|
|
|
|
FeatureFlag.remote = optimizelySDK.createInstance({
|
|
|
|
|
sdkKey: featureFlagConfig.remoteConfig.optimizely,
|
|
|
|
|
datafileOptions: {
|
|
|
|
|
autoUpdate: true,
|
|
|
|
|
updateInterval: 600000, // 10 minutes in milliseconds
|
|
|
|
|
urlTemplate: window.location.origin + "/f/datafiles/%s.json",
|
|
|
|
|
},
|
|
|
|
|
});
|
|
|
|
|
(FeatureFlag.remote as any).onReady().then(onInit);
|
|
|
|
|
}
|
2020-05-28 18:10:26 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static identify(userData: any) {
|
|
|
|
|
if (FeatureFlag.remote) {
|
|
|
|
|
if (FeatureFlag.isInitialized) {
|
|
|
|
|
updateFlagsInLocalStorage(userData);
|
|
|
|
|
} else {
|
|
|
|
|
(FeatureFlag.remote as any).onReady().then(() => {
|
|
|
|
|
onInit();
|
|
|
|
|
updateFlagsInLocalStorage(userData);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static check(flagName: string) {
|
|
|
|
|
return localStorage.getItem(flagName) === "true";
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function onInit() {
|
|
|
|
|
FeatureFlag.isInitialized = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function updateFlagsInLocalStorage(userData: any) {
|
|
|
|
|
const userId = userData.id;
|
|
|
|
|
const email = userData.email;
|
|
|
|
|
const optimizelyClientInstance = FeatureFlag.remote as any;
|
|
|
|
|
|
2020-05-29 18:29:03 +00:00
|
|
|
Object.values(FeatureFlagsEnum).forEach((flag: string) => {
|
|
|
|
|
localStorage.setItem(
|
|
|
|
|
flag,
|
|
|
|
|
optimizelyClientInstance.isFeatureEnabled(flag, userId, { email }),
|
|
|
|
|
);
|
|
|
|
|
});
|
2020-05-05 06:46:54 +00:00
|
|
|
}
|
2020-04-20 08:26:19 +00:00
|
|
|
|
2020-05-28 18:10:26 +00:00
|
|
|
export default FeatureFlag;
|