|
@@ -0,0 +1,145 @@
|
|
|
|
|
+<template>
|
|
|
|
|
+ <div class="login main-background main-background-type0">
|
|
|
|
|
+ <div class="nav-placeholder"></div>
|
|
|
|
|
+ <!-- 表单 -->
|
|
|
|
|
+ <section class="main-section ">
|
|
|
|
|
+ <div class="content small-h">
|
|
|
|
|
+ <div class="title">
|
|
|
|
|
+ <h2>修改个人信息</h2>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ <div class="form-container">
|
|
|
|
|
+ <template v-if="isSuccess">
|
|
|
|
|
+ <a-result
|
|
|
|
|
+ status="success"
|
|
|
|
|
+ title="修改成功"
|
|
|
|
|
+ >
|
|
|
|
|
+ <template #extra>
|
|
|
|
|
+ <a-button class="mt-3" block @click="router.back()">返回</a-button>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </a-result>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ <template v-else>
|
|
|
|
|
+ <DynamicForm
|
|
|
|
|
+ ref="form"
|
|
|
|
|
+ :model="formModel"
|
|
|
|
|
+ :options="formOptions"
|
|
|
|
|
+ />
|
|
|
|
|
+ <a-button type="primary" block :loading="isSubmiting" @click="handleSubmit">确认修改</a-button>
|
|
|
|
|
+ <a-button class="mt-3" block @click="router.back()">返回</a-button>
|
|
|
|
|
+ </template>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ </div>
|
|
|
|
|
+ </section>
|
|
|
|
|
+ </div>
|
|
|
|
|
+</template>
|
|
|
|
|
+
|
|
|
|
|
+<script setup lang="ts">
|
|
|
|
|
+import UserApi from '@/api/auth/UserApi';
|
|
|
|
|
+import { DynamicForm, type IDynamicFormOptions, type IDynamicFormRef } from '@imengyu/vue-dynamic-form';
|
|
|
|
|
+import { message, Modal, type FormInstance } from 'ant-design-vue';
|
|
|
|
|
+import { onMounted, ref } from 'vue';
|
|
|
|
|
+import { useRouter } from 'vue-router';
|
|
|
|
|
+import { useAuthStore } from '@/stores/auth';
|
|
|
|
|
+import { useBeforeUploadImageChecker } from '@imengyu/imengyu-web-shared';
|
|
|
|
|
+import { useImageSimpleUploadCo } from '@/common/upload/ImageUploadCo';
|
|
|
|
|
+
|
|
|
|
|
+const form = ref<IDynamicFormRef>();
|
|
|
|
|
+const formModel = ref({
|
|
|
|
|
+ avatar: '',
|
|
|
|
|
+ nickname: '',
|
|
|
|
|
+ intro: '',
|
|
|
|
|
+});
|
|
|
|
|
+const formOptions = ref<IDynamicFormOptions>({
|
|
|
|
|
+ formLabelCol: { span: 6 },
|
|
|
|
|
+ formWrapperCol: { span: 24 },
|
|
|
|
|
+ formAdditionaProps: {
|
|
|
|
|
+ layout: 'vertical'
|
|
|
|
|
+ },
|
|
|
|
|
+ formItems: [
|
|
|
|
|
+ {
|
|
|
|
|
+ label: '',
|
|
|
|
|
+ name: 'avatar',
|
|
|
|
|
+ type: 'single-image',
|
|
|
|
|
+ additionalProps: {
|
|
|
|
|
+ class: 'text-center',
|
|
|
|
|
+ placeholder: '请上传图片',
|
|
|
|
|
+ name: 'file',
|
|
|
|
|
+ accept: 'image/*',
|
|
|
|
|
+ beforeUpload: useBeforeUploadImageChecker(),
|
|
|
|
|
+ uploadCo: useImageSimpleUploadCo()
|
|
|
|
|
+ },
|
|
|
|
|
+ },
|
|
|
|
|
+ {
|
|
|
|
|
+ label: '昵称',
|
|
|
|
|
+ name: 'nickname',
|
|
|
|
|
+ type: 'text',
|
|
|
|
|
+ additionalProps: {
|
|
|
|
|
+ placeholder: '请输入昵称'
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ {
|
|
|
|
|
+ label: '个人介绍',
|
|
|
|
|
+ name: 'intro',
|
|
|
|
|
+ type: 'text-area',
|
|
|
|
|
+ additionalProps: {
|
|
|
|
|
+ placeholder: '请输入个人介绍'
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ ],
|
|
|
|
|
+ formRules: {
|
|
|
|
|
+ },
|
|
|
|
|
+});
|
|
|
|
|
+
|
|
|
|
|
+const isSubmiting = ref(false);
|
|
|
|
|
+const isSuccess = ref(false);
|
|
|
|
|
+
|
|
|
|
|
+const router = useRouter();
|
|
|
|
|
+const authStore = useAuthStore();
|
|
|
|
|
+
|
|
|
|
|
+onMounted(async () => {
|
|
|
|
|
+ if (authStore.userInfo) {
|
|
|
|
|
+ formModel.value.avatar = authStore.userInfo.avatar;
|
|
|
|
|
+ formModel.value.nickname = authStore.userInfo.nickname;
|
|
|
|
|
+ formModel.value.intro = (authStore.userInfo.intro || authStore.userInfo.bio || '') as string;
|
|
|
|
|
+ }
|
|
|
|
|
+});
|
|
|
|
|
+
|
|
|
|
|
+async function handleSubmit() {
|
|
|
|
|
+ isSubmiting.value = true;
|
|
|
|
|
+ try {
|
|
|
|
|
+ await (form.value?.getFormRef() as FormInstance).validate();
|
|
|
|
|
+ } catch {
|
|
|
|
|
+ isSubmiting.value = false;
|
|
|
|
|
+ return;
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ try {
|
|
|
|
|
+ await UserApi.updateSystemUserInfo({
|
|
|
|
|
+ username: authStore.userInfo?.username,
|
|
|
|
|
+ nickname: formModel.value.nickname,
|
|
|
|
|
+ avatar: formModel.value.avatar,
|
|
|
|
|
+ intro: formModel.value.intro,
|
|
|
|
|
+ });
|
|
|
|
|
+ if (authStore.userInfo) {
|
|
|
|
|
+ authStore.userInfo.avatar = formModel.value.avatar;
|
|
|
|
|
+ authStore.userInfo.nickname = formModel.value.nickname;
|
|
|
|
|
+ authStore.userInfo.intro = formModel.value.intro;
|
|
|
|
|
+ }
|
|
|
|
|
+ message.success('修改个人信息成功');
|
|
|
|
|
+ isSuccess.value = true;
|
|
|
|
|
+ } catch (error) {
|
|
|
|
|
+ Modal.error({
|
|
|
|
|
+ title: '修改个人信息失败',
|
|
|
|
|
+ content: '' + error,
|
|
|
|
|
+ });
|
|
|
|
|
+ } finally {
|
|
|
|
|
+ isSubmiting.value = false;
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+</script>
|
|
|
|
|
+
|
|
|
|
|
+<style lang="scss">
|
|
|
|
|
+.login {
|
|
|
|
|
+ min-height: calc(100vh - 50px);
|
|
|
|
|
+}
|
|
|
|
|
+</style>
|