Refiner Mobile SDK integration
iOS
Refiner iOS SDK's minimum deployment target is iOS 11.
1) Installation
The Refiner iOS SDK can be added either by using CocoaPods or SPM.
1.1 Swift Package Manager (Xcode 11+)
Swift Package Manager (SwiftPM) is a tool for managing the distribution of Swift code as well as C-family dependency. From Xcode 11, SwiftPM got natively integrated with Xcode.
Refiner SDK support SwiftPM. To use SwiftPM, you should use Xcode 11 to open your project. Click File
-> Swift Packages
-> Add Package Dependency
, enter RefinerSDK repo's URL. Or you can login Xcode with your GitHub account and just type RefinerSDK
to search.
After select the package, you can choose the dependency type (tagged version, branch or commit). Then Xcode will setup all the stuff for you.
1.2 CocoaPods
Referencing the RefinerSDK
pod in the Podfile
will be sufficient to add the Refiner iOS SDK to your project.
Steps to add:
- If your project doesn't have a
Podfile
then you can create one by running the following command on the terminal:
pod init
- Reference
RefinerSDK
in thePodfile
:
target 'YOUR_APPLICATION_NAME' do
# ... beginning of your Podfile ...
pod 'RefinerSDK'
# ... remaining of your Podfile ...
end
Note: Replace
YOUR_APPLICATION_NAME
with the name of your application in thetarget
section
- Install pods by running the following command on the terminal:
pod install
2) Usage
Visit our documentation for more information about how to use the SDK methods.
Initialization & Configuration
Initialize Refiner iOS SDK in your application class with the needed configuration parameters.
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
Refiner.instance.initialize(projectId: "PROJECT_ID", enableDebugMode: true)
return true
}
Identify User
Call Identify User
to create or update a user traits in Refiner.
The first parameter is the userId of your logged-in user and is the only mandatory parameter.
The second parameter is an object of user traits. You can omit or set this value to null
if you don't want to send any user traits to your Refiner account.
Refiner.instance.identifyUser(
userTraits: [
"email": "[email protected]"
"something": "else"
],
userId: "USER_ID"
)
The third parameter is for setting the locale
of a user and is optional. The expected format is a two letter ISO 639-1 language code. When provided, the locale code is used for launching surveys for specific languages, as well as launching translated surveys. You can omit or set the value to null
if you are not using any language specific features.
The fourth parameter is an optional Identity Verification signature. We recommend to use a Identify Verification signature for increased security in a production environment. For development purposes, you can omit or set this value to null
.
Refiner.instance.identifyUser(
userTraits: [
"email": "[email protected]"
"something": "else"
],
userId: "USER_ID",
locale: "en",
signature: "SIGNATURE")
Track Event
Track Event
lets you track user events. Tracked events can be used to create user segments and target audiences in Refiner.
Refiner.instance.trackEvent(name: "EVENT_NAME")
Track Screen
Track Screen
provides to track screen that user is currently on. Screen information can be used to launch surveys in specific areas of your app.
We recommend to track screens on which you might want to show a survey one day. There is no need to systematically track all screens of your app.
Refiner.instance.trackScreen(name: "SCREEN_NAME")
Ping
Depending on your setup, you might want to initiate regular checks for surveys that are scheduled for the current user. For example when you are using time based trigger events, or when a target audience is based on user data received by our backend API.
The Ping
method provides an easy way to perform such checks. You can call the Ping
method at key moments in a user's journey, such as when the app is re-opened, or when the user performs a specific action.
Refiner.ping()
Show Form
If you use the Manual Trigger Event for your survey, you need to call Show Form
whenever you want to launch the survey.
Refiner.instance.showForm(uuid: "FORM_UUID")
For testing purposes, you can also provide an additional force
parameter which will bypass all targeting rules and always display the survey.
Refiner.instance.showForm(uuid: "FORM_UUID", force: true)
Attach Contextual Data
Attach contextual data to the survey submissions with addToResponse
. Set null
to remove the contextual data.
Refiner.instance.addToResponse(
data: [
"some_data": "hello",
"some_more_data": "hello again"
])
Reset User
Call Reset User
to reset the user identifier previously set through Identify User
. We recommend calling this method when the user logs out from your app.
Refiner.instance.resetUser()
Register callback functions
Registering callback functions allows you to execute any code at specific moments in the lifecycle of a survey. A popular use-case for callback functions is to redirect a user to a new screen once they completed a survey.
onBeforeShow
gets called right before a survey is supposed to be shown.
Refiner.instance.onBeforeShow = { formId, formConfig in
print("onBeforeShowCallback")
print("formId: \(formId))")
print("formConfig: \(formConfig ?? ""))")
}
onNavigation
gets called when the user moves through the survey
Refiner.instance.onNavigation = { formId, formElement, progress in
print("onNavigationCallback")
print("formId: \(formId))")
print("formElement: \(formElement ?? ""))")
print("progress: \(progress ?? ""))")
}
onShow
gets called when a survey widget becomes visible to your user.
Refiner.instance.onShow = { formId in
print("onShowCallback")
print("formId: \(formId))")
}
onClose
gets called when the survey widgets disappears from the screen.
Refiner.instance.onClose = { formId in
print("onCloseCallback")
print("formId: \(formId))")
}
onDismiss
gets called when the user dismissed a survey by clicking on the “x” in the top right corner.
Refiner.instance.onComplete = { formId, formData in
print("onCompleteCallback")
print("formId: \(formId))")
print("formData: \(formData ?? ""))")
}
onComplete
gets called when the user completed (submitted) a survey.
Refiner.instance.onDismiss = { formId in
print("onDismissCallback")
print("formId: \(formId))")
}