This page provides you with information on In-app messaging feature.
The In-app messaging targets users by displaying messages while they are using your app. These messages are highly effective in providing contextual information and facilitating cross-selling/up-selling on specific screens or actions within your app.
Prerequisites
- HydraPushNotification framework: Manages in-app messages.
- HydraInAppMessaging framework: Handles silent remote notifications (in-app messages).
Integration
Add the HydraInAppMessage framework. This framework is responsible for processing in-app messages.
Initialize InAppMessagingCore object
Initialize the InAppMessagingCore object and create an instance of the InboxCore using the following method:
public init(with config: HydraInAppMessageConfigGenerator, environment env: Env = .dev) throws
Parameter | Type | Mandatory/Optional | Description |
---|---|---|---|
config | HydraInAppMessageConfigGenerator | Compulsory | An object of class conforming to HydraInAppMessageConfigGenerator protocol |
env | Environment | Optional | Either .dev or .unittest |
HydraInAppMessageConfigGenerator
This value is required and can be generated using the following protocol:
public protocol HydraInAppMessageConfigGenerator {
var hydraConfig: ConfigurationGenerator { get set }
var notificationCore: NotificationCore? { get set }
var placeholderImage: UIImage? { get set }
var appStoreId: String? { get set }
}
Parameter | Type | Mandatory/Optional | Description |
---|---|---|---|
hydraConfig | ConfigurationGenerator | Compulsory | An instance of Hydra core. |
notificationCore | NotificationCore | Optional | An instance of Notification core. |
placeholderImage | UIImage | Optional | An object of UIImage class. |
appStoreId | String | Optional | Application's app store id. |
Example:
let config = try HydraConfiguration(accountID: "AccountID", customerId: "CustomerID", server: .server1)
guard let hydra = try? Hydra.generate(with: config) else {
Logger.error("Error in configuration generation")
return nil
}
Logger.updateLogLevel(level: .critical)
do {
let inAppConfig = HydraInAppMessageConfiguration(hydraConfig: config, notificationCore: notificationCore, appStoreId: "", placeholderImage: nil)
inAppCore = try InAppMessagingCore(with: inAppConfig, environment: .dev)
} catch let error {
print(error)
}
InApp-supported layouts
data:image/s3,"s3://crabby-images/07924/0792419e47222af8b28ff4c8b9344560fe07f820" alt="App rating"
App rating
data:image/s3,"s3://crabby-images/978d0/978d0bb938509cef0e3da421e0cbb5e72b8becdb" alt="Feedback"
Feedback
data:image/s3,"s3://crabby-images/8d01b/8d01b8ffa43d806761ebcb6e8af3eb541f647686" alt="Footer"
Footer
data:image/s3,"s3://crabby-images/0796b/0796b248d05cb887a75682fb105465b208ae5686" alt="Header"
Header
data:image/s3,"s3://crabby-images/e6aec/e6aec6b0d84c62e90bfb391b199d3de47605d4ad" alt="Interstitial"
Interstitial
data:image/s3,"s3://crabby-images/fd7d8/fd7d8a6863efaa8a44508ae4497cddcdee13231c" alt="Pop up"
Pop up
data:image/s3,"s3://crabby-images/b80ba/b80ba9ec422546ffe1b2cfdd46d52d84c17852b7" alt="Rating"
Rating