This is a demo app that demonstrates the integration of Flipp Shopper SDK into a native Android app. To try it out:
- download or checkout the code
- open in Android Studio
- sync gradle dependencies
- run the app.
The Flipp Shopper SDK is a framework that provides the ability to embed the Flipp NativeX experience within your Android app.
The SDK does this by providing a custom view called FlyerView
, which has 2 main functionalities:
- Renders the NativeX experience
- Provides callback methods for your app to handle events from the
FlyerView
The standard 300x1800 ratio ad unit designed to be placed at the bottom of an article
The compact unit appears in a smaller size of 300x600 and is intended to be placed in the middle of the page. This ad type can automatically expand as the user engages with the content. To use the compact mode, define START_COMPACT
and DWELL_EXPANDABLE
as true. Read more about these options
This is configured using the START_COMPACT
and DWELL_EXPANDABLE
options
To successfully use the SDK, you need to request the following from Flipp:
- Access to the SDK library (Can be downloaded from this repo)
- publisherID, userID, siteID, zoneID(s), domain - values required to initialize the SDK in runtime and start showing flyers
The rest of this guide assumes you have obtained the aforementioned keys.
We publish the library to a private Maven repository hosted on JFrog. To access it,
please ask our team to grant access to the repository for your JFrog username.
The JFrog repository is called shopper-sdk-droid
.
To add the repository to the project (Assuming you have the proper authorization),
first add the repository URL to dependency resolution sources in settings.gradle
:
dependencyResolutionManagement {
repositories {
mavenLocal()
google()
mavenCentral()
maven {
url "https://flipplib.jfrog.io/artifactory/shopper-sdk-droid/"
credentials {
username "${artifactory_user}"
password "${artifactory_password}"
}
}
}
}
Note: Here we are retrieving our JFrog credentials from ~/.gradle/gradle.properties
(C:\Users\user\.gradle\gradle.properties
on Windows)
which we declared as artifactory_user
and artifactory_password
. You may use a similar approach or hardcode the username/password (not recommended).
Once library is accessible via Maven repo,
add implementation(group: 'com.flipp', name: 'shopper-sdk', version: 'X.Y', ext: 'aar')
to your app's dependencies,
replacing the version 'X.Y'
with actual version code (such as 1.8
).
Note: Updates to the SDK will be released over time. We recommend using the latest version number available from the Releases page here: https://github.com/wishabi/flipp-shopper-sdk-android-sample/releases. Flipp will also notify your team if there is a critical version number to upgrade to.
Finally, make sure to hit Sync Project with Maven Files.
That's it! Now you have the Flipp Shopper SDK added and ready to use.
You will need to initialize the SDK at runtime by calling Flipp.init
with the parameters below.
It is preferable to call the Flipp.init
as soon as possible, preferably from a subclass of Application
or from your MainActivity
.
app
- The current application objectpublisherName
- A name that uniquely identifies the name of the publisher integrating the SDK. Use values provided by FlippsiteId
- An ID that represents the SDK client. Use values provided by FlippuserId
- A unique string anonymously identifying the current user that is used for frequency cap and improving content relevancy. For example, the userId can be a hashed ADID/IDFA, hashed email, internal app or account ID. Do not send PII in plain text or hardcode a static userIDisDebug
- A boolean property indicating if this is a development environment. Usetrue
for testing andfalse
for productionisReactNative
- A boolean property indicating if the SDK is used in an React Native appzoneIds
- (optional) An array of zones used to separate site/properties within a media partner's portfolio to facilitate content targeting. For example, a zone for sports, another for news or food. ZoneIDs are constrained to integer values and must align with the ID's provided by Flippdomain
- A string property indicating the app's name. Can be the same as publisherName if the publisher only owns one appcontentCode
- (optional) A string that can be used to invoke different campaign content for testing purposesoptions
- (optional) A Set of loader options that can be used to customize how the ad renders. See available optionscallback
- (optional) Your callback function for handling events from the SDK
Make sure your Application
subclass is added to the AndroidManifest.xml
.
Here is a sample of what Flipp.init
looks like:
Flipp.init(app, publisherName, siteID, userID, isDebug, isReactNative, listOf(zoneIDs), "http://www.myapp.com", contentCode, setOf(Flipp.SdkOptions.DWELL_EXPANDABLE)) {
when (it) {
Flipp.SdkInitCallback.SdkInitResult.OK ->
Log.d("MyApp", "SDK initialized")
Flipp.SdkInitCallback.SdkInitResult.ERROR ->
Log.e("MyApp", "The impossible has happened?!")
}
}
NOTE: Please ensure the init parameters (publisherName, siteId, userId, zoneIds, domain) are passed and isDebug
is set to false in your production/release builds.
Failure to do so may result in missing revenue or SDK initialization failure.
The Shopper SDK provides a custom view, named FlyerView
, which enables you to embed a flyer into any layout or viewgroup.
- You may do so statically (via XML) or programmatically (create a new instance of the view and add it to your ViewGroup)
- The
FlyerView
itself is simply aFrameLayout
. For example, you can embed a flyer into a view's XML layout:
<com.flipp.shoppersdk.views.FlyerView
android:id="@+id/embedded_flyer_1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/black"
android:minHeight="50px" />
You won't need to do anything else to serve flyers. At this point, whenever the user scrolls or brings the FlyerView onto the screen, a flyer will be displayed.
NOTE: Do not initialize the FlyerView with 0 width/height - the SDK will not be able to detect if the experience is currently in view and thus will not trigger loading of the flyer.
Since 1.4
you can set the sizing mode of the FlyerView
via flyerViewInstance.autoResize
boolean (Default is true
, highly recommended!).
When auto resize is set to true
, the FlyerView
will automatically resize to fit the flyer content perfectly.
If set to false
, you'll have to set the size manually, both inside onFinishedLoading(height: Int)
and onRequestResize(height: Int)
callbacks.
To further personalize the content of the FlyerView
, you can pass the context of the page that the experience exists in to the SDK. For example, if the user is on a beef stew recipe page, you can pass in the ingredients as keywords, and the SDK will try to generate beef stew-related deals.
To do this, you can use the a function from FlyerView
called setContext
which takes two parameters:
contextList
- An array of strings that can contain keywords from a shopping list/recipe list/etc. Used to personalize the contextcontextUrl
- A string identifier of the current page containing the webview
It is preferable to call setContext
as close to the initialization of the FlyerView
as possible.
FlyerView
provides certain features that can be enabled/disabled depending on your use case.
Currently we support the following features:
GO_TO_URL
- if a user clicks on a link, it is opened in the native browser. This feature must be enabled.ADD_TO_SHOPPING_LIST
- (enabled by default) sends a callback when a flyer item is clicked. An example use case would be if your app has a shopping list functionality - enabling this feature would allow the SDK to send clicked items from the flyers for your app to store in the list. (See callbacks below)
To specify which features to enable, call the setSupportedFeatures
function with a list of features:
flyerView.setSupportedFeatures(
IntegrationFeatures.ADD_TO_SHOPPING_LIST,
IntegrationFeatures.GO_TO_URL
)
You can attach a FlyerEventsListener
to a FlyerView
instance to receive updates:
flyerView.setFlyerEventsListener(object: FlyerEventsListener() {
/**
* This signals the successful loading of a flyer.
* Flyer content will be visible at this state
*/
override fun onFinishedLoading(height: Int) {
}
/**
* This method is called when the flyer wants to be resized.
* You don't have to do manual resizing as the webview is automatically resized.
*/
override fun onRequestResize(heightPx: Int) {
}
/**
* If IntegrationFeatures.ADD_TO_SHOPPING_LIST is passed to setSupportedFeatures(),
* then an "Add to List" button will be shown when a flyer item is clicked.
* Clicking that button will trigger this callback which you can use to add the item to a list.
*/
override fun onAddItemToList(itemName: String) {
}
/**
* Callback used for communication of all FlyerView level errors.
*/
override fun onError(e: Exception) {
}
})
Please note that the callbacks are optional and you do not have to listen to them. You can also override only the needed methods.
You can apply additional settings that customize how the ad renders through the options
field of the Flipp.init
initialization function. Currently, the available options are:
.START_COMPACT
: Renders a flyer with a smaller height of 600px. It is recommended to also toggle onDWELL_EXPANDABLE
with this option. Read more about the Compact Unit.DWELL_EXPANDABLE
: Enables auto-expansion of the flyer if the user keeps the ad on screen for more than 3 seconds