Zum Inhalt springen

InboxKit mit CocoaPods einrichten

Verfügbar seit iOS SDK 7.0.40.

InboxKit wird als optionaler Subspec des übergeordneten PushwooshXCFramework-Pods ausgeliefert. Das Haupt-SDK muss bereits integriert sein. Wenn Sie bei Null anfangen, folgen Sie zuerst der Anleitung zur Basisin-Integration.

Den InboxKit-Pod hinzufügen

Anchor link to
  1. Öffnen Sie Ihre Podfile-Datei und fügen Sie den InboxKit-Subspec zu Ihrem App-Ziel hinzu:
target 'MyApp' do
use_frameworks!
pod 'PushwooshXCFramework'
pod 'PushwooshXCFramework/PushwooshInboxKit'
end
  1. Führen Sie pod install in Ihrem Projektverzeichnis aus:
Terminal window
pod install
  1. Öffnen Sie die generierte .xcworkspace-Datei. InboxKit ist nun neben dem Haupt-SDK verknüpft.

Die Inbox anzeigen

Anchor link to

Fügen Sie den Inbox-Controller zu einem beliebigen Navigationsfluss hinzu. Die Standardkonfiguration reicht aus, um eine funktionierende Inbox mit den drei Standard-Zelltypen zu erhalten:

import PushwooshInboxKit
let inboxVC = PushwooshInboxKitViewController()
navigationController?.pushViewController(inboxVC, animated: true)

Die Inbox anpassen

Anchor link to

In Swift konfigurieren Sie den Controller über den Werttyp PushwooshInboxKitAttributes. In Objective-C verwenden Sie die @objc-freundlichen Setter auf dem Controller – PushwooshInboxKitAttributes ist eine Swift-Struktur und wird nicht überbrückt.

var attributes = PushwooshInboxKitAttributes()
attributes.pullToRefreshEnabled = true
attributes.swipeToDeleteEnabled = true
attributes.pinningEnabled = true
attributes.style.unreadBadgeColor = .systemBlue
attributes.style.titleFont = .systemFont(ofSize: 17, weight: .semibold)
let inboxVC = PushwooshInboxKitViewController(attributes: attributes)

Die Style-Struktur legt alle Farben, Schriftarten, Eckradien und den Datumsformatierer offen, die von den Standardzellen verwendet werden. Jeder Wert ist standardmäßig eine semantische Farbe von Apple, sodass die Inbox automatisch auf den systemweiten Dunkelmodus reagiert.

Benutzerdefinierter InboxKit-Feed mit Markenfarben für Titel und Ungelesen-Anzeige

Zelle mit Beschriftung und einem benutzerdefinierten Thema, das über PushwooshInboxKitAttributes.Style angewendet wurde.

Taps und Aktualisierungen handhaben

Anchor link to

Konformieren Sie mit PushwooshInboxKitDelegate, um auf Benutzeraktionen und Aktualisierungsereignisse zu reagieren. Jede Methode hat eine Standardimplementierung, sodass Sie nur das überschreiben, was Sie benötigen:

final class InboxCoordinator: NSObject, PushwooshInboxKitDelegate {
func inboxKit(_ vc: PushwooshInboxKitViewController,
didSelect message: PWInboxMessageProtocol) -> Bool {
// Geben Sie true zurück, damit das SDK die Nachrichten-URL oder Rich Media öffnet.
// Geben Sie false zurück, wenn Sie den Tap vollständig selbst behandelt haben (z. B. auf einen benutzerdefinierten Bildschirm weitergeleitet haben).
return true
}
func inboxKit(_ vc: PushwooshInboxKitViewController,
didRefreshWith messages: [PWInboxMessageProtocol],
error: Error?) {
// Zeigen Sie hier bei Bedarf Ihren eigenen Leer- oder Fehlerzustand an.
}
}
inboxVC.delegate = inboxCoordinator

Das SDK liefert Massenoperationen als @objc-Methoden auf dem Controller, sodass Sie sie direkt mit einem UIBarButtonItem verbinden können:

let markAll = UIBarButtonItem(
image: UIImage(systemName: "checkmark.circle"),
style: .plain,
target: inboxVC,
action: #selector(PushwooshInboxKitViewController.markAllAsRead)
)
let clearRead = UIBarButtonItem(
image: UIImage(systemName: "trash"),
style: .plain,
target: inboxVC,
action: #selector(PushwooshInboxKitViewController.clearReadMessages)
)
inboxVC.navigationItem.rightBarButtonItems = [clearRead, markAll]

Nächste Schritte

Anchor link to