mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-26 11:30:50 +02:00
Address comments, show unencrypted rooms,
retain viewModel and services in ScreenSates so you can interact with Previews after the first state.
This commit is contained in:
+28
-35
@@ -26,9 +26,11 @@ class TemplateRoomChatService: TemplateRoomChatServiceProtocol {
|
||||
|
||||
private let room: MXRoom
|
||||
private let eventFormatter: EventFormatter
|
||||
private var roomState: MXRoomState?
|
||||
private var timeline: MXEventTimeline?
|
||||
private var eventBatch: [MXEvent]
|
||||
private var roomListenerReference: Any?
|
||||
|
||||
|
||||
// MARK: Public
|
||||
private(set) var chatMessagesSubject: CurrentValueSubject<[TemplateRoomChatMessage], Never>
|
||||
private(set) var roomInitializationStatus: CurrentValueSubject<TemplateRoomChatRoomInitializationStatus, Never>
|
||||
@@ -43,7 +45,7 @@ class TemplateRoomChatService: TemplateRoomChatServiceProtocol {
|
||||
self.eventFormatter = EventFormatter(matrixSession: room.mxSession)
|
||||
self.chatMessagesSubject = CurrentValueSubject([])
|
||||
self.roomInitializationStatus = CurrentValueSubject(.notInitialized)
|
||||
|
||||
self.eventBatch = [MXEvent]()
|
||||
initializeRoom()
|
||||
}
|
||||
|
||||
@@ -61,35 +63,31 @@ class TemplateRoomChatService: TemplateRoomChatServiceProtocol {
|
||||
// MARK: Private
|
||||
|
||||
private func initializeRoom(){
|
||||
room.state { [weak self] roomState in
|
||||
guard let self = self else { return }
|
||||
if let roomState = roomState {
|
||||
self.roomState = roomState
|
||||
self.roomInitializationStatus.value = .initialized
|
||||
self.loadInitialMessages()
|
||||
self.startListeningToRoomEvents()
|
||||
} else {
|
||||
self.roomInitializationStatus.value = .failedToInitialize
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private func loadInitialMessages() {
|
||||
let batch = room.enumeratorForStoredMessages.nextEventsBatch(200)
|
||||
let messageBatch = self.mapChatMessages(from: batch ?? [])
|
||||
self.chatMessagesSubject.value = messageBatch
|
||||
}
|
||||
|
||||
private func startListeningToRoomEvents(){
|
||||
roomListenerReference = room.listen { [weak self] event, directionId, roomState in
|
||||
let direction = MXTimelineDirection(identifer: directionId)
|
||||
room.liveTimeline { [weak self] timeline in
|
||||
guard let self = self,
|
||||
let event = event else { return }
|
||||
if let roomState = roomState {
|
||||
self.roomState = roomState
|
||||
let timeline = timeline
|
||||
else {
|
||||
return
|
||||
}
|
||||
if direction == .forwards && event.type == kMXEventTypeStringRoomMessage {
|
||||
self.appendNewMessage(event: event)
|
||||
self.timeline = timeline
|
||||
timeline.resetPagination()
|
||||
self.roomListenerReference = timeline.listenToEvents([.roomMessage], { [weak self] event, direction, roomState in
|
||||
guard let self = self else { return }
|
||||
if direction == .backwards {
|
||||
self.eventBatch.append(event)
|
||||
} else {
|
||||
self.chatMessagesSubject.value += self.mapChatMessages(from: [event])
|
||||
}
|
||||
|
||||
})
|
||||
timeline.paginate(200, direction: .backwards, onlyFromStore: false) { result in
|
||||
guard result.isSuccess else {
|
||||
self.roomInitializationStatus.value = .failedToInitialize
|
||||
return
|
||||
}
|
||||
let sortedBatch = self.eventBatch.sorted(by: { $0.originServerTs < $1.originServerTs})
|
||||
self.chatMessagesSubject.value = self.mapChatMessages(from: sortedBatch)
|
||||
self.roomInitializationStatus.value = .initialized
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -119,16 +117,11 @@ class TemplateRoomChatService: TemplateRoomChatServiceProtocol {
|
||||
}
|
||||
|
||||
private func senderForMessage(event: MXEvent) -> TemplateRoomChatMember? {
|
||||
guard let sender = event.sender, let roomState = roomState else {
|
||||
guard let sender = event.sender, let roomState = timeline?.state else {
|
||||
return nil
|
||||
}
|
||||
let displayName = eventFormatter.senderDisplayName(for: event, with: roomState)
|
||||
let avatarUrl = eventFormatter.senderAvatarUrl(for: event, with: roomState)
|
||||
return TemplateRoomChatMember(id: sender, avatarUrl: avatarUrl, displayName: displayName)
|
||||
}
|
||||
|
||||
private func appendNewMessage(event: MXEvent) {
|
||||
chatMessagesSubject.value += mapChatMessages(from: [event])
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
+10
-7
@@ -36,17 +36,17 @@ enum MockTemplateRoomChatScreenState: MockScreenState, CaseIterable {
|
||||
}
|
||||
|
||||
/// Generate the view struct for the screen state.
|
||||
var screenView: AnyView {
|
||||
var screenView: ([Any], AnyView) {
|
||||
let service: MockTemplateRoomChatService
|
||||
switch self {
|
||||
case .noMessages:
|
||||
service = MockTemplateRoomChatService(messages: [])
|
||||
service.simulateUpdate(initializationStatus: .initialized)
|
||||
case .messages:
|
||||
service = MockTemplateRoomChatService()
|
||||
service.simulateUpdate(initializationStatus: .initialized)
|
||||
service = MockTemplateRoomChatService()
|
||||
service.simulateUpdate(initializationStatus: .initialized)
|
||||
case .initializingRoom:
|
||||
service = MockTemplateRoomChatService()
|
||||
service = MockTemplateRoomChatService()
|
||||
case .failedToInitializeRoom:
|
||||
service = MockTemplateRoomChatService()
|
||||
service.simulateUpdate(initializationStatus: .failedToInitialize)
|
||||
@@ -54,8 +54,11 @@ enum MockTemplateRoomChatScreenState: MockScreenState, CaseIterable {
|
||||
let viewModel = TemplateRoomChatViewModel(templateRoomChatService: service)
|
||||
|
||||
// can simulate service and viewModel actions here if needs be.
|
||||
|
||||
return AnyView(TemplateRoomChat(viewModel: viewModel.context)
|
||||
.addDependency(MockAvatarService.example))
|
||||
|
||||
return (
|
||||
[service, viewModel],
|
||||
AnyView(TemplateRoomChat(viewModel: viewModel.context)
|
||||
.addDependency(MockAvatarService.example))
|
||||
)
|
||||
}
|
||||
}
|
||||
|
||||
+2
-1
@@ -46,7 +46,8 @@ class MockTemplateRoomChatService: TemplateRoomChatServiceProtocol {
|
||||
func simulateUpdate(initializationStatus: TemplateRoomChatRoomInitializationStatus) {
|
||||
self.roomInitializationStatus.value = initializationStatus
|
||||
}
|
||||
|
||||
func simulateUpdate(messages: [TemplateRoomChatMessage]) {
|
||||
self.chatMessagesSubject.send(messages)
|
||||
self.chatMessagesSubject.value = messages
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user