React Native Product Experiences
Learn how to set up Remote Config for your React Native application.
Overview
With the CleverTap React Native SDK, you can create variables on your app that take on new values from the CleverTap dashboard. Using variables in the CleverTap dashboard allows you to roll out changes without pushing an update through the Apple App Store/Google Play Store. These can also be used in A/B tests to test features for only a percentage of your users.
You can define variables using the CleverTap React Native SDK. When you define a variable in your code, you can sync it to the CleverTap Dashboard via the provided SDK methods.
SDK Prerequisite
Before you proceed, ensure that you are using React Native v1.1.0 or higher to use the Remote Config feature.
Supported Variable Types
CleverTap React Native SDK supports the following variable types:
- String
- Boolean
- Dictionary
- Int
- Float
- Double
- Short
- Long
- Number
- File (supported for CleverTap SDK v3.1.0 or higher)
Define Variables
Variables can be defined using the defineVariables
method. You must provide the names and default values of the variables using a JSON Object.
let variables = {
'reactnative_var_string': 'reactnative_var_string_value',
'reactnative_var_map': {
'reactnative_var_map_string': 'reactnative_var_map_value'
},
'reactnative_var_int': 6,
'reactnative_var_float': 6.9,
'reactnative_var_boolean': true
};
CleverTap.defineVariables(variables);
Define File Type Variables
CleverTap supports file type variables starting from CleverTap React Native SDK v3.1.0 and above. Supported file types include but are not limited to images (jpg, jpeg, png, gif), text files, and PDFs.
You can define a new file type variable using the following code:
CleverTap.defineFileVariable('fileVariable');
Sync Defined Variables
After defining your variables in the code, you must send/sync variables to the server. To do so, the app must be in DEBUG mode and mark a particular CleverTap user profile as a test profile from the CleverTap dashboard. Learn how to mark a profile as Test Profile
After marking the profile as a test profile, you must sync the app variables in DEBUG mode:
// 1. Define CleverTap variables
// β¦
// 2. Add variables/values changed callbacks
// β¦
// 3. Sync CleverTap Variables from DEBUG mode/builds
CleverTap.syncVariables();
Key Points to Remember
- In a scenario where there is already a draft created by another user profile in the dashboard, the sync call will fail to avoid overriding important changes made by someone else. In this case, Publish or Dismiss the existing draft before you proceed with syncing variables again. However, you can override a draft you created via the sync method previously to optimize the integration experience.
- You can receive the following Logcat logs from the CleverTap SDK:
- Variables synced successfully.
- Unauthorized access from a non-test profile. To address this, mark the profile as a test profile from the CleverTap dashboard.
Fetch Variables During a Session
You can fetch the updated values for your CleverTap variables from the server during a session. If variables have changed, the appropriate callbacks will be fired. The provided callback provides a boolean flag that indicates if the fetch call was successful. The callback is fired regardless of whether the variables have changed or not.
CleverTap.fetchVariables((err, success) => {
console.log('fetchVariables result: ', success);
});
Use Fetched Variables Values
This process involves the following major steps:
Fetch Variable Values
Variables are updated automatically when server values are received. If you want to receive feedback when a specific variable is updated, use the individual callback:
CleverTap.onValueChanged('reactnative_var_string', (variable) => {
console.log('onValueChanged: ', variable);
});
Verify Status of Variables Fetch Request
The fetchVariables
method verifies if the variables were successfully retrieved from the server.
CleverTap.fetchVariables((err, success) => {
console.log('fetchVariables result: ', success);
});
Access Variable Values
You can access these fetched values in the following two ways:
Getting all variables
CleverTap.getVariables((err, variables) => {
console.log('getVariables: ', variables, err);
});
Getting a specific variable
CleverTap.getVariable('reactnative_var_string', (err, variable) => {
console.log(`variable value for key \'reactnative_var_string\': ${variable}`);
});
Set Up Callbacks
CleverTap React Native SDK provides feedback through multiple callbacks. You can select only the required callbacks. They are as follows:
- All Variables Callbacks
- Individual Variable Callback
- All File Variables Callback
- File Variables Individual Callback
All Variables Callbacks
onVariablesChanged
onVariablesChanged
This callback is invoked after the variables are initialized with values fetched from the server. It is called each time new values are fetched.
CleverTap.onVariablesChanged((variables) => {
console.log('onVariablesChanged: ', variables);
});
onceVariablesChanged
onceVariablesChanged
This callback is invoked after the variables are initialized with values fetched from the server. It is called only once.
CleverTap.onceVariablesChanged((variables) => {
console.log('onceVariablesChanged: ', variables);
});
Individual Variable Callback
onValueChanged
onValueChanged
This callback is invoked after the variable's value changes. To monitor its value, you must provide the variable's name.
CleverTap.onValueChanged('reactnative_var_string', (variable) => {
console.log('onValueChanged: ', variable);
});
All File Variables Callback
onVariablesChangedAndNoDownloadsPending
onVariablesChangedAndNoDownloadsPending
This callback is called when no files need to be downloaded or all downloads have been completed. It is called each time new values are fetched and downloads are completed.
CleverTap.onVariablesChangedAndNoDownloadsPending('fileVariable', (fileVariable) => {
console.log('onVariablesChangedAndNoDownloadsPending: ', fileVariable);
});
onceVariablesChangedAndNoDownloadsPending
onceVariablesChangedAndNoDownloadsPending
This callback is called only once when no files need to be downloaded, or all downloads have been completed.
CleverTap.onceVariablesChangedAndNoDownloadsPending('fileVariable', (fileVariable) => {
console.log('onceVariablesChangedAndNoDownloadsPending: ', fileVariable);
});
File Variables Individual Callback
onFileValueChanged
onFileValueChanged
This callback is called when the file variable's value is downloaded and ready. It is available only for File variables.
CleverTap.onFileValueChanged('fileVariable', (fileVariable) => {
console.log('onFileValueChanged: ', fileVariable);
});
Troubleshooting
For troubleshooting, refer to the iOS and Android product experiences documentation.
Updated 2 months ago