UNPKG

@featbit/react-client-sdk

Version:
26 lines (25 loc) 1.55 kB
import * as React from 'react'; import { ProviderConfig } from './types'; import IntrinsicAttributes = React.JSX.IntrinsicAttributes; /** * `withFbProvider` is a function which accepts a config object which is used to * initialize `@featbit/js-client-sdk`. * * This HOC handles passing configuration to the `FbProvider`, which does the following: * - It initializes the fbClient instance by calling `@featbit/js-client-sdk` init on `componentDidMount` * - It saves all flags and the fbClient instance in the context API * - It subscribes to flag changes and propagate them through the context API * * The difference between `withFbProvider` and `asyncWithFbProvider` is that `withFbProvider` initializes * `@featbit/js-client-sdk` at `componentDidMount`. This means your flags and the fbClient are only available after * your app has mounted. This can result in a flicker due to flag changes at startup time. * * `asyncWithFbProvider` initializes `@featbit/js-client-sdk` at the entry point of your app prior to render. * This means that your flags and the fbClient are ready at the beginning of your app. This ensures your app does not * flicker due to flag changes at startup time. * * @param config - The configuration used to initialize FeatBit JS Client SDK * @return A function which accepts your root React component and returns a HOC */ export declare function withFbProvider<T extends IntrinsicAttributes = {}>(config: ProviderConfig): (WrappedComponent: React.ComponentType<T>) => any; export default withFbProvider;