App Inbox is similar to an email inbox but is designed for direct messages from an app. As opposed to push notifications, it allows customers to keep promotions and browse a chronological list of messages at any time.
With the Reteno App Inbox, there is no default UI. This means with a few lines of code, you can connect Reteno with your inbox.
NoteApp Inbox is available in version 1.7.0 and later.
Downloading New Messages
// If  `page`  or  `pageSize`  is not specified, then all messages will be returned
final messages = await Reteno.appInbox.getAppInboxMessages();final messages = await Reteno.appInbox.getAppInboxMessages(
    page: 1,
    pageSize: 20,
);The result is an instance of the AppInboxMessages class:
class AppInboxMessages {
  final List<AppInboxMessage> messages;
  final int totalPages;
  AppInboxMessages({required this.messages, required this.totalPages});
}Reteno inbox message attributes:
class AppInboxMessage {
  final String id;
  final String title;
  final String createdDate;
  final bool isNewMessage;
  final String? content;
  final String? imageUrl;
  final String? linkUrl;
  final String? category;
}Get Inbox Unread Messages Count
final count = await Reteno.appInbox.getAppInboxMessagesCount();Subscribe on Inbox Unread Messages Count
Reteno.appInbox.onMessagesCountChanged.listen((count) {
    print(count);
});StreamBuilder<int>(
    stream: Reteno.appInbox.onMessagesCountChanged,
    builder: (context, snapshot) {
    if (snapshot.hasData) {
        return Text(snapshot.data.toString());
    }
    return const SizedBox.shrink();
    },
),Change Inbox Message Status on OPENED
OPENEDReteno.appInbox.markAsOpened(message.id);Also you can change all inbox messages status via single method without providing messages ids.
Reteno.appInbox.markAllMessagesAsOpened();