From 8108926d71541911e3b770b9d0c228d9c67facc3 Mon Sep 17 00:00:00 2001 From: dankito Date: Sat, 3 Oct 2020 07:18:00 +0200 Subject: [PATCH] Implemented toggling password visibility --- .../ui/UIKit/UIKitTextField.swift | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) diff --git a/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/UIKitTextField.swift b/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/UIKitTextField.swift index ba210df8..a941b8cd 100644 --- a/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/UIKitTextField.swift +++ b/ui/BankingiOSApp/BankingiOSApp/ui/UIKit/UIKitTextField.swift @@ -74,6 +74,10 @@ struct UIKitTextField: UIViewRepresentable { textField.delegate = context.coordinator + if isPasswordField { + addTogglePasswordVisibilityButton(textField, context.coordinator) + } + // set tag on all TextFields to be able to focus next view (= next tag). See Coordinator for more details Self.NextTagId = Self.NextTagId + 1 // unbelievable, there's no ++ operator textField.tag = Self.NextTagId @@ -101,6 +105,18 @@ struct UIKitTextField: UIViewRepresentable { } } + private func addTogglePasswordVisibilityButton(_ textField: UITextField, _ coordinator: Coordinator) { + coordinator.textField = textField + + let togglePasswordVisiblityView = UIButton() + togglePasswordVisiblityView.setImage(UIImage(systemName: "eye.slash.fill"), for: .normal) + togglePasswordVisiblityView.tintColor = UIColor.secondaryLabel + togglePasswordVisiblityView.addTarget(coordinator, action:#selector(coordinator.togglePasswordVisibility), for: .touchUpInside) + + textField.leftView = togglePasswordVisiblityView + textField.leftViewMode = .always + } + private func addDoneButtonToKeyboard(_ textField: UITextField, _ coordinator: Coordinator) { coordinator.textField = textField @@ -211,6 +227,22 @@ struct UIKitTextField: UIViewRepresentable { handleReturnKeyPress(textField) } } + + @objc + func togglePasswordVisibility() { + if let textField = self.textField { + textField.isSecureTextEntry.toggle() + + if let togglePasswordVisiblityButton = textField.leftView as? UIButton { + if textField.isSecureTextEntry { + togglePasswordVisiblityButton.setImage(UIImage(systemName: "eye.slash.fill"), for: .normal) + } + else { + togglePasswordVisiblityButton.setImage(UIImage(systemName: "eye.fill"), for: .normal) + } + } + } + } }