mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-22 01:22:46 +02:00
User session flow coordinator and details view
This commit is contained in:
+15
-3
@@ -21,6 +21,10 @@ struct UserSessionsOverviewCoordinatorParameters {
|
||||
let session: MXSession
|
||||
}
|
||||
|
||||
protocol UserSessionsOverviewCoordinatorDelegate: AnyObject {
|
||||
func showUserSessionOverview(session: UserSessionInfo)
|
||||
}
|
||||
|
||||
final class UserSessionsOverviewCoordinator: Coordinator, Presentable {
|
||||
|
||||
// MARK: - Properties
|
||||
@@ -30,7 +34,8 @@ final class UserSessionsOverviewCoordinator: Coordinator, Presentable {
|
||||
private let parameters: UserSessionsOverviewCoordinatorParameters
|
||||
private let userSessionsOverviewHostingController: UIViewController
|
||||
private var userSessionsOverviewViewModel: UserSessionsOverviewViewModelProtocol
|
||||
|
||||
private let service: UserSessionsOverviewService
|
||||
|
||||
private var indicatorPresenter: UserIndicatorTypePresenterProtocol
|
||||
private var loadingIndicator: UserIndicator?
|
||||
|
||||
@@ -40,11 +45,15 @@ final class UserSessionsOverviewCoordinator: Coordinator, Presentable {
|
||||
var childCoordinators: [Coordinator] = []
|
||||
var completion: (() -> Void)?
|
||||
|
||||
weak var delegate: UserSessionsOverviewCoordinatorDelegate?
|
||||
|
||||
// MARK: - Setup
|
||||
|
||||
init(parameters: UserSessionsOverviewCoordinatorParameters) {
|
||||
self.parameters = parameters
|
||||
let viewModel = UserSessionsOverviewViewModel(userSessionsOverviewService: UserSessionsOverviewService(mxSession: parameters.session))
|
||||
let service = UserSessionsOverviewService(mxSession: parameters.session)
|
||||
self.service = service
|
||||
let viewModel = UserSessionsOverviewViewModel(userSessionsOverviewService: service)
|
||||
let view = UserSessionsOverview(viewModel: viewModel.context)
|
||||
userSessionsOverviewViewModel = viewModel
|
||||
|
||||
@@ -117,7 +126,10 @@ final class UserSessionsOverviewCoordinator: Coordinator, Presentable {
|
||||
}
|
||||
|
||||
private func showUserSessionDetails(sessionId: String) {
|
||||
// TODO
|
||||
guard let sessionInfo = service.getOtherSession(sessionId: sessionId) else {
|
||||
return
|
||||
}
|
||||
delegate?.showUserSessionOverview(session: sessionInfo)
|
||||
}
|
||||
|
||||
private func showAllOtherSessions() {
|
||||
|
||||
+6
-2
@@ -47,14 +47,18 @@ class UserSessionsOverviewService: UserSessionsOverviewServiceProtocol {
|
||||
self.mxSession.matrixRestClient.devices { response in
|
||||
switch response {
|
||||
case .success(let devices):
|
||||
let overviewData = self.userSessionsOverviewData(from: devices)
|
||||
completion(.success(overviewData))
|
||||
self.lastOverviewData = self.userSessionsOverviewData(from: devices)
|
||||
completion(.success(self.lastOverviewData))
|
||||
case .failure(let error):
|
||||
completion(.failure(error))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func getOtherSession(sessionId: String) -> UserSessionInfo? {
|
||||
lastOverviewData.otherSessionsInfo.first(where: {$0.sessionId == sessionId})
|
||||
}
|
||||
|
||||
// MARK: - Private
|
||||
|
||||
private func setupInitialOverviewData() {
|
||||
|
||||
+1
-1
@@ -75,7 +75,7 @@ struct UserSessionsOverview: View {
|
||||
viewModel.send(viewAction: .viewAppeared)
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
private var otherSessionsSection: some View {
|
||||
|
||||
SwiftUI.Section {
|
||||
|
||||
Reference in New Issue
Block a user