* Introduce a `UserIdentityProxy` and have it combine upstream methods into an easy to digest `UserIdentityVerificationState`. Use it in a dedicated `VerificationBadge` UI component * Show a DMs counterpart verification state in the room header * Show a warning on the room details `People` entry when there are identity verification state violations on any of the members. * Show verification badges in the room member list * Show a withdraw verification section on the room member details for users that have pinning violations. * Remove the verification section from the profile screen as there's no reliable way to keep it up to date - the underlying Rust SDK Olm Machine can be rebuilt without notice which would break any existing user identity change streams. * Update preview test snapshots
69 lines
2.3 KiB
Swift
69 lines
2.3 KiB
Swift
//
|
|
// Copyright 2022-2024 New Vector Ltd.
|
|
//
|
|
// SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
|
|
// Please see LICENSE files in the repository root for full details.
|
|
//
|
|
|
|
import Combine
|
|
import SwiftUI
|
|
|
|
struct UserProfileScreenCoordinatorParameters {
|
|
let userID: String
|
|
let isPresentedModally: Bool
|
|
let clientProxy: ClientProxyProtocol
|
|
let mediaProvider: MediaProviderProtocol
|
|
let userIndicatorController: UserIndicatorControllerProtocol
|
|
let analytics: AnalyticsService
|
|
}
|
|
|
|
enum UserProfileScreenCoordinatorAction {
|
|
case openDirectChat(roomID: String)
|
|
case startCall(roomID: String)
|
|
case dismiss
|
|
}
|
|
|
|
final class UserProfileScreenCoordinator: CoordinatorProtocol {
|
|
private var viewModel: UserProfileScreenViewModelProtocol
|
|
|
|
private var cancellables = Set<AnyCancellable>()
|
|
|
|
private let actionsSubject: PassthroughSubject<UserProfileScreenCoordinatorAction, Never> = .init()
|
|
var actionsPublisher: AnyPublisher<UserProfileScreenCoordinatorAction, Never> {
|
|
actionsSubject.eraseToAnyPublisher()
|
|
}
|
|
|
|
init(parameters: UserProfileScreenCoordinatorParameters) {
|
|
viewModel = UserProfileScreenViewModel(userID: parameters.userID,
|
|
isPresentedModally: parameters.isPresentedModally,
|
|
clientProxy: parameters.clientProxy,
|
|
mediaProvider: parameters.mediaProvider,
|
|
userIndicatorController: parameters.userIndicatorController,
|
|
analytics: parameters.analytics)
|
|
}
|
|
|
|
func start() {
|
|
viewModel.actionsPublisher.sink { [weak self] action in
|
|
guard let self else { return }
|
|
|
|
switch action {
|
|
case .openDirectChat(let roomID):
|
|
actionsSubject.send(.openDirectChat(roomID: roomID))
|
|
case .startCall(let roomID):
|
|
actionsSubject.send(.startCall(roomID: roomID))
|
|
case .dismiss:
|
|
actionsSubject.send(.dismiss)
|
|
}
|
|
}
|
|
.store(in: &cancellables)
|
|
}
|
|
|
|
func stop() {
|
|
viewModel.stop()
|
|
}
|
|
|
|
func toPresentable() -> AnyView {
|
|
AnyView(UserProfileScreen(context: viewModel.context))
|
|
}
|
|
}
|