mirror of
https://gitlab.opencode.de/bwi/bundesmessenger/clients/bundesmessenger-ios.git
synced 2026-04-21 00:52:43 +02:00
67df1a3e95
Merge commit 'af0b6d4be985d9f26e5111d3fa01389c7321949f' into feature/7276_FOSS_Merge_1_27_11 # Conflicts: # Config/AppVersion.xcconfig # Gemfile.lock # IDETemplateMacros.plist # Podfile # Podfile.lock # README.md # Riot/Modules/Authentication/AuthenticationCoordinator.swift # Riot/Modules/Room/CellData/RoomBubbleCellData.m # Riot/target.yml # RiotNSE/NotificationService.swift # RiotSwiftUI/Modules/Authentication/ServerSelection/AuthenticationServerSelectionModels.swift # RiotSwiftUI/Modules/Authentication/ServerSelection/AuthenticationServerSelectionViewModel.swift # RiotSwiftUI/Modules/Authentication/ServerSelection/Coordinator/AuthenticationServerSelectionCoordinator.swift # RiotSwiftUI/Modules/Authentication/ServerSelection/View/AuthenticationServerSelectionScreen.swift # RiotSwiftUI/Modules/Room/CompletionSuggestion/Service/CompletionSuggestionService.swift # fastlane/Fastfile
75 lines
3.1 KiB
Swift
75 lines
3.1 KiB
Swift
//
|
|
// Copyright 2021-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 SwiftUI
|
|
|
|
typealias ChangePasswordViewModelType = StateStoreViewModel<ChangePasswordViewState, ChangePasswordViewAction>
|
|
|
|
class ChangePasswordViewModel: ChangePasswordViewModelType, ChangePasswordViewModelProtocol {
|
|
// MARK: - Properties
|
|
|
|
// MARK: Private
|
|
|
|
// MARK: Public
|
|
|
|
var callback: (@MainActor (ChangePasswordViewModelResult) -> Void)?
|
|
|
|
// MARK: - Setup
|
|
|
|
init(oldPassword: String = "",
|
|
newPassword1: String = "",
|
|
newPassword2: String = "",
|
|
passwordRequirements: String = "",
|
|
signoutAllDevices: Bool = false) {
|
|
let bindings = ChangePasswordBindings(oldPassword: oldPassword,
|
|
newPassword1: newPassword1,
|
|
newPassword2: newPassword2,
|
|
signoutAllDevices: signoutAllDevices)
|
|
let viewState = ChangePasswordViewState(passwordRequirements: passwordRequirements,
|
|
bindings: bindings)
|
|
super.init(initialViewState: viewState)
|
|
}
|
|
|
|
// MARK: - Public
|
|
|
|
override func process(viewAction: ChangePasswordViewAction) {
|
|
switch viewAction {
|
|
case .submit:
|
|
guard state.bindings.newPassword1 == state.bindings.newPassword2 else {
|
|
Task { await displayError(.passwordsDontMatch, primaryButtonCallback: {}) }
|
|
return
|
|
}
|
|
Task { await callback?(.submit(oldPassword: state.bindings.oldPassword,
|
|
newPassword: state.bindings.newPassword1,
|
|
signoutAllDevices: state.bindings.signoutAllDevices))
|
|
}
|
|
case .toggleSignoutAllDevices:
|
|
state.bindings.signoutAllDevices.toggle()
|
|
}
|
|
}
|
|
|
|
@MainActor func displayError(_ type: ChangePasswordErrorType, primaryButtonCallback: @escaping (() -> Void)) {
|
|
switch type {
|
|
case .passwordChangeSucceeded:
|
|
state.bindings.alertInfo = AlertInfo(id: .passwordChangeSucceeded,
|
|
title: BWIL10n.settingsPasswordChanged,
|
|
message: "",
|
|
primaryButton: (VectorL10n.ok, action: { primaryButtonCallback() }))
|
|
case .mxError(let message):
|
|
state.bindings.alertInfo = AlertInfo(id: type,
|
|
title: VectorL10n.error,
|
|
message: message)
|
|
case .passwordsDontMatch:
|
|
state.bindings.alertInfo = AlertInfo(id: type,
|
|
title: VectorL10n.error,
|
|
message: VectorL10n.authPasswordDontMatch)
|
|
case .unknown:
|
|
state.bindings.alertInfo = AlertInfo(id: type)
|
|
}
|
|
}
|
|
}
|