fix(修复issue): 🐛 https://gitee.com/huge-dream/django-vue3-admin/issues/I6OS1E
This commit is contained in:
@@ -1,524 +1,506 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="personal layout-pd">
|
<div class="personal layout-pd">
|
||||||
<el-row>
|
<el-row>
|
||||||
<!-- 个人信息 -->
|
<!-- 个人信息 -->
|
||||||
<el-col :xs="24" :sm="16">
|
<el-col :xs="24" :sm="16">
|
||||||
<el-card shadow="hover" header="个人信息">
|
<el-card shadow="hover" header="个人信息">
|
||||||
<div class="personal-user">
|
<div class="personal-user">
|
||||||
<div class="personal-user-left">
|
<div class="personal-user-left">
|
||||||
<el-upload class="h100 personal-user-left-upload" :action="uploadAvatar.action" :headers="uploadAvatar.headers" multiple :limit="1">
|
<el-upload class="h100 personal-user-left-upload" :action="uploadAvatar.action" :headers="uploadAvatar.headers" multiple :limit="1">
|
||||||
<img v-if="state.personalForm.avatar" :src="state.personalForm.avatar" />
|
<img v-if="state.personalForm.avatar" :src="state.personalForm.avatar" />
|
||||||
<img v-else src="https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500" />
|
<img v-else src="https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500" />
|
||||||
</el-upload>
|
</el-upload>
|
||||||
</div>
|
</div>
|
||||||
<div class="personal-user-right">
|
<div class="personal-user-right">
|
||||||
<el-row>
|
<el-row>
|
||||||
<el-col :span="24" class="personal-title mb18">{{ currentTime }},{{state.personalForm.username}},生活变的再糟糕,也不妨碍我变得更好! </el-col>
|
<el-col :span="24" class="personal-title mb18"
|
||||||
<el-col :span="24">
|
>{{ currentTime }},{{ state.personalForm.username }},生活变的再糟糕,也不妨碍我变得更好!
|
||||||
<el-row>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="8" class="personal-item mb6">
|
<el-col :span="24">
|
||||||
<div class="personal-item-label">昵称:</div>
|
<el-row>
|
||||||
<div class="personal-item-value">{{state.personalForm.name}}</div>
|
<el-col :xs="24" :sm="8" class="personal-item mb6">
|
||||||
</el-col>
|
<div class="personal-item-label">昵称:</div>
|
||||||
<el-col :xs="24" :sm="16" class="personal-item mb6">
|
<div class="personal-item-value">{{ state.personalForm.name }}</div>
|
||||||
<div class="personal-item-label">部门:</div>
|
</el-col>
|
||||||
<div class="personal-item-value">
|
<el-col :xs="24" :sm="16" class="personal-item mb6">
|
||||||
<el-tag >{{state.personalForm.dept_info.dept_name}}</el-tag>
|
<div class="personal-item-label">部门:</div>
|
||||||
</div>
|
<div class="personal-item-value">
|
||||||
</el-col>
|
<el-tag>{{ state.personalForm.dept_info.dept_name }}</el-tag>
|
||||||
</el-row>
|
</div>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="24">
|
</el-row>
|
||||||
<el-row>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="24" class="personal-item mb6">
|
<el-col :span="24">
|
||||||
<div class="personal-item-label">角色:</div>
|
<el-row>
|
||||||
<div class="personal-item-value">
|
<el-col :xs="24" :sm="24" class="personal-item mb6">
|
||||||
<el-tag v-for="(item,index) in state.personalForm.role_info" :key="index">{{item.name}}</el-tag>
|
<div class="personal-item-label">角色:</div>
|
||||||
</div>
|
<div class="personal-item-value">
|
||||||
</el-col>
|
<el-tag v-for="(item, index) in state.personalForm.role_info" :key="index">{{ item.name }}</el-tag>
|
||||||
</el-row>
|
</div>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</div>
|
</el-col>
|
||||||
</div>
|
</el-row>
|
||||||
</el-card>
|
</div>
|
||||||
</el-col>
|
</div>
|
||||||
|
</el-card>
|
||||||
|
</el-col>
|
||||||
|
|
||||||
<!-- 消息通知 -->
|
<!-- 消息通知 -->
|
||||||
<el-col :xs="24" :sm="8" class="pl15 personal-info">
|
<el-col :xs="24" :sm="8" class="pl15 personal-info">
|
||||||
<el-card shadow="hover">
|
<el-card shadow="hover">
|
||||||
<template #header>
|
<template #header>
|
||||||
<span>消息通知</span>
|
<span>消息通知</span>
|
||||||
<span class="personal-info-more" @click="msgMore">更多</span>
|
<span class="personal-info-more" @click="msgMore">更多</span>
|
||||||
</template>
|
</template>
|
||||||
<div class="personal-info-box">
|
<div class="personal-info-box">
|
||||||
<ul class="personal-info-ul">
|
<ul class="personal-info-ul">
|
||||||
<li v-for="(v, k) in state.newsInfoList" :key="k" class="personal-info-li">
|
<li v-for="(v, k) in state.newsInfoList" :key="k" class="personal-info-li">
|
||||||
<div class="personal-info-li-title">
|
<div class="personal-info-li-title">[{{ v.creator_name }},{{ v.create_datetime }}] {{ v.title }}</div>
|
||||||
[{{v.creator_name}},{{v.create_datetime}}] {{v.title}}
|
</li>
|
||||||
</div>
|
</ul>
|
||||||
</li>
|
</div>
|
||||||
</ul>
|
</el-card>
|
||||||
</div>
|
</el-col>
|
||||||
</el-card>
|
|
||||||
</el-col>
|
|
||||||
|
|
||||||
<!-- 更新信息 -->
|
<!-- 更新信息 -->
|
||||||
<el-col :span="24">
|
<el-col :span="24">
|
||||||
<el-card shadow="hover" class="mt15 personal-edit" header="更新信息">
|
<el-card shadow="hover" class="mt15 personal-edit" header="更新信息">
|
||||||
<div class="personal-edit-title">基本信息</div>
|
<div class="personal-edit-title">基本信息</div>
|
||||||
<el-form :model="state.personalForm" ref="userInfoFormRef" :rules="rules" size="default" label-width="50px" class="mt35 mb35">
|
<el-form :model="state.personalForm" ref="userInfoFormRef" :rules="rules" size="default" label-width="50px" class="mt35 mb35">
|
||||||
<el-row :gutter="35">
|
<el-row :gutter="35">
|
||||||
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
<el-form-item label="昵称" prop="name">
|
<el-form-item label="昵称" prop="name">
|
||||||
<el-input v-model="state.personalForm.name" placeholder="请输入昵称" clearable></el-input>
|
<el-input v-model="state.personalForm.name" placeholder="请输入昵称" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
<el-form-item label="邮箱">
|
<el-form-item label="邮箱">
|
||||||
<el-input v-model="state.personalForm.email" placeholder="请输入邮箱" clearable></el-input>
|
<el-input v-model="state.personalForm.email" placeholder="请输入邮箱" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
<el-form-item label="手机" prop="mobile">
|
<el-form-item label="手机" prop="mobile">
|
||||||
<el-input v-model="state.personalForm.mobile" placeholder="请输入手机" clearable></el-input>
|
<el-input v-model="state.personalForm.mobile" placeholder="请输入手机" clearable></el-input>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
||||||
<el-form-item label="性别">
|
<el-form-item label="性别">
|
||||||
<el-select v-model="state.personalForm.gender" placeholder="请选择性别" clearable class="w100">
|
<el-select v-model="state.personalForm.gender" placeholder="请选择性别" clearable class="w100">
|
||||||
<el-option label="男" :value="1"></el-option>
|
<el-option label="男" :value="1"></el-option>
|
||||||
<el-option label="女" :value="0"></el-option>
|
<el-option label="女" :value="0"></el-option>
|
||||||
<el-option label="保密" :value="2"></el-option>
|
<el-option label="保密" :value="2"></el-option>
|
||||||
</el-select>
|
</el-select>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
|
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
|
||||||
<el-form-item>
|
<el-form-item>
|
||||||
<el-button type="primary" @click="submitForm">
|
<el-button type="primary" @click="submitForm">
|
||||||
<el-icon>
|
<el-icon>
|
||||||
<ele-Position />
|
<ele-Position />
|
||||||
</el-icon>
|
</el-icon>
|
||||||
更新个人信息
|
更新个人信息
|
||||||
</el-button>
|
</el-button>
|
||||||
</el-form-item>
|
</el-form-item>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
</el-form>
|
</el-form>
|
||||||
<div class="personal-edit-title mb15">账号安全</div>
|
<div class="personal-edit-title mb15">账号安全</div>
|
||||||
<div class="personal-edit-safe-box">
|
<div class="personal-edit-safe-box">
|
||||||
<div class="personal-edit-safe-item">
|
<div class="personal-edit-safe-item">
|
||||||
<div class="personal-edit-safe-item-left">
|
<div class="personal-edit-safe-item-left">
|
||||||
<div class="personal-edit-safe-item-left-label">账户密码</div>
|
<div class="personal-edit-safe-item-left-label">账户密码</div>
|
||||||
<div class="personal-edit-safe-item-left-value">当前密码强度:强</div>
|
<div class="personal-edit-safe-item-left-value">当前密码强度:强</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="personal-edit-safe-item-right">
|
<div class="personal-edit-safe-item-right">
|
||||||
<el-button text type="primary" @click="passwordFormShow=true">立即修改</el-button>
|
<el-button text type="primary" @click="passwordFormShow = true">立即修改</el-button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="personal-edit-safe-box">
|
<div class="personal-edit-safe-box">
|
||||||
<div class="personal-edit-safe-item">
|
<div class="personal-edit-safe-item">
|
||||||
<div class="personal-edit-safe-item-left">
|
<div class="personal-edit-safe-item-left">
|
||||||
<div class="personal-edit-safe-item-left-label">密保手机</div>
|
<div class="personal-edit-safe-item-left-label">密保手机</div>
|
||||||
<div class="personal-edit-safe-item-left-value">已绑定手机:{{state.personalForm.mobile}}</div>
|
<div class="personal-edit-safe-item-left-value">已绑定手机:{{ state.personalForm.mobile }}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="personal-edit-safe-item-right">
|
<div class="personal-edit-safe-item-right">
|
||||||
<!-- <el-button text type="primary">立即修改</el-button>-->
|
<!-- <el-button text type="primary">立即修改</el-button>-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="personal-edit-safe-box">
|
<div class="personal-edit-safe-box">
|
||||||
<div class="personal-edit-safe-item">
|
<div class="personal-edit-safe-item">
|
||||||
<div class="personal-edit-safe-item-left">
|
<div class="personal-edit-safe-item-left">
|
||||||
<div class="personal-edit-safe-item-left-label">绑定邮箱</div>
|
<div class="personal-edit-safe-item-left-label">绑定邮箱</div>
|
||||||
<div class="personal-edit-safe-item-left-value">已绑定邮箱:{{state.personalForm.email}}</div>
|
<div class="personal-edit-safe-item-left-value">已绑定邮箱:{{ state.personalForm.email }}</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="personal-edit-safe-item-right">
|
<div class="personal-edit-safe-item-right">
|
||||||
<!-- <el-button text type="primary">立即设置</el-button>-->
|
<!-- <el-button text type="primary">立即设置</el-button>-->
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</el-card>
|
</el-card>
|
||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
<!-- 密码修改-->
|
<!-- 密码修改-->
|
||||||
<el-dialog v-model="passwordFormShow" title="密码修改">
|
<el-dialog v-model="passwordFormShow" title="密码修改">
|
||||||
<el-form
|
<el-form
|
||||||
ref="userPasswordFormRef"
|
ref="userPasswordFormRef"
|
||||||
:model="userPasswordInfo"
|
:model="userPasswordInfo"
|
||||||
required-asterisk
|
required-asterisk
|
||||||
label-width="100px"
|
label-width="100px"
|
||||||
label-position="left"
|
label-position="left"
|
||||||
:rules="passwordRules"
|
:rules="passwordRules"
|
||||||
center
|
center
|
||||||
>
|
>
|
||||||
<el-form-item label="原密码" required prop="oldPassword">
|
<el-form-item label="原密码" required prop="oldPassword">
|
||||||
<el-input
|
<el-input v-model="userPasswordInfo.oldPassword" placeholder="请输入原始密码" clearable></el-input>
|
||||||
v-model="userPasswordInfo.oldPassword"
|
</el-form-item>
|
||||||
placeholder="请输入原始密码"
|
<el-form-item required prop="newPassword" label="新密码">
|
||||||
clearable
|
<el-input type="password" v-model="userPasswordInfo.newPassword" placeholder="请输入新密码" show-password clearable></el-input>
|
||||||
></el-input>
|
</el-form-item>
|
||||||
</el-form-item>
|
<el-form-item required prop="newPassword2" label="确认密码">
|
||||||
<el-form-item required prop="newPassword" label="新密码">
|
<el-input type="password" v-model="userPasswordInfo.newPassword2" placeholder="请再次输入新密码" show-password clearable></el-input>
|
||||||
<el-input
|
</el-form-item>
|
||||||
type="password"
|
</el-form>
|
||||||
v-model="userPasswordInfo.newPassword"
|
<template #footer>
|
||||||
placeholder="请输入新密码"
|
<span class="dialog-footer">
|
||||||
show-password
|
<el-button type="primary" @click="settingPassword"> <i class="fa fa-check"></i>提交 </el-button>
|
||||||
clearable
|
</span>
|
||||||
></el-input>
|
</template>
|
||||||
</el-form-item>
|
</el-dialog>
|
||||||
<el-form-item required prop="newPassword2" label="确认密码">
|
</div>
|
||||||
<el-input
|
|
||||||
type="password"
|
|
||||||
v-model="userPasswordInfo.newPassword2"
|
|
||||||
placeholder="请再次输入新密码"
|
|
||||||
show-password
|
|
||||||
clearable
|
|
||||||
></el-input>
|
|
||||||
</el-form-item>
|
|
||||||
</el-form>
|
|
||||||
<template #footer>
|
|
||||||
<span class="dialog-footer">
|
|
||||||
<el-button type="primary" @click="settingPassword">
|
|
||||||
<i class="fa fa-check"></i>提交
|
|
||||||
</el-button>
|
|
||||||
|
|
||||||
</span>
|
|
||||||
</template>
|
|
||||||
</el-dialog>
|
|
||||||
</div>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup lang="ts" name="personal">
|
<script setup lang="ts" name="personal">
|
||||||
import { reactive, computed,onMounted,ref } from 'vue';
|
import { reactive, computed, onMounted, ref } from 'vue';
|
||||||
import { formatAxis } from '/@/utils/formatTime';
|
import { formatAxis } from '/@/utils/formatTime';
|
||||||
import * as api from './api'
|
import * as api from './api';
|
||||||
import {ElMessage } from "element-plus";
|
import { ElMessage } from 'element-plus';
|
||||||
import {getBaseURL} from "/@/utils/baseUrl";
|
import { getBaseURL } from '/@/utils/baseUrl';
|
||||||
import { Session } from '/@/utils/storage';
|
import { Session } from '/@/utils/storage';
|
||||||
|
import { useRouter } from 'vue-router';
|
||||||
|
|
||||||
// 当前时间提示语
|
// 当前时间提示语
|
||||||
const currentTime = computed(() => {
|
const currentTime = computed(() => {
|
||||||
return formatAxis(new Date());
|
return formatAxis(new Date());
|
||||||
});
|
});
|
||||||
const userInfoFormRef = ref()
|
const userInfoFormRef = ref();
|
||||||
const rules = reactive({
|
const rules = reactive({
|
||||||
name: [{ required: true, message: '请输入昵称', trigger: 'blur' }],
|
name: [{ required: true, message: '请输入昵称', trigger: 'blur' }],
|
||||||
mobile: [{ pattern: /^1[3-9]\d{9}$/, message: '请输入正确手机号' }]
|
mobile: [{ pattern: /^1[3-9]\d{9}$/, message: '请输入正确手机号' }],
|
||||||
})
|
});
|
||||||
// 定义变量内容
|
// 定义变量内容
|
||||||
const uploadAvatar = reactive({
|
const uploadAvatar = reactive({
|
||||||
action:getBaseURL() + 'api/system/file/',
|
action: getBaseURL() + 'api/system/file/',
|
||||||
headers: {
|
headers: {
|
||||||
Authorization: 'JWT ' + Session.get('token')
|
Authorization: 'JWT ' + Session.get('token'),
|
||||||
},
|
},
|
||||||
})
|
});
|
||||||
const state = reactive<PersonalState>({
|
const state = reactive<PersonalState>({
|
||||||
newsInfoList:[],
|
newsInfoList: [],
|
||||||
personalForm: {
|
personalForm: {
|
||||||
avatar:'',
|
avatar: '',
|
||||||
username:'',
|
username: '',
|
||||||
name: '',
|
name: '',
|
||||||
email: '',
|
email: '',
|
||||||
mobile: '',
|
mobile: '',
|
||||||
gender:'',
|
gender: '',
|
||||||
dept_info:{
|
dept_info: {
|
||||||
dept_id:0,
|
dept_id: 0,
|
||||||
dept_name:''
|
dept_name: '',
|
||||||
},
|
},
|
||||||
role_info:[{
|
role_info: [
|
||||||
id:0,
|
{
|
||||||
name:''
|
id: 0,
|
||||||
}]
|
name: '',
|
||||||
},
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 跳转消息中心
|
* 跳转消息中心
|
||||||
*/
|
*/
|
||||||
import {useRouter } from "vue-router";
|
const route = useRouter();
|
||||||
import {Session} from "/@/utils/storage";
|
const msgMore = () => {
|
||||||
const route = useRouter()
|
route.push({ path: '/messageCenter' });
|
||||||
const msgMore=()=>{
|
};
|
||||||
route.push({path:'/messageCenter'})
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取用户个人信息
|
* 获取用户个人信息
|
||||||
*/
|
*/
|
||||||
const getUserInfo = function (){
|
const getUserInfo = function () {
|
||||||
api.GetUserInfo({}).then((res:any)=>{
|
api.GetUserInfo({}).then((res: any) => {
|
||||||
const {data} = res
|
const { data } = res;
|
||||||
state.personalForm.avatar = data.avatar || '';
|
state.personalForm.avatar = data.avatar || '';
|
||||||
state.personalForm.username = data.username || '';
|
state.personalForm.username = data.username || '';
|
||||||
state.personalForm.name = data.name || '';
|
state.personalForm.name = data.name || '';
|
||||||
state.personalForm.email = data.email || '';
|
state.personalForm.email = data.email || '';
|
||||||
state.personalForm.mobile = data.mobile || '';
|
state.personalForm.mobile = data.mobile || '';
|
||||||
state.personalForm.gender = data.gender || '';
|
state.personalForm.gender = data.gender;
|
||||||
state.personalForm.dept_info.dept_name = data.dept_info.dept_name || '';
|
state.personalForm.dept_info.dept_name = data.dept_info.dept_name || '';
|
||||||
state.personalForm.role_info = data.role_info || [];
|
state.personalForm.role_info = data.role_info || [];
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 更新用户信息
|
* 更新用户信息
|
||||||
* @param formEl
|
* @param formEl
|
||||||
*/
|
*/
|
||||||
const submitForm = async () => {
|
const submitForm = async () => {
|
||||||
if (!userInfoFormRef.value) return
|
if (!userInfoFormRef.value) return;
|
||||||
await userInfoFormRef.value.validate((valid, fields) => {
|
await userInfoFormRef.value.validate((valid, fields) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
api.updateUserInfo(state.personalForm).then((res:any)=>{
|
api.updateUserInfo(state.personalForm).then((res: any) => {
|
||||||
ElMessage.success('更新成功')
|
ElMessage.success('更新成功');
|
||||||
getUserInfo()
|
getUserInfo();
|
||||||
})
|
});
|
||||||
} else {
|
} else {
|
||||||
ElMessage.error('表单验证失败,请检查~')
|
ElMessage.error('表单验证失败,请检查~');
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 获取消息通知
|
* 获取消息通知
|
||||||
*/
|
*/
|
||||||
const getMsg = () => {
|
const getMsg = () => {
|
||||||
api.GetSelfReceive({}).then((res:any)=>{
|
api.GetSelfReceive({}).then((res: any) => {
|
||||||
const {data} = res
|
const { data } = res;
|
||||||
state.newsInfoList = data || [];
|
state.newsInfoList = data || [];
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
onMounted(()=>{
|
onMounted(() => {
|
||||||
getUserInfo();
|
getUserInfo();
|
||||||
getMsg();
|
getMsg();
|
||||||
})
|
});
|
||||||
|
|
||||||
/**************************密码修改部分************************/
|
/**************************密码修改部分************************/
|
||||||
const passwordFormShow = ref(false)
|
const passwordFormShow = ref(false);
|
||||||
const userPasswordFormRef = ref()
|
const userPasswordFormRef = ref();
|
||||||
const userPasswordInfo=reactive({
|
const userPasswordInfo = reactive({
|
||||||
oldPassword: '',
|
oldPassword: '',
|
||||||
newPassword: '',
|
newPassword: '',
|
||||||
newPassword2: ''
|
newPassword2: '',
|
||||||
})
|
});
|
||||||
|
|
||||||
const validatePass = (rule, value, callback) => {
|
const validatePass = (rule, value, callback) => {
|
||||||
const pwdRegex = new RegExp('(?=.*[0-9])(?=.*[a-zA-Z]).{8,30}')
|
const pwdRegex = new RegExp('(?=.*[0-9])(?=.*[a-zA-Z]).{8,30}');
|
||||||
if (value === '') {
|
if (value === '') {
|
||||||
callback(new Error('请输入密码'))
|
callback(new Error('请输入密码'));
|
||||||
} else if (value === userPasswordInfo.oldPassword) {
|
} else if (value === userPasswordInfo.oldPassword) {
|
||||||
callback(new Error('原密码与新密码一致'))
|
callback(new Error('原密码与新密码一致'));
|
||||||
} else if (!pwdRegex.test(value)) {
|
} else if (!pwdRegex.test(value)) {
|
||||||
callback(new Error('您的密码复杂度太低(密码中必须包含字母、数字)'))
|
callback(new Error('您的密码复杂度太低(密码中必须包含字母、数字)'));
|
||||||
} else {
|
} else {
|
||||||
if (userPasswordInfo.newPassword2 !== '') {
|
if (userPasswordInfo.newPassword2 !== '') {
|
||||||
userPasswordFormRef.value.validateField('newPassword2')
|
userPasswordFormRef.value.validateField('newPassword2');
|
||||||
}
|
}
|
||||||
callback()
|
callback();
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
const validatePass2 = (rule, value, callback) => {
|
const validatePass2 = (rule, value, callback) => {
|
||||||
if (value === '') {
|
if (value === '') {
|
||||||
callback(new Error('请再次输入密码'))
|
callback(new Error('请再次输入密码'));
|
||||||
} else if (value !== userPasswordInfo.newPassword) {
|
} else if (value !== userPasswordInfo.newPassword) {
|
||||||
callback(new Error('两次输入密码不一致!'))
|
callback(new Error('两次输入密码不一致!'));
|
||||||
} else {
|
} else {
|
||||||
callback()
|
callback();
|
||||||
}
|
}
|
||||||
}
|
};
|
||||||
|
|
||||||
const passwordRules=reactive({
|
const passwordRules = reactive({
|
||||||
oldPassword: [
|
oldPassword: [
|
||||||
{
|
{
|
||||||
required: true,
|
required: true,
|
||||||
message: '请输入原密码',
|
message: '请输入原密码',
|
||||||
trigger: 'blur'
|
trigger: 'blur',
|
||||||
}
|
},
|
||||||
],
|
],
|
||||||
newPassword: [{ validator: validatePass, trigger: 'blur' }],
|
newPassword: [{ validator: validatePass, trigger: 'blur' }],
|
||||||
newPassword2: [{ validator: validatePass2, trigger: 'blur' }]
|
newPassword2: [{ validator: validatePass2, trigger: 'blur' }],
|
||||||
})
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 重新设置密码
|
* 重新设置密码
|
||||||
*/
|
*/
|
||||||
const settingPassword= ()=>{
|
const settingPassword = () => {
|
||||||
userPasswordFormRef.value.validate((valid) => {
|
userPasswordFormRef.value.validate((valid) => {
|
||||||
if (valid) {
|
if (valid) {
|
||||||
api.UpdatePassword(userPasswordInfo).then((res:any)=>{
|
api.UpdatePassword(userPasswordInfo).then((res: any) => {
|
||||||
ElMessage.success('密码修改成功')
|
ElMessage.success('密码修改成功');
|
||||||
})
|
});
|
||||||
} else {
|
} else {
|
||||||
// 校验失败
|
// 校验失败
|
||||||
// 登录表单校验失败
|
// 登录表单校验失败
|
||||||
ElMessage.error('表单校验失败,请检查')
|
ElMessage.error('表单校验失败,请检查');
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
}
|
};
|
||||||
|
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
@import '/@/theme/mixins/index.scss';
|
@import '/@/theme/mixins/index.scss';
|
||||||
.personal {
|
.personal {
|
||||||
.personal-user {
|
.personal-user {
|
||||||
height: 130px;
|
height: 130px;
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
.personal-user-left {
|
.personal-user-left {
|
||||||
width: 100px;
|
width: 100px;
|
||||||
height: 130px;
|
height: 130px;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
:deep(.el-upload) {
|
:deep(.el-upload) {
|
||||||
height: 100%;
|
height: 100%;
|
||||||
}
|
}
|
||||||
.personal-user-left-upload {
|
.personal-user-left-upload {
|
||||||
img {
|
img {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
}
|
}
|
||||||
&:hover {
|
&:hover {
|
||||||
img {
|
img {
|
||||||
animation: logoAnimation 0.3s ease-in-out;
|
animation: logoAnimation 0.3s ease-in-out;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-user-right {
|
.personal-user-right {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
padding: 0 15px;
|
padding: 0 15px;
|
||||||
.personal-title {
|
.personal-title {
|
||||||
font-size: 18px;
|
font-size: 18px;
|
||||||
@include text-ellipsis(1);
|
@include text-ellipsis(1);
|
||||||
}
|
}
|
||||||
.personal-item {
|
.personal-item {
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
.personal-item-label {
|
.personal-item-label {
|
||||||
color: var(--el-text-color-secondary);
|
color: var(--el-text-color-secondary);
|
||||||
@include text-ellipsis(1);
|
@include text-ellipsis(1);
|
||||||
}
|
}
|
||||||
.personal-item-value {
|
.personal-item-value {
|
||||||
@include text-ellipsis(1);
|
@include text-ellipsis(1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-info {
|
.personal-info {
|
||||||
.personal-info-more {
|
.personal-info-more {
|
||||||
float: right;
|
float: right;
|
||||||
color: var(--el-text-color-secondary);
|
color: var(--el-text-color-secondary);
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
&:hover {
|
&:hover {
|
||||||
color: var(--el-color-primary);
|
color: var(--el-color-primary);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-info-box {
|
.personal-info-box {
|
||||||
height: 130px;
|
height: 130px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
.personal-info-ul {
|
.personal-info-ul {
|
||||||
list-style: none;
|
list-style: none;
|
||||||
.personal-info-li {
|
.personal-info-li {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
padding-bottom: 10px;
|
padding-bottom: 10px;
|
||||||
.personal-info-li-title {
|
.personal-info-li-title {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
@include text-ellipsis(1);
|
@include text-ellipsis(1);
|
||||||
color: var(--el-text-color-secondary);
|
color: var(--el-text-color-secondary);
|
||||||
text-decoration: none;
|
text-decoration: none;
|
||||||
}
|
}
|
||||||
& a:hover {
|
& a:hover {
|
||||||
color: var(--el-color-primary);
|
color: var(--el-color-primary);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-recommend-row {
|
.personal-recommend-row {
|
||||||
.personal-recommend-col {
|
.personal-recommend-col {
|
||||||
.personal-recommend {
|
.personal-recommend {
|
||||||
position: relative;
|
position: relative;
|
||||||
height: 100px;
|
height: 100px;
|
||||||
border-radius: 3px;
|
border-radius: 3px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
&:hover {
|
&:hover {
|
||||||
i {
|
i {
|
||||||
right: 0px !important;
|
right: 0px !important;
|
||||||
bottom: 0px !important;
|
bottom: 0px !important;
|
||||||
transition: all ease 0.3s;
|
transition: all ease 0.3s;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
i {
|
i {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: -10px;
|
right: -10px;
|
||||||
bottom: -10px;
|
bottom: -10px;
|
||||||
font-size: 70px;
|
font-size: 70px;
|
||||||
transform: rotate(-30deg);
|
transform: rotate(-30deg);
|
||||||
transition: all ease 0.3s;
|
transition: all ease 0.3s;
|
||||||
}
|
}
|
||||||
.personal-recommend-auto {
|
.personal-recommend-auto {
|
||||||
padding: 15px;
|
padding: 15px;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 0;
|
left: 0;
|
||||||
top: 5%;
|
top: 5%;
|
||||||
color: var(--next-color-white);
|
color: var(--next-color-white);
|
||||||
.personal-recommend-msg {
|
.personal-recommend-msg {
|
||||||
font-size: 12px;
|
font-size: 12px;
|
||||||
margin-top: 10px;
|
margin-top: 10px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-edit {
|
.personal-edit {
|
||||||
.personal-edit-title {
|
.personal-edit-title {
|
||||||
position: relative;
|
position: relative;
|
||||||
padding-left: 10px;
|
padding-left: 10px;
|
||||||
color: var(--el-text-color-regular);
|
color: var(--el-text-color-regular);
|
||||||
&::after {
|
&::after {
|
||||||
content: '';
|
content: '';
|
||||||
width: 2px;
|
width: 2px;
|
||||||
height: 10px;
|
height: 10px;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
left: 0;
|
left: 0;
|
||||||
top: 50%;
|
top: 50%;
|
||||||
transform: translateY(-50%);
|
transform: translateY(-50%);
|
||||||
background: var(--el-color-primary);
|
background: var(--el-color-primary);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.personal-edit-safe-box {
|
.personal-edit-safe-box {
|
||||||
border-bottom: 1px solid var(--el-border-color-light, #ebeef5);
|
border-bottom: 1px solid var(--el-border-color-light, #ebeef5);
|
||||||
padding: 15px 0;
|
padding: 15px 0;
|
||||||
.personal-edit-safe-item {
|
.personal-edit-safe-item {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
display: flex;
|
display: flex;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: space-between;
|
justify-content: space-between;
|
||||||
.personal-edit-safe-item-left {
|
.personal-edit-safe-item-left {
|
||||||
flex: 1;
|
flex: 1;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
.personal-edit-safe-item-left-label {
|
.personal-edit-safe-item-left-label {
|
||||||
color: var(--el-text-color-regular);
|
color: var(--el-text-color-regular);
|
||||||
margin-bottom: 5px;
|
margin-bottom: 5px;
|
||||||
}
|
}
|
||||||
.personal-edit-safe-item-left-value {
|
.personal-edit-safe-item-left-value {
|
||||||
color: var(--el-text-color-secondary);
|
color: var(--el-text-color-secondary);
|
||||||
@include text-ellipsis(1);
|
@include text-ellipsis(1);
|
||||||
margin-right: 15px;
|
margin-right: 15px;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
&:last-of-type {
|
&:last-of-type {
|
||||||
padding-bottom: 0;
|
padding-bottom: 0;
|
||||||
border-bottom: none;
|
border-bottom: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|||||||
Reference in New Issue
Block a user