mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-21 09:02:44 +02:00
Setup a dedicated listener owned by PresenceIndicatorView
This commit is contained in:
@@ -45,6 +45,7 @@ final class RoomInfoListViewModel: NSObject, RoomInfoListViewModelType {
|
||||
encryptionImage: encryptionImage,
|
||||
isEncrypted: room.summary.isEncrypted,
|
||||
isDirect: room.isDirect,
|
||||
directUserId: room.directUserId,
|
||||
directUserPresence: directUserPresence)
|
||||
|
||||
return RoomInfoListViewData(numberOfMembers: Int(room.summary.membersCount.joined),
|
||||
@@ -58,12 +59,10 @@ final class RoomInfoListViewModel: NSObject, RoomInfoListViewModelType {
|
||||
self.room = room
|
||||
super.init()
|
||||
startObservingSummaryChanges()
|
||||
startObservingPresenceChanges()
|
||||
}
|
||||
|
||||
deinit {
|
||||
stopObservingSummaryChanges()
|
||||
stopObservingPresenceChanges()
|
||||
}
|
||||
|
||||
// MARK: - Public
|
||||
@@ -91,27 +90,11 @@ final class RoomInfoListViewModel: NSObject, RoomInfoListViewModelType {
|
||||
NotificationCenter.default.removeObserver(self, name: .mxRoomSummaryDidChange, object: nil)
|
||||
}
|
||||
|
||||
private func startObservingPresenceChanges() {
|
||||
NotificationCenter.default.addObserver(self, selector: #selector(presenceUpdated(_:)), name: .mxkContactManagerMatrixUserPresenceChange, object: nil)
|
||||
}
|
||||
|
||||
private func stopObservingPresenceChanges() {
|
||||
NotificationCenter.default.removeObserver(self, name: .mxkContactManagerMatrixUserPresenceChange, object: nil)
|
||||
}
|
||||
|
||||
@objc private func roomSummaryUpdated(_ notification: Notification) {
|
||||
// force update view
|
||||
self.update(viewState: .loaded(viewData: viewData))
|
||||
}
|
||||
|
||||
@objc private func presenceUpdated(_ notification: NSNotification) {
|
||||
guard let updatedUserId = notification.object as? String, updatedUserId == room.directUserId else {
|
||||
return
|
||||
}
|
||||
|
||||
self.update(viewState: .loaded(viewData: viewData))
|
||||
}
|
||||
|
||||
private func loadData() {
|
||||
self.update(viewState: .loaded(viewData: viewData))
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user