element-ios/RiotSwiftUI/Modules/UserSessions/UserOtherSessions/UserOtherSessionsViewModel.swift

90 lines
3.7 KiB
Swift
Raw Normal View History

2022-09-30 13:34:41 +00:00
//
// Copyright 2021 New Vector Ltd
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
import SwiftUI
typealias UserOtherSessionsViewModelType = StateStoreViewModel<UserOtherSessionsViewState, UserOtherSessionsViewAction>
2022-10-04 12:34:31 +00:00
enum OtherUserSessionsFilter {
case all
case inactive
case unverified
}
2022-09-30 13:34:41 +00:00
class UserOtherSessionsViewModel: UserOtherSessionsViewModelType, UserOtherSessionsViewModelProtocol {
2022-10-04 12:44:09 +00:00
2022-09-30 13:34:41 +00:00
var completion: ((UserOtherSessionsViewModelResult) -> Void)?
private let sessionsInfo: [UserSessionInfo]
2022-09-30 13:34:41 +00:00
init(sessionsInfo: [UserSessionInfo],
2022-09-30 13:34:41 +00:00
filter: OtherUserSessionsFilter,
title: String) {
self.sessionsInfo = sessionsInfo
2022-09-30 13:34:41 +00:00
super.init(initialViewState: UserOtherSessionsViewState(title: title, sections: []))
updateViewState(sessionsInfo: sessionsInfo, filter: filter)
2022-09-30 13:34:41 +00:00
}
// MARK: - Public
override func process(viewAction: UserOtherSessionsViewAction) {
2022-10-04 06:38:53 +00:00
switch viewAction {
case let .userOtherSessionSelected(sessionId: sessionId):
guard let session = sessionsInfo.first(where: {$0.id == sessionId}) else {
2022-10-04 07:07:04 +00:00
assertionFailure("Session should exist in the array.")
2022-10-04 06:38:53 +00:00
return
}
completion?(.showUserSessionOverview(sessionInfo: session))
2022-10-04 06:38:53 +00:00
}
2022-09-30 13:34:41 +00:00
}
// MARK: - Private
private func updateViewState(sessionsInfo: [UserSessionInfo], filter: OtherUserSessionsFilter) {
let sectionItems = filterSessions(sessionsInfo: sessionsInfo, by: filter).asViewData()
2022-09-30 13:34:41 +00:00
let sectionHeader = createHeaderData(filter: filter)
state.sections = [.sessionItems(header: sectionHeader, items: sectionItems)]
}
private func filterSessions(sessionsInfo: [UserSessionInfo], by filter: OtherUserSessionsFilter) -> [UserSessionInfo] {
2022-09-30 13:34:41 +00:00
switch filter {
case .all:
return sessionsInfo.filter { !$0.isCurrent }
2022-09-30 13:34:41 +00:00
case .inactive:
return sessionsInfo.filter { !$0.isActive }
2022-09-30 13:34:41 +00:00
case .unverified:
return sessionsInfo.filter { !$0.isVerified }
2022-09-30 13:34:41 +00:00
}
}
private func createHeaderData(filter: OtherUserSessionsFilter) -> UserOtherSessionsHeaderViewData {
switch filter {
case .all:
// TODO:
return UserOtherSessionsHeaderViewData(title: nil,
subtitle: "",
iconName: nil)
case .inactive:
2022-10-04 07:07:04 +00:00
return UserOtherSessionsHeaderViewData(title: VectorL10n.userSessionsOverviewSecurityRecommendationsInactiveTitle,
subtitle: VectorL10n.userSessionsOverviewSecurityRecommendationsInactiveInfo,
2022-09-30 13:34:41 +00:00
iconName: Asset.Images.userOtherSessionsInactive.name)
case .unverified:
2022-10-05 13:01:17 +00:00
return UserOtherSessionsHeaderViewData(title: VectorL10n.userSessionsOverviewSecurityRecommendationsUnverifiedTitle,
subtitle: VectorL10n.userOtherSessionUnverifiedSessionsHeaderSubtitle,
iconName: Asset.Images.userOtherSessionsUnverified.name)
2022-09-30 13:34:41 +00:00
}
}
}