Skip to content
This repository has been archived by the owner on Jan 5, 2023. It is now read-only.

Latest commit

 

History

History
391 lines (293 loc) · 11.9 KB

README.md

File metadata and controls

391 lines (293 loc) · 11.9 KB

⚠️ Deprecated ⚠️

This SDK has been deprecated and is no longer maintained. Please reach to [email protected] if you want to integrate with the Thanx platform.

Thanx iOS SDK

The Thanx iOS SDK provides a simple way to embed the Thanx customer engagement experience in iOS applications.

Delivery

The SDK will be delivered as a native Swift library distributed via the package manager Cocoapods.

Authentication

Merchant

Thanx will provide the SDK Client ID and a Client Secret via a secure channel.

Authentication of the SDK should be done with the provided SDK Client ID and  Client Secret. The developer should initialize the SDK when the app launches with those values.

User

This SDK supports user authentication via access token or user login.

Access Token Authentication:

If an access token is provided on SDK initialization, the user and SDK will be automatically authenticated.

Manual Authentication:

If no access token is provided on SDK initialization, a login form will be displayed to the user in the webview where they will be prompted to login or create an account.

Post Authentication

After authentication is completed through either mechanism, the user's details (email, firstName, lastName) will be accessible via the SDK.

Push Notifications

Thanx will need the push services certificate in order to send Loyalty related push notifications to the user. The Thanx team will work with the Merchant to provide a mechanism for securely exchanging this information.

In the app, after the developer asks for push notifications permissions and the user accepts, the developer should send the push registration token to the SDK so the user gets the loyalty related push notifications that the Thanx platform offers.

User Experience

Web flows

Thanx SDK user experience will be web based. When the user launches the rewards, they'll be presented with a web view that will load the Thanx platform. There, the user will be able to see and redeem rewards and link cards in order to accrue progress when shopping at the stores.

Integration Testing

The SDK will provide an option to run in test mode. In that mode, the web view and the API will point to a dev environment where the developer will be able to test the integration without affecting production data (more details when SDK is delivered).

Installation

Via Cocoapods

The ThanxSDK pod lives in Thanx's Spec repo, for this reason, the first thing you need to add to your Podfile is the repo url as a new source:

# Podfile
source 'https://github.com/thanx/Specs.git'

Then you can include the ThanxSDK pod as one of your dependencies:

# Podfile
source 'https://github.com/thanx/Specs.git'

target 'Your App' do
  use_frameworks!

  # Thanx SDK pod
  pod 'ThanxSDK'

  # ... Other dependencies ...
end

The SDK uses the camera and photo library in order to upload receipts so make sure to add the following in your plist:

<key>NSCameraUsageDescription</key>
<string>This app requests access to your camera and photo library to allow you to easily add credit cards (by reading them with your camera) as well as upload photos of receipts.</string>
<key>NSPhotoLibraryUsageDescription</key>
<string>This app requests access to your camera and photo library to allow you to easily add credit cards (by reading them with your camera) as well as upload photos of receipts.</string>

Initialization

You should initialize the SDK in the AppDelegate file of your project:

  1. Import the SDK at the top of the file: import ThanxSDK
  2. Call Thanx.initialize on the application:didFinishLaunchingWithOptions method

Swift:

// AppDelegate.swift
import ThanxSDK

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

  var window: UIWindow?

  func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?
  ) -> Bool {
    // Automatic User Authentication
    Thanx.initialize(accessToken: "USER_ACCESS_TOKEN", debug: true)
    // Manual User Authentication
    Thanx.initialize(clientId: "YOUR_CLIENT_ID", clientSecret: "YOUR_CLIENT_SECRET", debug: true)
    return true
  }
}

The Thanx SDK is now initialized and ready for use.

Make sure to set debug: false for production builds.

Launching the Thanx experience

The Thanx SDK provides the WebViewController with the full Thanx mobile experience. The UIViewController can be presented in any way. Example:

Swift:

// UIViewController.swift
# Present it as a full screen modal
let thanxWebViewController = Thanx.WebViewController(showToolbar: true)
present(thanxWebViewController, animated: true)

# Present it as a part of a UINavigationController
let thanxWebViewController = Thanx.WebViewController(showToolbar: false)
navigationController?.pushViewcontroller(thanxWebViewController, animated: true)

Loading Callbacks

Callbacks are provided as a protocol in order to know when the Thanx SDK mobile experience is loading.

@objc public protocol WebViewControllerDelegate: class {
  // Callback triggered when the initial load starts
  @objc optional func didStartInitialLoading(url: URL?)

  // Callback triggered when any load starts (including the initial load)
  // Note: It might be triggered multiple times for the same page
  @objc optional func didStartLoading(url: URL?)

  // Callback triggered when the initial load finishes
  @objc optional func didFinishInitialLoading(url: URL?)

  // Callback triggered when any load finishes (including the initial load)
  // Note: It might be triggered multiple times for the same page
  @objc optional func didFinishLoading(url: URL?)
}

You need to initialize the WebViewController with the delegate parameter:

