iOS UX Helper
Rokt UX Helper est un projet open source qui vous aide à rendre des expériences client magnifiques dans un environnement serveur à serveur. Vous pouvez trouver et contribuer au projet sur la page Github.
Ce document décrit le processus d'intégration de RoktUXHelper dans votre application iOS, qui fonctionne en parallèle avec l'intégration Server-to-Server (S2S) pour offrir des expériences pertinentes à vos clients lors de leur passage en caisse. Ce guide suppose que vous êtes familier avec UIKit/SwiftUI et les concepts de développement iOS de base.
| Système | Version |
|---|---|
| RoktUXHelper | 0.3.1 |
| iOS | 15.0+ |
| Gestionnaire de paquets | Swift Package Manager |
| Swift | 5+ |
| Xcode | 15+ |
Guide d'installationLien direct vers Guide d'installation
La bibliothèque est disponible en tant que dépendance Swift Package Manager (SPM). Pour l'installer, ajoutez la dépendance SPM suivante dans votre fichier package.json. Cette configuration garantit que votre application recevra les mises à jour de la bibliothèque jusqu'à, mais sans inclure, la prochaine version majeure.
dependencies: [
.package(url: "https://github.com/ROKT/rokt-ux-helper-ios.git", .upToNextMajor(from: "0.1.0"))
]
Importer les modules requisLien direct vers Importer les modules requis
Pour commencer à utiliser RoktLayoutView, vous devez importer les modules nécessaires dans votre contrôleur de vue ou classe.
import SwiftUI
import RoktUXHelper
Initialiser RoktLayoutViewLien direct vers Initialiser RoktLayoutView
La classe RoktLayoutView offre plusieurs options d'initialisation, permettant une flexibilité de configuration. Vous pouvez l'initialiser en passant les liaisons et paramètres requis comme experienceResponse, le nom de location, la config optionnelle, et les gestionnaires d'événements.
var body: some View {
RoktLayoutView(experienceResponse: "{experience_response_json}",
location: "RoktEmbedded1",
config: roktConfig,
onUXEvent: { uxEvent in
// Gérer les événements UX ici
},
onPlatformEvent: { platformEvent in
// Envoyer ces événements de plateforme à l'API Rokt
})
}
Événements UXLien direct vers Événements UX
Utilisez le gestionnaire onUXEvent pour recevoir des retours en temps réel sur les interactions utilisateur.
Au minimum, vous devez gérer l'événement RoktUXEvent.OpenUrl lorsqu'il est déclenché afin de pouvoir ouvrir le lien en utilisant l'exemple ci-dessous.
OpenUrl & onCloseLien direct vers OpenUrl & onClose
event.onClose?(event.id) est crucial à appeler après qu'une URL a été ouverte et notifiera le RoktUXHelper pour exécuter une logique comme passer à l'offre suivante.
onUXEvent: { uxEvent in // Gérer les événements UX ici
// Gérer l'événement d'ouverture d'URL
// Voici un exemple de comment ouvrir différents types d'URLs
if let event = uxEvent as? RoktUXEvent.OpenUrl,
let url = URL(string: event.url) {
switch event.type {
case .externally:
UIApplication.shared.open(url) { _ in
event.onClose?(event.id) // Cela doit être appelé lorsque l'utilisateur est prêt pour l'offre suivante
}
default:
let safariVC = SFSafariViewController(url: url)
safariVC.modalPresentationStyle = .overFullScreen
if let rootVC = UIApplication.shared.connectedScenes
.compactMap({ ($0 as? UIWindowScene)?.keyWindow }).last?.rootViewController {
rootVC.present(safariVC, animated: true, completion: {
event.onClose?(event.id) // Cela doit être appelé lorsque l'utilisateur est prêt pour l'offre suivante
})
}
}
}
},
Tous les événements
Événements UXLien direct vers Événements UX
| Événement | Description | Paramètres |
|---|---|---|
| OfferEngagement | Déclenché lorsque l'utilisateur interagit avec l'offre | layoutId: String |
| PositiveEngagement | Déclenché lorsque l'utilisateur interagit positivement avec l'offre | layoutId: String |
| LayoutInteractive | Déclenché lorsqu'une mise en page a été rendue et est interactive | layoutId: String |
| LayoutReady | Déclenché lorsqu'une mise en page est prête à être affichée mais n'a pas encore rendu le contenu | layoutId: String |
| LayoutClosed | Déclenché lorsqu'une mise en page est fermée par l'utilisateur | layoutId: String |
| LayoutCompleted | Déclenché lorsque la progression de l'offre atteint la fin et qu'aucune autre offre n'est disponible | layoutId: String |
| LayoutFailure | Déclenché lorsqu'une mise en page n'a pas pu être affichée en raison d'une défaillance | layoutId: String (optionnel) |
| OpenUrl | Déclenché lorsqu'un lien doit être ouvert | url: String, id: String, type: OpenURLType (internally/externally/passthrough), onClose: (String) -> Void, onError: (String: Error?) -> Void |
Envoyer des platformEvents à RoktLien direct vers Envoyer des platformEvents à Rokt
Les événements de plateforme (platform events) sont une partie essentielle de l'intégration et doivent être envoyés à Rokt via votre backend. Pour faciliter l'utilisation, platformEvent est défini comme [String: Any]
onPlatformEvent: { platformEvent in
// Envoyer ces événements de plateforme à l'API Rokt
},
Exemple de charge utile
{
"events":[
{
"instanceGuid":"6A764CDC-CCC5-4976-8121-5179E45757FB",
"eventTime":"2024-10-28T03:56:18.502Z",
"pageInstanceGuid":"",
"eventType":"SignalInitialize",
"sessionId":"DE110000-1000-1000-1000-100000000000",
"attributes":[
],
"metadata":[
{
"name":"clientTimeStamp",
"value":"2024-10-28T03:56:18.502Z"
},
{
"name":"captureMethod",
"value":"ClientProvided"
}
],
"token":"...",
"parentGuid":"b2170040-e74f-49db-819e-317ebd7f92ac"
}
],
"integration":{
"deviceLocale":"en_AU",
"version":"1.0",
"packageName":"com.rokt.roktuxhelperdemo.RoktUX-Demo",
"operatingSystemVersion":"17.5",
"deviceType":"Phone",
"platform":"iOS",
"operatingSystem":"iOS",
"deviceModel":"iPhone 16",
"packageVersion":"1.0",
"layoutSchemaVersion":"2.1.0",
"name":"UX Helper iOS",
"framework":"Swift"
}
}
Vous pouvez trouver une liste complète des événements ici.
RésuméLien direct vers Résumé
Intégrer RoktLayoutView dans votre application iOS est simple et offre une manière flexible de gérer les vues et les expériences. En suivant les étapes décrites dans ce guide, vous pouvez ajouter RoktLayoutView à votre projet et profiter pleinement des fonctionnalités puissantes offertes par RoktUXHelper.
var body: some View {
RoktLayoutView(
experienceResponse: "{experience_response_json}",
location: "RoktEmbedded1",
config: roktConfig,
onUXEvent: { uxEvent in
// Gérez les événements UX ici
if let event = uxEvent as? RoktUXEvent.OpenUrl,
let url = URL(string: event.url) {
switch event.type {
case .externally:
UIApplication.shared.open(url) { _ in
event.onClose?(event.id)
}
default:
let safariVC = SFSafariViewController(url: url)
safariVC.modalPresentationStyle = .overFullScreen
if let rootVC = UIApplication.shared.connectedScenes
.compactMap({ ($0 as? UIWindowScene)?.keyWindow }).last?.rootViewController {
rootVC.present(safariVC, animated: true, completion: {
event.onClose?(event.id)
})
}
}
}
},
onPlatformEvent: { platformEvent in
// Envoyez ces événements de plateforme à l'API Rokt
}
)
}
Optionnel : Configurations de l'applicationLien direct vers Optionnel : Configurations de l'application
RoktUXConfig permet aux applications partenaires de fournir des paramètres de configuration personnalisés depuis leur environnement applicatif. Cela permet à RoktUXHelper d'appliquer ces configurations, offrant plus de flexibilité et de contrôle sur l'expérience utilisateur, plutôt que de se fier exclusivement aux paramètres par défaut du système.
// si l'application ne prend en charge que le mode clair.
let roktConfig = RoktUXConfig.builder()
.colorMode(.light)
.imageLoader(imageLoader)
.build()
Objet ColorModeLien direct vers Objet ColorMode
| Valeur | Description |
|---|---|
| light | L'application est en mode clair |
| dark | L'application est en mode sombre |
| system | L'application utilise le mode couleur du système par défaut |
RoktUXImageLoaderLien direct vers RoktUXImageLoader
Rokt UX Helper accepte un RoktUXImageLoader optionnel pour offrir aux partenaires une flexibilité sur le téléchargement des images. Dans l'exemple RoktUXImageLoaderImpl, les images sont récupérées de manière asynchrone à partir d'une URL en utilisant URLSession et retournées via un gestionnaire de complétion. Si aucun ImageLoader n'est fourni, RoktUXHelper utilise par défaut AsyncImage de SwiftUI.
import UIKit
import RoktUXHelper
class RoktUXImageLoaderImpl : RoktUXImageLoader {
func loadImage(urlString: String, completion: @escaping (Result<UIImage?, any Error>) -> Void) {
guard let url = URL(string: urlString) else { return }
let task = URLSession.shared.dataTask(with: url) { data, response, error in
guard let data = data else { return }
DispatchQueue.main.async {
completion(.success(UIImage(data: data)))
}
}
task.resume()
}
}
Polices de caractèresLien direct vers Polices de caractères
Rokt UX Helper pourra utiliser des polices de caractères personnalisées en les enregistrant simplement dans votre projet et en les configurant sur votre compte Rokt dans One Platform.
Guide d'installationLien direct vers Guide d'installation
La bibliothèque est disponible en tant que dépendance Swift Package Manager (SPM). Pour l'installer, ajoutez la dépendance SPM suivante dans votre fichier package.json. Cette configuration garantit que votre application recevra les mises à jour de la bibliothèque jusqu'à, mais sans inclure, la prochaine version majeure.
dependencies: [
.package(url: "https://github.com/ROKT/rokt-ux-helper-ios.git", .upToNextMajor(from: "0.1.0"))
]
Importer les modules requisLien direct vers Importer les modules requis
Pour commencer à utiliser RoktLayoutUIView, vous devez importer les modules nécessaires dans votre contrôleur de vue ou classe.
import UIKit
import RoktUXHelper
Initialiser RoktLayoutUIViewLien direct vers Initialiser RoktLayoutUIView
La classe RoktLayoutUIView offre plusieurs options d'initialisation, permettant une flexibilité de configuration. Vous pouvez l'initialiser avec un experienceResponse, un nom de location et des paramètres de configuration optionnels tels que RoktUXConfig, ainsi que des gestionnaires d'événements.
func loadRokt() {
let experienceResponse = "{experience_response_json}"
let roktView = RoktLayoutUIView(
experienceResponse: experienceResponse,
location: "RoktEmbedded1",
config: roktConfig,
onUXEvent: { uxEvent in
// Gérer les événements UX ici
},
onPlatformEvent: { platformEvent in
// Envoyer ces événements de plateforme à l'API Rokt
},
onEmbeddedSizeChange: { newSize in
// Gérer les changements de taille de la vue si nécessaire
}
)
}
Ajouter la Vue à Votre Mise en PageLien direct vers Ajouter la Vue à Votre Mise en Page
Une fois initialisée, vous devez ajouter le RoktLayoutUIView à votre hiérarchie de vues. Vous pouvez le faire par programmation dans votre contrôleur de vue en définissant des contraintes ou en positionnant manuellement.
// Ajouter le RoktLayoutUIView à la hiérarchie de vues
self.view.addSubview(roktView)
// Définir les contraintes pour positionner le RoktLayoutUIView
roktView.translatesAutoresizingMaskIntoConstraints = false
NSLayoutConstraint.activate([
roktView.topAnchor.constraint(equalTo: self.view.topAnchor),
roktView.leadingAnchor.constraint(equalTo: self.view.leadingAnchor),
roktView.trailingAnchor.constraint(equalTo: self.view.trailingAnchor),
// Ajuster le reste si nécessaire
])
Événements UXLien direct vers Événements UX
Utilisez le gestionnaire onUXEvent pour recevoir des retours en temps réel sur les interactions utilisateur.
Au minimum, vous devez gérer lorsque l'événement RoktUXEvent.OpenUrl est déclenché afin de pouvoir ouvrir le lien en utilisant l'exemple ci-dessous.
OpenUrl & onCloseLien direct vers OpenUrl & onClose
event.onClose?(event.id) est essentiel à appeler après qu'une URL a été ouverte et notifiera le RoktUXHelper pour exécuter une logique comme passer à l'offre suivante.
onUXEvent: { uxEvent in // Gérer les événements UX ici
// Gérer l'événement d'ouverture d'URL
// Voici un exemple de comment ouvrir différents types d'URLs
if let event = uxEvent as? RoktUXEvent.OpenUrl,
let url = URL(string: event.url){
switch event.type {
case .externally:
UIApplication.shared.open(url) { _ in
event.onClose?(event.id) // Cela doit être appelé lorsque l'utilisateur est prêt pour l'offre suivante
}
default:
let safariVC = SFSafariViewController(url: url)
safariVC.modalPresentationStyle = .overFullScreen
self.present(safariVC, animated: true, completion: {
event.onClose?(event.id) // Cela doit être appelé lorsque l'utilisateur est prêt pour l'offre suivante
})
}
}
},
Tous les événements
Événements UXLien direct vers Événements UX
| Événement | Description | Paramètres |
|---|---|---|
| OfferEngagement | Déclenché lorsque l'utilisateur interagit avec l'offre | layoutId: String |
| PositiveEngagement | Déclenché lorsque l'utilisateur interagit positivement avec l'offre | layoutId: String |
| LayoutInteractive | Déclenché lorsqu'une mise en page a été rendue et est interactive | layoutId: String |
| LayoutReady | Déclenché lorsqu'une mise en page est prête à être affichée mais n'a pas encore rendu le contenu | layoutId: String |
| LayoutClosed | Déclenché lorsqu'une mise en page est fermée par l'utilisateur | layoutId: String |
| LayoutCompleted | Déclenché lorsque la progression de l'offre atteint la fin et qu'aucune autre offre n'est disponible | layoutId: String |
| LayoutFailure | Déclenché lorsqu'une mise en page n'a pas pu être affichée en raison d'une défaillance | layoutId: String (optionnel) |
| OpenUrl | Déclenché lorsqu'un lien doit être ouvert | url: String, id: String, type: OpenURLType (internally/externally/passthrough), onClose: (String) -> Void, onError: (String: Error?) -> Void |
Envoyer des platformEvents à RoktLien direct vers Envoyer des platformEvents à Rokt
Les événements de plateforme (platform events) sont une partie essentielle de l'intégration et doivent être envoyés à Rokt via votre backend. Pour faciliter l'utilisation, platformEvent est défini comme [String: Any]
onPlatformEvent: { platformEvent in
// Envoyer ces événements de plateforme à l'API Rokt
},
Exemple de charge utile
{
"events":[
{
"instanceGuid":"6A764CDC-CCC5-4976-8121-5179E45757FB",
"eventTime":"2024-10-28T03:56:18.502Z",
"pageInstanceGuid":"",
"eventType":"SignalInitialize",
"sessionId":"DE110000-1000-1000-1000-100000000000",
"attributes":[
],
"metadata":[
{
"name":"clientTimeStamp",
"value":"2024-10-28T03:56:18.502Z"
},
{
"name":"captureMethod",
"value":"ClientProvided"
}
],
"token":"...",
"parentGuid":"b2170040-e74f-49db-819e-317ebd7f92ac"
}
],
"integration":{
"deviceLocale":"en_AU",
"version":"1.0",
"packageName":"com.rokt.roktuxhelperdemo.RoktUX-Demo",
"operatingSystemVersion":"17.5",
"deviceType":"Phone",
"platform":"iOS",
"operatingSystem":"iOS",
"deviceModel":"iPhone 16",
"packageVersion":"1.0",
"layoutSchemaVersion":"2.1.0",
"name":"UX Helper iOS",
"framework":"Swift"
}
}
Vous pouvez trouver une liste complète des événements ici.
RésuméLien direct vers Résumé
Intégrer RoktLayoutUIView dans votre application iOS est simple et offre une manière flexible de gérer les vues et les expériences. En suivant les étapes décrites dans ce guide, vous pouvez ajouter RoktLayoutUIView à votre projet et profiter pleinement des fonctionnalités puissantes offertes par RoktUXHelper.
import UIKit
import RoktUXHelper
import SafariServices
class ViewController: UIViewController {
// Implémentation de RoktUXImageLoader pour télécharger des images
let imageLoader: RoktUXImageLoader = RoktUXImageLoaderImpl()
lazy var roktConfig = RoktUXConfig.builder().imageLoader(imageLoader).build()
override func viewDidLoad() {
super.viewDidLoad()
loadRokt()
}
func loadRokt() {
let experienceResponse = "{experience_response_json}"
let roktView = RoktLayoutUIView(
experienceResponse: experienceResponse,
location: "RoktEmbedded1",
config: roktConfig,
onUXEvent: { uxEvent in // Gérer les événements UX ici
// Gérer l'événement d'ouverture d'URL
// Voici un exemple de comment ouvrir différents types d'URLs
if let event = uxEvent as? RoktUXEvent.OpenUrl,
let url = URL(string: event.url){
switch event.type {
case .externally:
UIApplication.shared.open(url) { _ in
event.onClose?(event.id)
}
default:
let safariVC = SFSafariViewController(url: url)
safariVC.modalPresentationStyle = .overFullScreen
self.present(safariVC, animated: true, completion: {
event.onClose?(event.id)
})
}
}
},
onPlatformEvent: { platformEvent in
// Envoyer ces événements de plateforme à l'API Rokt
},
onEmbeddedSizeChange: { newSize in
// Gérer les changements de taille de vue si nécessaire
}
)
self.view.addSubview(roktView)
// Ajouter le RoktLayoutUIView à la hiérarchie de vues
roktView.translatesAutoresizingMaskIntoConstraints = false
// Définir les contraintes pour positionner le RoktLayoutUIView
```swift
NSLayoutConstraint.activate([
roktView.topAnchor.constraint(equalTo: self.view.topAnchor),
roktView.leadingAnchor.constraint(equalTo: self.view.leadingAnchor),
roktView.trailingAnchor.constraint(equalTo: self.view.trailingAnchor),
// Ajustez le reste si nécessaire
])
}
class RoktUXImageLoaderImpl : RoktUXImageLoader {
func loadImage(urlString: String, completion: @escaping (Result<UIImage?, any Error>) -> Void) {
guard let url = URL(string: urlString) else { return }
let task = URLSession.shared.dataTask(with: url) { data, response, error in
guard let data = data else { return }
DispatchQueue.main.async {
completion(.success(UIImage(data: data)))
}
}
task.resume()
}
}
}
Optionnel : Configurations de l'applicationLien direct vers Optionnel : Configurations de l'application
RoktUXConfig permet aux applications partenaires de fournir des paramètres de configuration personnalisés depuis leur environnement applicatif. Cela permet à RoktUXHelper d'appliquer ces configurations, offrant plus de flexibilité et de contrôle sur l'expérience utilisateur, plutôt que de se fier exclusivement aux paramètres par défaut du système.
// si l'application ne prend en charge que le mode clair.
let roktConfig = RoktUXConfig.builder()
.colorMode(.light)
.imageLoader(imageLoader)
.build()
Objet ColorModeLien direct vers Objet ColorMode
| Valeur | Description |
|---|---|
| light | L'application est en mode clair |
| dark | L'application est en mode sombre |
| system | L'application utilise le mode couleur du système par défaut |
RoktUXImageLoaderLien direct vers RoktUXImageLoader
Rokt UX Helper accepte un RoktUXImageLoader optionnel pour offrir aux partenaires une flexibilité sur le téléchargement des images. Dans l'exemple RoktUXImageLoaderImpl, les images sont récupérées de manière asynchrone à partir d'une URL en utilisant URLSession et retournées via un gestionnaire de complétion. Si aucun ImageLoader n'est fourni, RoktUXHelper utilise par défaut AsyncImage de SwiftUI.
import UIKit
import RoktUXHelper
class RoktUXImageLoaderImpl : RoktUXImageLoader {
func loadImage(urlString: String, completion: @escaping (Result<UIImage?, any Error>) -> Void) {
guard let url = URL(string: urlString) else { return }
let task = URLSession.shared.dataTask(with: url) { data, response, error in
guard let data = data else { return }
DispatchQueue.main.async {
completion(.success(UIImage(data: data)))
}
}
task.resume()
}
}
Polices de caractèresLien direct vers Polices de caractères
Rokt UX Helper pourra utiliser des polices de caractères personnalisées en les enregistrant simplement dans votre projet et en les configurant sur votre compte Rokt dans One Platform.