Cordova plugin for Firebase Analytics
Your help is appreciated. Create a PR, submit a bug or just grab me 🍺 |
---|
- iOS
- Android
$ cordova plugin add cordova-plugin-firebase-analytics
If you get an error about CocoaPods being unable to find compatible versions, run
$ pod repo update
Use variables ANDROID_FIREBASE_BOM_VERSION
or IOS_FIREBASE_POD_VERSION
to override dependency versions for Firebase SDKs:
$ cordova plugin add cordova-plugin-firebase-analytics \
--variable IOS_FIREBASE_POD_VERSION="9.3.0" \
--variable ANDROID_FIREBASE_BOM_VERSION="30.3.1"
NOTE: on iOS in order to collect demographic, age, gender data etc. you should additionally include AdSupport.framework
into your project.
In some cases, you may wish to temporarily or permanently disable collection of Analytics data. You can set the value of variable ANALYTICS_COLLECTION_ENABLED
to false
to prevent collecting any user data:
$ cordova plugin add cordova-plugin-firebase-analytics \
--variable ANALYTICS_COLLECTION_ENABLED=false
Later you can re-enable analytics data collection (for instance after getting end-user consent) using method setEnabled.
In order to disable automatic collection of screen view events set the value of variable AUTOMATIC_SCREEN_REPORTING_ENABLED
to false
:
$ cordova plugin add cordova-plugin-firebase-analytics \
--variable AUTOMATIC_SCREEN_REPORTING_ENABLED=false
Cordova supports resource-file
tag for easy copying resources files. Firebase SDK requires google-services.json
on Android and GoogleService-Info.plist
on iOS platforms.
- Put
google-services.json
and/orGoogleService-Info.plist
into the root directory of your Cordova project - Add new tag for Android platform
<platform name="android">
...
<resource-file src="google-services.json" target="app/google-services.json" />
</platform>
...
<platform name="ios">
...
<resource-file src="GoogleService-Info.plist" />
</platform>
This way config files will be copied on cordova prepare
step.
logEvent(name
, params
): Promise
<void
>
Logs an app event.
Example
cordova.plugins.firebase.analytics.logEvent("my_event", {param1: "value1"});
Name | Type | Description |
---|---|---|
name |
string |
Enent name |
params |
Record <string , string | number | object []> |
Event parameters |
Promise
<void
>
Callback when operation is completed
resetAnalyticsData(): Promise
<void
>
Clears all analytics data for this instance from the device and resets the app instance ID.
Example
cordova.plugins.firebase.analytics.resetAnalyticsData();
Promise
<void
>
Callback when operation is completed
setCurrentScreen(screenName
,screenClass
): Promise
<void
>
Sets the current screen name and screen class, which specifies the current visual context in your app. This helps identify the areas in your app where users spend their time and how they interact with your app. Screen class is optional. If you don't provide a value for second parameter, screen class is automatically set as screen name.
Example
cordova.plugins.firebase.analytics.setCurrentScreen("User dashboard", "User dashboard");
Name | Type | Description |
---|---|---|
screenName |
string |
Current screen name |
screenClass |
string |
Current screen class (optional) |
Promise
<void
>
Callback when operation is completed
setDefaultEventParameters(defaults
): Promise
<void
>
Adds parameters that will be set on every event logged from the SDK, including automatic ones.
Example
cordova.plugins.firebase.analytics.setDefaultEventParameters({foo: "bar"});
Name | Type | Description |
---|---|---|
defaults |
Record <string , string | number | object []> |
Key-value default parameters map |
Promise
<void
>
Callback when operation is completed
setEnabled(enabled
): Promise
<void
>
Sets whether analytics collection is enabled for this app on this device.
Example
cordova.plugins.firebase.analytics.setEnabled(false);
Name | Type | Description |
---|---|---|
enabled |
boolean |
Flag that specifies new state |
Promise
<void
>
Callback when operation is completed
setUserId(userId
): Promise
<void
>
Sets the user ID property. This feature must be used in accordance with Google's Privacy Policy.
See
https://www.google.com/policies/privacy
Example
cordova.plugins.firebase.analytics.setUserId("12345");
Name | Type | Description |
---|---|---|
userId |
string |
User's indentifier string |
Promise
<void
>
Callback when operation is completed
setUserProperty(name
, value
): Promise
<void
>
Sets a user property to a given value. Be aware of automatically collected user properties.
See
https://support.google.com/firebase/answer/6317486?hl=en&ref_topic=6317484
Example
cordova.plugins.firebase.analytics.setUserProperty("name1", "value1");
Name | Type | Description |
---|---|---|
name |
string |
Property name |
value |
string |
Property value |
Promise
<void
>
Callback when operation is completed