React Native Android Integration¶
Prerequisites¶
This setup assumes you have already setup your App Key on the Dashboard, see prerequisites for more on this.
- Your App must be targeted for at least Lollipop (21) and above;
- Your app’s compileSdkVersion must be set to 28 or higher;
- Contextual supports React Native 0.60 or more recent, older versions might have incompatibility issues;
-
Contextual uses Java 1.8 features, please make sure your app uses it as well:
1 2 3 4 5 6 7 8 9
android { compileOptions { sourceCompatibility JavaVersion.VERSION_1_8 targetCompatibility JavaVersion.VERSION_1_8 } kotlinOptions { jvmTarget = "1.8" } }
-
Contextual UI is based on Google's Material Components library. Please ensure your app's theme inherits from
Theme.MaterialComponents
or its subthemes. -
Verify that your app uses a version eqal or more recent to 1.1.0
1 2 3
dependencies { implementation (group: "com.google.android.material", name: "material", version: "1.1.0") }
-
Make sure that inside your
app/res/values/styles.xml
(or equivalent) the parent ofAppTheme
is part of theTheme.MaterialComponents
theme. Here is an example from the Wikipedia's app:1 2 3 4 5 6
<style name="BaseAppTheme" parent="Theme.MaterialComponents.Light.NoActionBar"> <...> </style> <style name="AppTheme" parent="BaseAppTheme"> <...> </style>
Tip
If you are having issues with using Material with Contextual please check instructions here, specially step 4
Integration Steps¶
Step 1 - Native Integration¶
Setup the Android native SDK requirements.
Step 2 - Install the npm module:¶
1 |
|
Link the dependency (not necessary in ReactNative version >0.60):
1 |
|
Step 3 - Import pointzi¶
Import Pontzi module into android/settings.gradle
1 2 |
|
Use the pointzi-react module as a dependency in android/app/build.gradle
file
1 2 3 |
|
Step 4 - Set your Contextual AppKey¶
Set Contextual App Key in the android/app/src/main/AndroidManifest.xml
Under the application tag, add the following meta-data tag replacing APP_KEY with your app key:
1 2 3 4 5 6 |
|
React Native has only one Activity, when the user switches from page 1 to page 2 on your App the native side will not know what to name Page 1 and Page 2. Sometimes naming them the same or with non friendly names.
To fix this and allow Contextual to work properly you should add
PointziReact.viewWillRender('VIEW_NAME');
on the JS side
of your app, changing VIEW_NAME
with the name of the view
or a variable that contains it.
Call this method when there there is a page transition, this will allow the SDK to know that there was a View change and its name. A Few Examples showcasing how to do this can be found below.
React Navigation's NavigationContainer:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
|
Tab pages:
1 2 3 4 5 6 7 |
|
Or in some React Native projects, when a page has changed
componentWillMount()
is called upon page enter.
Class Component:¶
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
Function Component:¶
1 2 3 4 5 6 7 8 9 10 11 12 13 |
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
|
Usage¶
Tagging¶
You can tag Contextual installs by the following.
Tag Name | Description |
---|---|
sh_cuid | Use sh_cuid to tag an install with a unique identifier for the install. sh_cuid is needed to link the identity of App Users to Users in your - and the StreetHawk backend. Allows tagging via api call. Used to identify the same User across multiple installs. |
Code: | PointziReact.tagCuid('MY USER ABC'); |
tagString | For tagging any String and Value |
Code: | PointziReact.tagString("String key" , "String tag"); |
tagNumeric | Tagging any Numeric String and double value |
Code: | PointziReact.tagNumeric("String key" , 123); |