React Native SDK Getting Started
There are two ways to initialize the SDK:
- Non-Blocking: This loads your application and makes a request to initialize the SDK in the background. Once this request is complete, your application will be ready to use the SDK.
- Blocking: This allows you to delay the rendering of your application until the request to initialize the SDK is completed.
To use these providers, you must grab the SDK Key from the DevCycle Dashboard.
You can optionally pass in a user object to the provider to initialize the SDK.
If you do not pass in a user to the provider, it will create an anonymous user and initialize the SDK with it.
You can then call the identifyUser
method on the client once the user has been authenticated.
See Identifying Users & Setting Properties for more details.
Non-Blocking
The withDevCycleProvider
function initializes the React SDK and wraps your root component. This provider may cause your app
to flicker when it is first rendered, as it is waiting for the SDK to initialize.
import { withDevCycleProvider } from '@devcycle/react-native-client-sdk'
export default withDevCycleProvider({ sdkKey: '<DEVCYCLE_CLIENT_SDK_KEY>' })(App)
Blocking
The useIsDevCycleInitialized
hook allows you to block rendering of your application until SDK initialization is complete. This ensures your app
does not flicker due to value changes and enables you to control what you want displayed when initialization isn't finished yet.
import { useIsDevCycleInitialized, withDevCycleProvider } from '@devcycle/react-native-client-sdk'
function App() {
const devcycleReady = useIsDevCycleInitialized()
if (!devcycleReady) return <LoadingState/>
return <TheRestofYourApp/>
}
export default withDevCycleProvider({ sdkKey: '<DEVCYCLE_CLIENT_SDK_KEY>' })(App)
Provider Config
The withDevCycleProvider
function accepts a Provider Config object:
DevCycle ProviderConfig Typescript Schema
Property | Type | Description |
---|---|---|
sdkKey | String | SDK key |
user | DevCycleUser | DevCycleUser object |
options | DevCycleOptions | DevCycleOptions object |
Initialization Options
The SDK exposes various initialization options which can be set by passing a DevCycleOptions
object in the Provider Config:
DevCycleOptions Typescript Schema
DevCycle Option | Type | Description |
---|---|---|
enableEdgeDB | Boolean | Enables the usage of EdgeDB for DevCycle that syncs User Data to DevCycle. |
logger | DevCycleLogger | Logger override to replace default logger |
logLevel | DevCycleDefaultLogLevel | Set log level of the default logger. Options are: debug , info , warn , error . Defaults to info . |
eventFlushIntervalMS | Number | Controls the interval between flushing events to the DevCycle servers in milliseconds, defaults to 10 seconds. |
flushEventQueueSize | Number | Controls the maximum size the event queue can grow to until a flush is forced. Defaults to 100 . |
maxEventQueueSize | Number | Controls the maximum size the event queue can grow to until events are dropped. Defaults to 1000 . |
apiProxyURL | String | Allows the SDK to communicate with a proxy of DevCycle bucketing API / client SDK API. |
configCacheTTL | Number | The maximum allowed age of a cached config in milliseconds, defaults to 7 days |
disableConfigCache | Boolean | Disable the use of cached configs |
disableRealtimeUpdates | Boolean | Disable Realtime Updates |
disableAutomaticEventLogging | Boolean | Disables logging of sdk generated events (e.g. variableEvaluated, variableDefaulted) to DevCycle. |
disableCustomEventLogging | Boolean | Disables logging of custom events, from track() method, and user data to DevCycle. |