thanxWebViewController = Thanx.WebViewController(showToolbar: true, delegate: self)
present(thanxWebViewController, animated: true)

And then implement the protocol:

extension ViewController: WebViewControllerDelegate {
  public func didStartInitialLoading(url: URL?) {
    // Callback triggered when the initial load starts
    // E.g. show loading spinner
  }

  public func didFinishInitialLoading(url: URL?) {
    // Callback triggered when the initial load finishes
    // E.g. hide loading spinner
  }

  public func didStartLoading(url: URL?) {
    // Callback triggered when any load starts (including the initial load)
    // Note: It might be triggered multiple times for the same page
  }

  public func didFinishLoading(url: URL?) {
    // Callback triggered when any load finishes (including the initial load)
    // Note: It might be triggered multiple times for the same page
  }
}

Push Notifications

Device Token Registration

Thanx will send some push notifications to the user to remind him/her about their progress towards their reward, to leave feedback, and when they achieve a new reward. To make it work, the SDK needs to be notified about the device token whenever the user registers a new device for push notifications:

Swift:

// AppDelegate.swift
import ThanxSDK

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
  func application(
    _ application: UIApplication,
    didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data
  ) {
    Thanx.registerForNotifications(token: deviceToken)
  }
}

Push Notification Landing Screens

Thanx also delivers some contextual landing screens for most of the push notifications. These screens are meant to give a bit more context to the user about what just happened with their rewards and also contain very engaging call to actions with very high yield (for example, to leave feedback about the most recent visit). In order to enable these landing screens, the SDK needs to be notified every time a new push notification arrives.

Swift:

// AppDelegate.swift
import ThanxSDK

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
  func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?
  ) -> Bool {
    // Make sure that the SDK is initialized before launching the WebViewController
    Thanx.initialize(clientId: "YOUR_CLIENT_ID", clientSecret: "YOUR_CLIENT_SECRET", debug: true) { error in
      guard error == nil else { return }
      if let notificationPayload = launchOptions?[UIApplicationLaunchOptionsKey.remoteNotification] as? [AnyHashable: Any] {
        // Initialize the WebViewController with the notification payload from launchOptions?[UIApplicationLaunchOptionsKey.remoteNotification]
        let webViewController = Thanx.WebViewController(showToolbar: true, notificationPayload: notificationPayload)
        // Present the WebViewController however you want
        window?.rootViewController?.present(webViewController, animated: true)
      }
    }
    return true
  }
}
Make sure that the SDK is initialized before presenting the WebViewController

App Store Rating Prompt

The default app rating prompt will display automatically after using a reward (or activating it if is a statement credit reward) based on Apple's displaying rules noted in their documentation.

In order to disable automatically displaying the prompt, add the following line after SDK initialization:

# SDK initialization
Thanx.initialize(accessToken: "token")
# Disable App Store rate prompt after reward redemption
Thanx.displayRatePrompt(false)

Debug Mode

In order to run the SDK in debug mode, you'll need to initialize it with the debug flag as true:

// AppDelegate.swift
Thanx.initialize(clientId: "YOUR_CLIENT_ID", clientSecret: "YOUR_CLIENT_SECRET", debug: true)
// or
Thanx.initialize(accessToken: "USER_ACCESS_TOKEN", debug: true)

Running the SDK in debug will provide you with extra console output and most importantly, it will point to the Thanx Staging environment.

You should always run in Debug mode unless is a production build.

Class Reference

//! Project version number for ThanxSDK.
public var ThanxSDKVersionNumber: Double
public struct Thanx { }

extension Thanx {
  /// ViewController with the Thanx experience as a WebView
  public class WebViewController : UIViewController {
    /**
    Initializes the WebViewController to display the Thanx experience within a WKWebView

    - Parameters:
    - showToolbar: Whether or not to display the toolbar (You might want to display it when ViewController is
    presented as a full screen modal)
    */
    public convenience init(showToolbar: Bool)
  }
}

extension Thanx {
  public typealias LoginCallback = (ThanxSDK.Thanx.User?, Error?) -> ()

  /// The authenticated user
  public static var user: ThanxSDK.Thanx.User?

  /// Whether or not the user is authenticated.
  public static var authenticated: Bool

  /**
  Logs the user out

  - Parameters:
  - completion: Callback fired after log out has completed
  */
  public static func logout(completion: (() -> ())? = default)
}

extension Thanx {
  /// Whether or not the SDK has been initialized
  public static var initialized: Bool { get }

  /**
  Initializes the SDK with the client ID and client secret provided.

  - Parameters:
  - clientId: Your SDK client ID
  - clientSecret: Your SDK client secret
  - debug: Whether or not to run the SDK in debug mode
  - accessToken: User Access Token
  - completion: Callback fired when the initialization has been completed
  */
  public static func initialize(
    clientId: String,
    clientSecret: String,
    debug: Bool = default,
    accessToken: String? = default,
    completion: ((Error?) -> ())? = default
  )
}

extension Thanx {
  public class User {
    public let firstName: String!

    public let lastName: String!

    public let email: String!
  }
}