// // 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 Foundation // MARK: View model enum AuthenticationServerSelectionViewModelResult { /// The user would like to use the homeserver at the given address. case confirm(homeserverAddress: String) /// Dismiss the view without using the entered address. case dismiss /// Show the app store page for the replacement app. case downloadReplacementApp(BuildSettings.ReplacementApp) } // MARK: View struct AuthenticationServerSelectionViewState: BindableState { enum FooterError: Equatable { case message(String) case sunsetBanner } /// View state that can be bound to from SwiftUI. var bindings: AuthenticationServerSelectionBindings /// An error message to be shown in the text field footer. var footerError: FooterError? /// The flow that the screen is being used for. let flow: AuthenticationFlow /// Whether the screen is presented modally or within a navigation stack. var hasModalPresentation: Bool var headerTitle: String { flow == .login ? BWIL10n.authenticationServerSelectionLoginTitle : VectorL10n.authenticationServerSelectionRegisterTitle } var headerMessage: String { flow == .login ? VectorL10n.authenticationServerSelectionLoginMessage : VectorL10n.authenticationServerSelectionRegisterMessage } /// The title shown on the confirm button. var scanCodeButtonTitle: String { BWIL10n.authenticationServerSelectionScanCodeButtonTitle } /// The title shown on the confirm button. var buttonTitle: String { hasModalPresentation ? VectorL10n.confirm : BWIL10n.authenticationServerSelectionSubmitButtonTitle } /// The text field is showing an error. var isShowingFooterError: Bool { footerError != nil } /// Whether it is possible to continue when tapping the confirmation button. var hasValidationError: Bool { bindings.homeserverAddress.isEmpty || isShowingFooterError } } struct AuthenticationServerSelectionBindings { /// The homeserver address input by the user. var homeserverAddress: String /// Information describing the currently displayed alert. var alertInfo: AlertInfo? /// BWI: #6777 Show error alerts var showAlert = false /// BWI: #6777 show info alert if the server is not supported var isInvalidServerAlert = false /// BWI END } enum AuthenticationServerSelectionViewAction { /// The user would like to use the homeserver at the input address. case confirm /// Dismiss the view without using the entered address. case dismiss /// Clear any errors shown in the text field footer. case clearFooterError /// Show the app store page for the replacement app. case downloadReplacementApp(BuildSettings.ReplacementApp) } enum AuthenticationServerSelectionErrorType: Hashable { /// An error message to be shown in the text field footer. case footerMessage(String) /// An error occurred when trying to open the EMS link case openURLAlert /// bwi: When an invalid or nonexisting server is selected at login an info message is displayed case openInvalidServerInfo /// An error message shown alongside a marketing banner to download the replacement app. case requiresReplacementApp }