imp: modal of hiding recovery password permanently

pull/891/head
Ryan Zhao 1 year ago
parent 01f202ac79
commit cf63d6e48f

@ -811,9 +811,7 @@ final class HomeVC: BaseVC, SessionUtilRespondingViewController, UITableViewData
if let recoveryPasswordView: RecoveryPasswordView = try? RecoveryPasswordView() { if let recoveryPasswordView: RecoveryPasswordView = try? RecoveryPasswordView() {
let viewController: SessionHostingViewController = SessionHostingViewController(rootView: recoveryPasswordView) let viewController: SessionHostingViewController = SessionHostingViewController(rootView: recoveryPasswordView)
viewController.setNavBarTitle("recovery_password_title".localized()) viewController.setNavBarTitle("recovery_password_title".localized())
self.navigationController?.pushViewController(viewController, animated: true) { self.navigationController?.pushViewController(viewController, animated: true)
Storage.shared.writeAsync { db in db[.hasViewedSeed] = true }
}
} else { } else {
let targetViewController: UIViewController = ConfirmationModal( let targetViewController: UIViewController = ConfirmationModal(
info: ConfirmationModal.Info( info: ConfirmationModal.Info(

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -859,3 +859,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_warning_1" = "Without your recovery password, you cannot load your account on new devices."; "hide_recovery_password_modal_warning_1" = "Without your recovery password, you cannot load your account on new devices.";
"hide_recovery_password_modal_warning_2" = "We strongly recommend you save your recovery password in a safe and secure place before continuing."; "hide_recovery_password_modal_warning_2" = "We strongly recommend you save your recovery password in a safe and secure place before continuing.";
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -861,3 +861,4 @@ The point that a message will disappear in a disappearing message update message
"hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone."; "hide_recovery_password_modal_confirmation" = "Are you sure you want to permanently hide your recovery password on this device? This cannot be undone.";
"view_qr_code_button_title" = "View QR"; "view_qr_code_button_title" = "View QR";
"view_mnemonic_button_title" = "View Password"; "view_mnemonic_button_title" = "View Password";
"yes_button_title" = "Yes";

@ -160,6 +160,7 @@ enum Onboarding {
// Clear any data which gets set during Onboarding // Clear any data which gets set during Onboarding
Storage.shared.write { db in Storage.shared.write { db in
db[.hasViewedSeed] = false db[.hasViewedSeed] = false
db[.hideRecoveryPasswordPermanently] = false
try SessionThread.deleteAll(db) try SessionThread.deleteAll(db)
try Profile.deleteAll(db) try Profile.deleteAll(db)

@ -206,7 +206,7 @@ struct RecoveryPasswordView: View {
) )
Button { Button {
hideRecoveryPassword()
} label: { } label: {
Text("hide_button_title".localized()) Text("hide_button_title".localized())
.bold() .bold()
@ -226,7 +226,10 @@ struct RecoveryPasswordView: View {
} }
} }
.padding(.horizontal, Values.largeSpacing) .padding(.horizontal, Values.largeSpacing)
.padding(.vertical, Values.mediumSpacing)
} }
}.onAppear {
Storage.shared.writeAsync { db in db[.hasViewedSeed] = true }
} }
} }
@ -234,6 +237,47 @@ struct RecoveryPasswordView: View {
UIPasteboard.general.string = self.mnemonic UIPasteboard.general.string = self.mnemonic
self.copied = true self.copied = true
} }
private func hideRecoveryPassword() {
let modal: ConfirmationModal = ConfirmationModal(
info: ConfirmationModal.Info(
title: "hide_recovery_password_modal_title".localized(),
body: .text(
"hide_recovery_password_modal_warning_1".localized() +
"\n\n" +
"hide_recovery_password_modal_warning_2".localized()
),
confirmTitle: "continue_2".localized(),
confirmStyle: .danger,
cancelStyle: .textPrimary,
onConfirm: { modal in
guard let presentingViewController: UIViewController = modal.presentingViewController else {
return
}
let continueModal: ConfirmationModal = ConfirmationModal(
info: ConfirmationModal.Info(
title: "hide_recovery_password_modal_title".localized(),
body: .text("hide_recovery_password_modal_confirmation".localized()),
confirmTitle: "TXT_CANCEL_TITLE".localized(),
confirmStyle: .textPrimary,
cancelTitle: "yes_button_title".localized(),
cancelStyle: .danger,
onCancel: { modal in
modal.dismiss(animated: true) {
Storage.shared.writeAsync { db in db[.hideRecoveryPasswordPermanently] = true }
self.host.controller?.navigationController?.popViewController(animated: true)
}
}
)
)
return presentingViewController.present(continueModal, animated: true, completion: nil)
}
)
)
self.host.controller?.present(modal, animated: true)
}
} }
struct RecoveryPasswordView_Previews: PreviewProvider { struct RecoveryPasswordView_Previews: PreviewProvider {

@ -215,14 +215,21 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
.eraseToAnyPublisher() .eraseToAnyPublisher()
// MARK: - Content // MARK: - Content
private struct State: Equatable {
let profile: Profile
let hideRecoveryPasswordPermanently: Bool
}
let title: String = "vc_settings_title".localized() let title: String = "vc_settings_title".localized()
lazy var observation: TargetObservation = ObservationBuilder lazy var observation: TargetObservation = ObservationBuilder
.databaseObservation(self) { [weak self, dependencies] db -> Profile in .databaseObservation(self) { [weak self, dependencies] db -> State in
Profile.fetchOrCreateCurrentUser(db, using: dependencies) State(
profile: Profile.fetchOrCreateCurrentUser(db, using: dependencies),
hideRecoveryPasswordPermanently: db[.hideRecoveryPasswordPermanently]
)
} }
.map { [weak self] profile -> [SectionModel] in .map { [weak self] state -> [SectionModel] in
return [ return [
SectionModel( SectionModel(
model: .profileInfo, model: .profileInfo,
@ -230,9 +237,9 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
SessionCell.Info( SessionCell.Info(
id: .avatar, id: .avatar,
accessory: .profile( accessory: .profile(
id: profile.id, id: state.profile.id,
size: .hero, size: .hero,
profile: profile profile: state.profile
), ),
styling: SessionCell.StyleInfo( styling: SessionCell.StyleInfo(
alignment: .centerHugging, alignment: .centerHugging,
@ -243,13 +250,13 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
label: "Profile picture" label: "Profile picture"
), ),
onTap: { onTap: {
self?.updateProfilePicture(currentFileName: profile.profilePictureFileName) self?.updateProfilePicture(currentFileName: state.profile.profilePictureFileName)
} }
), ),
SessionCell.Info( SessionCell.Info(
id: .profileName, id: .profileName,
title: SessionCell.TextInfo( title: SessionCell.TextInfo(
profile.displayName(), state.profile.displayName(),
font: .titleLarge, font: .titleLarge,
alignment: .center, alignment: .center,
interaction: .editable interaction: .editable
@ -261,7 +268,7 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
), ),
accessibility: Accessibility( accessibility: Accessibility(
identifier: "Username", identifier: "Username",
label: profile.displayName() label: state.profile.displayName()
), ),
onTap: { self?.setIsEditing(true) } onTap: { self?.setIsEditing(true) }
) )
@ -273,7 +280,7 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
SessionCell.Info( SessionCell.Info(
id: .sessionId, id: .sessionId,
title: SessionCell.TextInfo( title: SessionCell.TextInfo(
profile.id, state.profile.id,
font: .monoLarge, font: .monoLarge,
alignment: .center, alignment: .center,
interaction: .copy interaction: .copy
@ -284,7 +291,7 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
), ),
accessibility: Accessibility( accessibility: Accessibility(
identifier: "Session ID", identifier: "Session ID",
label: profile.id label: state.profile.id
) )
), ),
SessionCell.Info( SessionCell.Info(
@ -293,14 +300,14 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
style: .bordered, style: .bordered,
title: "copy".localized(), title: "copy".localized(),
run: { button in run: { button in
self?.copySessionId(profile.id, button: button) self?.copySessionId(state.profile.id, button: button)
} }
), ),
rightAccessory: .button( rightAccessory: .button(
style: .bordered, style: .bordered,
title: "share".localized(), title: "share".localized(),
run: { _ in run: { _ in
self?.shareSessionId(profile.id) self?.shareSessionId(state.profile.id)
} }
), ),
styling: SessionCell.StyleInfo( styling: SessionCell.StyleInfo(
@ -406,7 +413,7 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
), ),
title: "vc_settings_invite_a_friend_button_title".localized(), title: "vc_settings_invite_a_friend_button_title".localized(),
onTap: { onTap: {
let invitation: String = "Hey, I've been using Session to chat with complete privacy and security. Come join me! Download it at https://getsession.org/. My Session ID is \(profile.id) !" let invitation: String = "Hey, I've been using Session to chat with complete privacy and security. Come join me! Download it at https://getsession.org/. My Session ID is \(state.profile.id) !"
self?.transitionToScreen( self?.transitionToScreen(
UIActivityViewController( UIActivityViewController(
@ -416,7 +423,9 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
transitionType: .present transitionType: .present
) )
} }
), )
].appending(
state.hideRecoveryPasswordPermanently ? nil :
SessionCell.Info( SessionCell.Info(
id: .recoveryPhrase, id: .recoveryPhrase,
leftAccessory: .icon( leftAccessory: .icon(
@ -441,7 +450,9 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
self?.transitionToScreen(targetViewController, transitionType: .present) self?.transitionToScreen(targetViewController, transitionType: .present)
} }
} }
), )
).appending(
contentsOf: [
SessionCell.Info( SessionCell.Info(
id: .help, id: .help,
leftAccessory: .icon( leftAccessory: .icon(
@ -469,6 +480,7 @@ class SettingsViewModel: SessionTableViewModel, NavigationItemSource, Navigatabl
) )
] ]
) )
)
] ]
} }

