The Ada iOS SDK is a small framework that is used to embed your Ada Chat bot into your native iOS application.
This document is intended for bot specialists and developers with working knowledge of iOS development. It also assumes you have a native iOS app into which you plan to integrate the Ada iOS SDK.
The Ada iOS SDK can be installed manually or using CocoaPods. The SDK supports iOS 10.x and up.
- Download the Ada iOS SDK framework here.
- Right click on the project file in XCode, then click "Add Files to MyProjectName". Ensure that the Copy groups option is selected.
- Ensure your Deployment Target is set to 10.0, which is the minimum iOS version that the Ada iOS SDK is compatible with.
- In the project settings under General, link the
AdaEmbedFramework.framework
under the Embedded Binaries section. You can do this by dragging the framework from the left side list in the Embedded Binaries list.
The AdaEmbedFramework CocoaPod is public, however use of the Chat interface is gated. To gain access please reach out to an Ada Bot Specialist.
- Add the
AdaEmbedFramework
to your Podfile.
Example:
platform :ios, '10.0'
target 'MyApp' do
use_frameworks!
# Pods for MyApp
pod "AdaEmbedFramework", "~>1.0.0"
end
- Install the pod using:
pod install
Once you have installed the Ada iOS SDK, you are ready to use it in your app! To start, import AdaEmbedFramework into your controller:
import AdaEmbedFramework
You can then create an instance of the AdaWebHost like so:
var adaFramework = AdaWebHost(handle: “ada-example”)
Please note "ada-example" is being used for demonstration purposes. Be sure to sure modify handle
, as well as any other values as needed for your bot.
Finally, launch Ada using any of the 3 opening methods: launchModalWebSupport, launchNavWebSupport, or launchInjectingWebSupport.
AdaWebHost
can take various input parameters to customize the behaviour of your Chat bot.
Specifies the Kubernetes cluster to be used. Unless directed by an Ada team member, you will not need to change this value.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, cluster: "ca")
This can be used to customize the greeting messages that new users see. This is useful for setting view-specific greetings across your app. The greeting should correspond to the ID of the Answer you would like to use. The ID can be found in the URL of the corresponding Answer in the dashboard.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, greeting: "5c59aaabd8269e0339979014")
The handle for your bot. This is a required field.
Takes in a language code to programatically set the bot language. Languages must first be turned on in the Settings > Multilingual page of your Ada dashboard. Language codes follow the ISO 639-1 language format.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, language: "fr")
Used to pass meta information about a Chatter. This can be useful for tracking information about your end users, as well as for personalizing their experience. For example, you may wish to track the phone_number and name for conversation attribution. Once set, this information can be accessed in the email attachment from Handoff Form submissions, or via the Chatter modal in the Conversations page of your Ada dashboard. Should you need to programatically change these values after bot setup, you can make use of the setMetaFields method below.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, metafields: ["tier": "pro"])
The styles
setting can be used to override default styles inside the Chat bot. The value of the string should be the CSS rule-set you wish to apply inside the Chat UI. A list of CSS selectors available for targetting can be found in the table below.
WARNING: We do not recommend assigning styles to classes you inspect in the DOM. Class naming is subject to change, and can cause your custom styles to break. |
---|
Selector | Description |
---|---|
#message-container |
The outer wrapper, containing the top bar, message list, and input bar |
#ada-close-button |
The button used to close the Web Chat window |
#input-bar |
The bottom wrapper, containg the textarea element, send button, and bottom text |
#message-input |
The textarea inside the input bar, used for user input |
#clear-message |
The button used to clear text from the message input |
#send-button |
The button for submitting the user input |
#status-bar |
The bottom text inside the input bar |
#close-info-button |
The button to close the settings modal |
#language-selector |
The language select container |
#language-picker |
The language select element |
#terms-of-service |
The terms of service link |
#privacy |
The privacy link |
#messages-list |
The messages container |
#topBar |
The top bar container above the message list |
#info-button |
The settings modal button |
.g-message |
The base message selector |
.g-message--is-owned-by-user |
The selector for messages from the end user |
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, styles: "*{font-size: 14px !important;}")
Can be used to pass the scheme name of the host app. This allows for more robust handling of universal links.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, appScheme: "my-app-scheme")
External web links now open by default in-app via the SFSafariViewController. To open external links in the Safari browser, pass openWebLinksInSafari: true
to AdaWebHost
.
Example:
var adaFramework = AdaWebHost(handle: “ada-example”, openWebLinksInSafari: true)
Launches Ada Chat in a modal view overtop your current view.
Example:
adaFramework.launchModalWebSupport(from: self)
Pushes a view containing Ada Chat to the top of your navigational stack.
Example:
adaFramework.launchNavWebSupport(from: navigationController)
Launches Ada Chat into a specified subview.
Example:
adaFramework.launchInjectingWebSupport(into: injectingView)
Used to set meta data for a chatter after instantiation. This is useful if you need to update user data after Ada Chat has already launched.
Example:
adaFramework.setMetaFields([
"firstName": "Jane",
"lastName": "Doe",
"tier": "pro"
])
Can be used to create a new chatter
and refresh the Chat window.
Example:
adaFramework.reset()
Deletes the chatter
used to fetch conversation logs for an end-user from storage. When a user opens a new Chat window a new chatter
will be generated.
Example:
adaFramework.deleteHistory();
Need some help? Get in touch with us at [email protected].