The Thunderhead ONE SDK Flutter Plugin for iOS and Android.
To see integration examples, see examples.
To install the Thunderhead ONE Flutter Plugin, go to your pubspec.yaml
and add the dependency:
one_sdk_flutter:
git:
url: https://github.com/thunderheadone/one-sdk-flutter.git
- See example here
By disabling automatic Interaction detection, the SDK will no longer automatically send Interaction requests as native iOS View Controllers
or Android Activities
or Fragments
are presented on screen.
It is recommended to disable automatic Interaction detection in Flutter applications as the SDK does not recognize Flutter or web view elements, so it becomes your responsibility to send them when needed by using the send Interaction methods outlined below.
For native applications where only a part of the app uses Flutter, you may want to ignore disabling automatic Interaction detection to automatically detect native Interactions.
You can disable automatic Interaction detection by calling the method disableAutomaticInteractionDetection:
and passing true
as a parameter, as shown below:
// Swift
One.disableAutomaticInteractionDetection(true)
// https://github.com/thunderheadone/one-sdk-ios#disable-automatic-interaction-detection
// Kotlin
oneConfigureCodelessInteractionTracking {
// disables Fragment/Activity Interaction Tracking
disableCodelessInteractionTracking = true
}
// https://github.com/thunderheadone/one-sdk-android#disable-automatic-interaction-detection
An appropriate place to call the method might be under didFinishLaunchingWithOptions
in your AppDelegate
for iOS or under onCreate
in your Application
class for Android.
You can set this back to false
at any point to restart automatic Interaction detection.
To initialize the ONE Flutter Plugin, call the following method:
import 'package:one_sdk_flutter/one_sdk_flutter.dart';
One.initializeOne(SITE_KEY, TOUCHPOINT, API_KEY, SHARED_SECRET, USER_ID, HOST, false);
- See example of usage here
To send an Interaction request without properties, call the following method:
One.sendInteraction("/interactionPath");
- See example of usage here
To send an Interaction request with properties, call the following method:
One.sendInteraction("/interactionPath", { 'key' : 'value' });
- See example of usage here
To send an Interaction request and retrieve the response, call the following method:
One.sendInteraction("/interactionPath").then((response) {
print('Interaction response tid = ${response[oneResponseTidKey]}');
print('Interaction response Interaction path = ${response[oneResponseInteractionPathKey]}');
print('Interaction response optimization points = ${response[oneResponseOptimizationPointsKey]}');
});
- See example of usage here
To send a response code, call the following method:
One.sendResponseCode("code", "/interactionPath");
To opt an end-user out of all tracking options, when the end-user does not give permission to be tracked in the client app, call the following method:
// Opts out of all tracking options.
One.optOut(true);
To opt back in, call the following method:
// Opt in for all tracking options.
One.optOut(false);
To opt an end-user out of city/country level tracking, call the following method:
// Calling this method will opt the end-user back in for all tracking.
One.optOutCityCountryDetection(true);
To opt an end-user out of all keychain Tid storage, call the following method:
One.optOutKeychainTidStorage(true);
To configure logging, call the following method:
One.setThunderheadLogLevel(true);
- See example of usage here
The Thunderhead team is available 24/7 to answer any questions you have. Just email onesupport@thunderhead.com or visit our docs page for more detailed installation and usage information.
For Salesforce Marketing Cloud Interaction Studio questions, please submit a support ticket via https://help.salesforce.com/home