fix: improve the lock-screen password validation logic (#4324)

* fix: after entering the password correctly, the verification still shows' failed ', resulting in the inability to enter the system

* chore: update

---------

Co-authored-by: zyy <532612154@qq.com>
pull/48/MERGE
Li Kui 2024-09-05 22:25:44 +08:00 committed by GitHub
parent 58f2b17bde
commit 2b65e935c1
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 8 additions and 18 deletions

View File

@ -1,5 +1,5 @@
<script setup lang="ts"> <script setup lang="ts">
import { computed, reactive, ref, watchEffect } from 'vue'; import { computed, reactive, ref } from 'vue';
import { LockKeyhole } from '@vben/icons'; import { LockKeyhole } from '@vben/icons';
import { $t, useI18n } from '@vben/locales'; import { $t, useI18n } from '@vben/locales';
@ -36,7 +36,6 @@ const minute = useDateFormat(now, 'mm');
const date = useDateFormat(now, 'YYYY-MM-DD dddd', { locales: locale.value }); const date = useDateFormat(now, 'YYYY-MM-DD dddd', { locales: locale.value });
const showUnlockForm = ref(false); const showUnlockForm = ref(false);
const validPass = ref(true);
const { lockScreenPassword } = storeToRefs(lockStore); const { lockScreenPassword } = storeToRefs(lockStore);
const formState = reactive({ const formState = reactive({
@ -44,15 +43,14 @@ const formState = reactive({
submitted: false, submitted: false,
}); });
const passwordStatus = computed(() => { const validPass = computed(
if (formState.submitted && !formState.password) { () => lockScreenPassword?.value === formState.password,
return 'error'; );
}
const passwordStatus = computed(() => {
if (formState.submitted && !validPass.value) { if (formState.submitted && !validPass.value) {
return 'error'; return 'error';
} }
return 'default'; return 'default';
}); });
@ -62,21 +60,13 @@ const errorTip = computed(() => {
: $t('widgets.lockScreen.errorPasswordTip'); : $t('widgets.lockScreen.errorPasswordTip');
}); });
watchEffect(() => {
if (!formState.password) {
validPass.value = true;
}
});
function handleSubmit() { function handleSubmit() {
formState.submitted = true; formState.submitted = true;
if (passwordStatus.value !== 'default') {
return; if (!validPass.value) {
}
if (lockScreenPassword?.value !== formState.password) {
validPass.value = false;
return; return;
} }
lockStore.unlockScreen(); lockStore.unlockScreen();
} }