FlagRouter
Implements
Constructors
constructor
**new FlagRouter**(flags)
Parameters
flagsRecord<string, boolean \| Record<string, boolean>>RequiredProperties
flagsanyRequiredMethods
isFeatureEnabled
**isFeatureEnabled**(flag): boolean
Check if a feature flag is enabled. There are two ways of using this method:
isFeatureEnabled("myFeatureFlag")isFeatureEnabled({ myNestedFeatureFlag: "someNestedFlag" })We use 1. for top-level feature flags and 2. for nested feature flags. Almost all flags are top-level. An example of a nested flag is workflows. To use it, you would do:isFeatureEnabled({ workflows: Workflows.CreateCart })
Parameters
flagstring | Record<string, string>RequiredThe flag to check
Returns
boolean
booleanboolean
Whether the flag is enabled or not
listFlags
**listFlags**(): [FeatureFlagsResponse](/references/services/types/FeatureFlagsResponse)
Returns
FeatureFlagsResponse{ key: string ; value: boolean \| Record<string, boolean> }[]RequiredsetFlag
**setFlag**(key, value): void
Sets a feature flag.
Flags take two shapes:
setFlag("myFeatureFlag", true)
setFlag("myFeatureFlag", { nestedFlag: true })
These shapes are used for top-level and nested flags respectively, as explained in isFeatureEnabled.
Parameters
keystringRequiredThe key of the flag to set.
valueboolean | { [key: string]: boolean; }RequiredThe value of the flag to set.
Returns
void
voidvoid
void
Was this section helpful?