<template> <el-form :model="profile" ref="form" v-loading="loading" label-position="top"> <Upload class="w-28 h-28 rounded-full mx-auto" action="upload/image" :show-file-list="false" name="image" :on-success="uploadAvatar"> <img :src="profile.avatar" class="h-28 rounded-full" v-if="profile.avatar" /> <Icon name="plus" v-else /> </Upload> <el-form-item label="昵称" prop="username" class="mt-2" :rules="[ { required: true, message: '昵称必须填写', }, ]" > <el-input v-model="profile.username" placeholder="请填写昵称" /> </el-form-item> <el-form-item label="邮箱" prop="email" :rules="[ { required: true, message: '邮箱必须填写', }, { type: 'email', message: '邮箱格式不正确', }, ]" > <el-input v-model="profile.email" placeholder="请填写邮箱" /> </el-form-item> <el-form-item label="密码" prop="password" :rules="[ { pattern: /^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,20}$/, message: '必须包含大小写字母和数字的组合,可以使用特殊字符,长度在6-20之间', }, ]" > <el-input v-model="profile.password" type="password" show-password placeholder="请输入密码" /> </el-form-item> <div class="flex justify-center"> <el-button type="primary" @click="submitForm(form)">{{ $t('system.update') }}</el-button> </div> </el-form> </template> <script lang="ts" setup> import {onMounted, ref} from 'vue' import {useCreate} from '/admin/composables/curd/useCreate' import http from '/admin/support/http' import {Code} from '/admin/enum/app' import Message from '/admin/support/message' import {useUserStore} from '/admin/stores/modules/user' interface profile { avatar: string username: string email: string password: string } const profile = ref<profile>( Object.assign({ avatar: '', username: '', email: '', password: '', }), ) const { form, loading, submitForm, afterCreate } = useCreate('user/online', null, profile) const getUserInfo = () => { loading.value = true http.get('user/online').then(r => { profile.value.username = r.data.data.username profile.value.avatar = r.data.data.avatar profile.value.email = r.data.data.email loading.value = false }) } onMounted(() => { getUserInfo() }) const userStore = useUserStore() const uploadAvatar = (response, uploadFile) => { if (response.code === Code.SUCCESS) { form.value.avatar = response.data.path profile.value.avatar = response.data.path } else { Message.error(response.message) } } afterCreate.value = () => { userStore.getUserInfo() } </script> <style scoped lang="scss"> :deep(.el-upload) { @apply h-full w-full; } </style>