|
|
@@ -0,0 +1,72 @@
|
|
|
+<!-- 系统公告 -->
|
|
|
+<template>
|
|
|
+ <app-drawer title="头像" :width="600" v-model:show="show" :loading="loading" :refresh="refresh">
|
|
|
+ <el-form ref="formRef" class="el-form--vertical" label-width="100px" :model="formData" :rules="formRules">
|
|
|
+ <el-form-item prop="cardbackphotourl" label="用户头像">
|
|
|
+ <app-upload :file-types="['image']" type-message="请选择正确的图片类型" @change="f_afterRead"
|
|
|
+ :rules="formRules.cardbackphotourl" />
|
|
|
+ </el-form-item>
|
|
|
+ </el-form>
|
|
|
+ <template #footer>
|
|
|
+ <el-button type="info" @click="onCancel(false)">取消</el-button>
|
|
|
+ <el-button type="danger" @click="onSubmit">修改</el-button>
|
|
|
+ </template>
|
|
|
+ </app-drawer>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script lang="ts" setup>
|
|
|
+import { ref, reactive } from 'vue'
|
|
|
+import type { FormInstance, FormRules } from 'element-plus'
|
|
|
+import { ElMessage } from 'element-plus'
|
|
|
+import { updateUserHeadUrl } from '@/services/api/user'
|
|
|
+import { useLoginStore, useUserStore } from '@/stores'
|
|
|
+import AppDrawer from '@pc/components/base/drawer/index.vue'
|
|
|
+import AppUpload from '@pc/components/base/upload/index.vue'
|
|
|
+
|
|
|
+const show = ref(true)
|
|
|
+const refresh = ref(false)
|
|
|
+const formRef = ref<FormInstance>()
|
|
|
+const loginStore = useLoginStore()
|
|
|
+const userStore = useUserStore()
|
|
|
+
|
|
|
+const formData = reactive<Model.UserHeadUrlReq>({
|
|
|
+ userid: loginStore.userId, // 用户ID
|
|
|
+ headurl: '', // 头像地址
|
|
|
+})
|
|
|
+
|
|
|
+const formRules: FormRules = {
|
|
|
+ headurl: [{
|
|
|
+ message: '请上传头像',
|
|
|
+ validator: () => {
|
|
|
+ return !!formData.headurl
|
|
|
+ }
|
|
|
+ }],
|
|
|
+}
|
|
|
+
|
|
|
+const f_afterRead = ({ filePath }: { filePath: string }) => {
|
|
|
+ formData.headurl = filePath
|
|
|
+ formRef.value?.validateField('headurl')
|
|
|
+}
|
|
|
+
|
|
|
+const onCancel = (isRefresh = false) => {
|
|
|
+ show.value = false
|
|
|
+ refresh.value = isRefresh
|
|
|
+}
|
|
|
+
|
|
|
+const onSubmit = () => {
|
|
|
+ formRef.value?.validate((valid) => {
|
|
|
+ if (valid) {
|
|
|
+ updateUserHeadUrl({
|
|
|
+ data: formData
|
|
|
+ }).then(() => {
|
|
|
+ userStore.getUserData()
|
|
|
+ ElMessage.success('提交成功')
|
|
|
+ onCancel(true)
|
|
|
+ }).catch((err) => {
|
|
|
+ ElMessage.error('提交失败:' + err)
|
|
|
+ })
|
|
|
+ }
|
|
|
+ })
|
|
|
+}
|
|
|
+
|
|
|
+</script>
|