From 90efea0470cfb73763a9ede41351b58529dad66d Mon Sep 17 00:00:00 2001 From: Mohammed Mohsin <59914433+mdmohsin7@users.noreply.github.com> Date: Thu, 13 Jun 2024 15:46:02 +0530 Subject: [PATCH] improve password validation handling --- .../authentification/create_password_page.dart | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/lib/screens/authentification/create_password_page.dart b/lib/screens/authentification/create_password_page.dart index 48d608ad8..893b56730 100644 --- a/lib/screens/authentification/create_password_page.dart +++ b/lib/screens/authentification/create_password_page.dart @@ -37,7 +37,9 @@ class _CreatePasswordPageState extends State { if (text.isEmpty || text2.isEmpty || !_formKey.currentState.validate() || - controller1.text != controller2.text) { + controller1.text != controller2.text || + controller1.text.length < 12 || + controller2.text.length < 12) { setState(() { isValidPassword = false; }); @@ -49,12 +51,16 @@ class _CreatePasswordPageState extends State { } bool _validateInputs() { + // Only validate if the user has entered atleast 3 characters. + if (controller1.text.length < 3) { + return false; + } if (_formKey.currentState.validate()) { -// If all data are correct then save data to out variables + // If all data are correct then save data to out variables _formKey.currentState.save(); return true; } else { -// If all data are not valid then start auto validation. + // If all data are not valid then start auto validation. setState(() { _autoValidate = true; }); @@ -90,6 +96,9 @@ class _CreatePasswordPageState extends State { _fieldFocusChange(context, _focus1, _focus2); _validateInputs(); }, + onChanged: (value) { + _validateInputs(); + }, textInputAction: TextInputAction.next, autocorrect: false, enableInteractiveSelection: true,