From d415638bd9c0aeb31b50f207fce6103f229b647e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E4=B8=89=E5=92=B2=E6=99=BA=E5=AD=90?= Date: Sun, 8 Jan 2023 17:06:15 +0800 Subject: [PATCH] refactor(settings): improve profile appearance - move user info to bottom - don't reset dirty form after pulling the latest info --- pages/settings/profile/appearance.vue | 36 +++++++++++++++------------ 1 file changed, 20 insertions(+), 16 deletions(-) diff --git a/pages/settings/profile/appearance.vue b/pages/settings/profile/appearance.vue index c8a4b2d70..340ab739f 100644 --- a/pages/settings/profile/appearance.vue +++ b/pages/settings/profile/appearance.vue @@ -5,8 +5,6 @@ import { parse } from 'ultrahtml' definePageMeta({ middleware: 'auth', - // Keep alive the form page will reduce raw data timeliness and its status timeliness - keepalive: false, }) const { t } = useI18n() @@ -51,13 +49,8 @@ const { form, reset, submitter, dirtyFields, isError } = useForm({ }, }) -onMastoInit(async () => { - // Keep the information to be edited up to date - await pullMyAccountInfo() - reset() -}) - -const isCanSubmit = computed(() => !isError.value && !isEmptyObject(dirtyFields.value)) +const isDirty = $computed(() => !isEmptyObject(dirtyFields.value)) +const isCanSubmit = computed(() => !isError.value && isDirty) const { submit, submitting } = submitter(async ({ dirtyFields }) => { if (!isCanSubmit.value) @@ -76,6 +69,16 @@ const { submit, submitting } = submitter(async ({ dirtyFields }) => { setAccountInfo(account!.id, res.account) reset() }) + +const refreshInfo = async () => { + // Keep the information to be edited up to date + await pullMyAccountInfo() + if (!isDirty) + reset() +} + +onMastoInit(refreshInfo) +onReactivated(refreshInfo)