@ -53,6 +53,9 @@ public extension Setting.BoolKey {
/// A flag indicating whether the user has ever viewed their seed /// A flag indicating whether the user has ever viewed their seed
static let hasViewedSeed: Setting.BoolKey = "hasViewedSeed" static let hasViewedSeed: Setting.BoolKey = "hasViewedSeed"
/// A flag indicating whether the user hides the recovery password permanently
static let hideRecoveryPasswordPermanently: Setting.BoolKey = "hideRecoveryPasswordPermanently"
/// A flag indicating whether the user has ever saved a thread /// A flag indicating whether the user has ever saved a thread
static let hasSavedThread: Setting.BoolKey = "hasSavedThread" static let hasSavedThread: Setting.BoolKey = "hasSavedThread"

@ -113,9 +113,9 @@ public class ConfirmationModal: Modal, UITextFieldDelegate {
result.isLayoutMarginsRelativeArrangement = true result.isLayoutMarginsRelativeArrangement = true
result.layoutMargins = UIEdgeInsets( result.layoutMargins = UIEdgeInsets(
top: Values.largeSpacing, top: Values.largeSpacing,
left: Values.largeSpacing, left: Values.veryLargeSpacing,
bottom: Values.verySmallSpacing, bottom: Values.verySmallSpacing,
right: Values.largeSpacing right: Values.veryLargeSpacing
) )
return result return result

Loading…
Cancel
Save