fix 修改个人信息同时更新登录用户信息

This commit is contained in:
yxh 2023-04-03 22:17:25 +08:00
parent 403df9aa2a
commit 731fb66724

View File

@ -1,387 +1,516 @@
<template> <template>
<div class="personal"> <div class="personal">
<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="https://jsonplaceholder.typicode.com/posts/" multiple :limit="1"> <el-upload
<img src="https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500" /> class=" h100 personal-user-left-upload avatar-uploader"
</el-upload> :action="baseURL+'/api/v1/system/upload/singleImg'"
</div> :show-file-list="false"
<div class="personal-user-right"> :on-success="handleAvatarSuccess"
<el-row> :data="dataParam"
<el-col :span="24" class="personal-title mb18">{{ currentTime }}admin生活变的再糟糕也不妨碍我变得更好 </el-col> >
<el-col :span="24"> <img v-if="imageUrl" :src="proxy.getUpFileUrl(imageUrl)" class="avatar" />
<el-row> <el-icon v-else class="avatar-uploader-icon"><ele-Plus /></el-icon>
<el-col :xs="24" :sm="8" class="personal-item mb6">
<div class="personal-item-label">昵称</div>
<div class="personal-item-value">小柒</div>
</el-col>
<el-col :xs="24" :sm="16" class="personal-item mb6">
<div class="personal-item-label">身份</div>
<div class="personal-item-value">超级管理</div>
</el-col>
</el-row>
</el-col>
<el-col :span="24">
<el-row>
<el-col :xs="24" :sm="8" class="personal-item mb6">
<div class="personal-item-label">登录IP</div>
<div class="personal-item-value">192.168.1.1</div>
</el-col>
<el-col :xs="24" :sm="16" class="personal-item mb6">
<div class="personal-item-label">登录时间</div>
<div class="personal-item-value">2021-02-05 18:47:26</div>
</el-col>
</el-row>
</el-col>
</el-row>
</div>
</div>
</el-card>
</el-col>
<!-- 消息通知 --> </el-upload>
<el-col :xs="24" :sm="8" class="pl15 personal-info"> </div>
<el-card shadow="hover"> <div class="personal-user-right">
<template #header> <el-row>
<span>消息通知</span> <el-col :span="24" class="personal-title mb18">{{ currentTime }}{{ personalForm.nickname }}{{ personalForm.describe }} </el-col>
<span class="personal-info-more">更多</span> <el-col :span="24">
</template> <el-row>
<div class="personal-info-box"> <el-col :xs="24" :sm="8" class="personal-item mb6">
<ul class="personal-info-ul"> <div class="personal-item-label">昵称</div>
<li v-for="(v, k) in newsInfoList" :key="k" class="personal-info-li"> <div class="personal-item-value"> {{ personalForm.nickname }}</div>
<a :href="v.link" target="_block" class="personal-info-li-title">{{ v.title }}</a> </el-col>
</li> <el-col :xs="24" :sm="16" class="personal-item mb6">
</ul> <div class="personal-item-label">联系电话</div>
</div> <div class="personal-item-value">{{ personalForm.mobile }}</div>
</el-card> </el-col>
</el-col> </el-row>
</el-col>
<el-col :span="24">
<el-row>
<el-col :xs="24" :sm="8" class="personal-item mb6">
<div class="personal-item-label">登录IP</div>
<div class="personal-item-value">{{personalForm.lastLoginIp}}</div>
</el-col>
<el-col :xs="24" :sm="16" class="personal-item mb6">
<div class="personal-item-label">登录时间</div>
<div class="personal-item-value">{{personalForm.lastLoginTime}}</div>
</el-col>
</el-row>
</el-col>
<el-col :span="24">
<el-row>
<el-col :xs="24" :sm="8" class="personal-item mb6">
<div class="personal-item-label">所属部门</div>
<div class="personal-item-value">{{ deptName }}</div>
</el-col>
<el-col :xs="24" :sm="16" class="personal-item mb6">
<div class="personal-item-label">所属角色</div>
<div class="personal-item-value">{{ roles.join(',') }}</div>
</el-col>
</el-row>
</el-col>
</el-row>
</div>
</div>
</el-card>
</el-col>
<!-- 营销推荐 --> <!-- 消息通知 -->
<el-col :span="24"> <el-col :xs="24" :sm="8" class="pl15 personal-info">
<el-card shadow="hover" class="mt15" header="营销推荐"> <el-card shadow="hover">
<el-row :gutter="15" class="personal-recommend-row"> <template #header>
<el-col :sm="6" v-for="(v, k) in recommendList" :key="k" class="personal-recommend-col"> <span>消息通知</span>
<div class="personal-recommend" :style="{ 'background-color': v.bg }"> <span class="personal-info-more">更多</span>
<SvgIcon :name="v.icon" :size="70" :style="{ color: v.iconColor }" /> </template>
<div class="personal-recommend-auto"> <div class="personal-info-box">
<div>{{ v.title }}</div> <ul class="personal-info-ul">
<div class="personal-recommend-msg">{{ v.msg }}</div> <li v-for="(v, k) in newsInfoList" :key="k" class="personal-info-li">
</div> <a :href="v.link" target="_block" class="personal-info-li-title">{{ v.title }}</a>
</div> </li>
</el-col> </ul>
</el-row> </div>
</el-card> </el-card>
</el-col> </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" header="营销推荐">
<div class="personal-edit-title">基本信息</div> <el-row :gutter="15" class="personal-recommend-row">
<el-form :model="personalForm" size="default" label-width="40px" class="mt35 mb35"> <el-col :sm="6" v-for="(v, k) in recommendList" :key="k" class="personal-recommend-col">
<el-row :gutter="35"> <div class="personal-recommend" :style="{ 'background-color': v.bg }">
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> <SvgIcon :name="v.icon" :size="70" :style="{ color: v.iconColor }" />
<el-form-item label="昵称"> <div class="personal-recommend-auto">
<el-input v-model="personalForm.name" placeholder="请输入昵称" clearable></el-input> <div>{{ v.title }}</div>
</el-form-item> <div class="personal-recommend-msg">{{ v.msg }}</div>
</el-col> </div>
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> </div>
<el-form-item label="邮箱"> </el-col>
<el-input v-model="personalForm.email" placeholder="请输入邮箱" clearable></el-input> </el-row>
</el-form-item> </el-card>
</el-col> </el-col>
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
<el-form-item label="签名"> <!-- 更新信息 -->
<el-input v-model="personalForm.autograph" placeholder="请输入签名" clearable></el-input> <el-col :span="24">
</el-form-item> <el-card shadow="hover" class="mt15 personal-edit" header="更新信息">
</el-col> <div class="personal-edit-title">基本信息</div>
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> <el-form :model="personalForm" size="default" label-width="40px" class="mt35 mb35">
<el-form-item label="职业"> <el-row :gutter="35">
<el-select v-model="personalForm.occupation" placeholder="请选择职业" clearable class="w100"> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
<el-option label="计算机 / 互联网 / 通信" value="1"></el-option> <el-form-item label="昵称">
<el-option label="生产 / 工艺 / 制造" value="2"></el-option> <el-input v-model="personalForm.nickname" placeholder="请输入昵称" clearable></el-input>
<el-option label="医疗 / 护理 / 制药" value="3"></el-option> </el-form-item>
</el-select> </el-col>
</el-form-item> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
</el-col> <el-form-item label="邮箱">
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> <el-input v-model="personalForm.userEmail" placeholder="请输入邮箱" clearable></el-input>
<el-form-item label="手机"> </el-form-item>
<el-input v-model="personalForm.phone" placeholder="请输入手机" clearable></el-input> </el-col>
</el-form-item> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
</el-col> <el-form-item label="签名">
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20"> <el-input v-model="personalForm.describe" placeholder="请输入签名" clearable></el-input>
<el-form-item label="性别"> </el-form-item>
<el-select v-model="personalForm.sex" placeholder="请选择性别" clearable class="w100"> </el-col>
<el-option label="男" value="1"></el-option> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
<el-option label="女" value="2"></el-option> <el-form-item label="职业">
</el-select> <el-select v-model="personalForm.remark" placeholder="请选择职业" clearable class="w100">
</el-form-item> <el-option label="计算机 / 互联网 / 通信" value="1"></el-option>
</el-col> <el-option label="生产 / 工艺 / 制造" value="2"></el-option>
<el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24"> <el-option label="医疗 / 护理 / 制药" value="3"></el-option>
<el-form-item> </el-select>
<el-button type="primary"> </el-form-item>
<el-icon> </el-col>
<ele-Position /> <el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
</el-icon> <el-form-item label="手机">
更新个人信息 <el-input v-model="personalForm.mobile" placeholder="请输入手机" clearable></el-input>
</el-button> </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-row> <el-form-item label="性别">
</el-form> <el-select v-model="personalForm.sex" placeholder="请选择性别" clearable class="w100">
<div class="personal-edit-title mb15">账号安全</div> <el-option label="男" value="1"></el-option>
<div class="personal-edit-safe-box"> <el-option label="女" value="2"></el-option>
<div class="personal-edit-safe-item"> </el-select>
<div class="personal-edit-safe-item-left"> </el-form-item>
<div class="personal-edit-safe-item-left-label">账户密码</div> </el-col>
<div class="personal-edit-safe-item-left-value">当前密码强度</div> <el-col :xs="24" :sm="24" :md="24" :lg="24" :xl="24">
</div> <el-form-item>
<div class="personal-edit-safe-item-right"> <el-button type="primary" @click="handleUpload">
<el-button text type="primary">立即修改</el-button> <el-icon>
</div> <ele-Position />
</div> </el-icon>
</div> 更新个人信息
<div class="personal-edit-safe-box"> </el-button>
<div class="personal-edit-safe-item"> </el-form-item>
<div class="personal-edit-safe-item-left"> </el-col>
<div class="personal-edit-safe-item-left-label">密保手机</div> </el-row>
<div class="personal-edit-safe-item-left-value">已绑定手机132****4108</div> </el-form>
</div> <div class="personal-edit-title mb15">账号安全</div>
<div class="personal-edit-safe-item-right"> <div class="personal-edit-safe-box">
<el-button text type="primary">立即修改</el-button> <div class="personal-edit-safe-item">
</div> <div class="personal-edit-safe-item-left">
</div> <div class="personal-edit-safe-item-left-label">账户密码</div>
</div> <div class="personal-edit-safe-item-left-value">当前密码强度</div>
<div class="personal-edit-safe-box"> </div>
<div class="personal-edit-safe-item"> <div class="personal-edit-safe-item-right">
<div class="personal-edit-safe-item-left"> <el-button text type="primary" @click="handleEditPass">立即修改</el-button>
<div class="personal-edit-safe-item-left-label">密保问题</div> </div>
<div class="personal-edit-safe-item-left-value">已设置密保问题账号安全大幅度提升</div> </div>
</div> </div>
<div class="personal-edit-safe-item-right"> <div class="personal-edit-safe-box">
<el-button text type="primary">立即设置</el-button> <div class="personal-edit-safe-item">
</div> <div class="personal-edit-safe-item-left">
</div> <div class="personal-edit-safe-item-left-label">密保手机</div>
</div> <div class="personal-edit-safe-item-left-value">已绑定手机132****4108</div>
<div class="personal-edit-safe-box"> </div>
<div class="personal-edit-safe-item"> <div class="personal-edit-safe-item-right">
<div class="personal-edit-safe-item-left"> <el-button text type="primary">立即修改</el-button>
<div class="personal-edit-safe-item-left-label">绑定QQ</div> </div>
<div class="personal-edit-safe-item-left-value">已绑定QQ110****566</div> </div>
</div> </div>
<div class="personal-edit-safe-item-right"> <div class="personal-edit-safe-box">
<el-button text type="primary">立即设置</el-button> <div class="personal-edit-safe-item">
</div> <div class="personal-edit-safe-item-left">
</div> <div class="personal-edit-safe-item-left-label">密保问题</div>
</div> <div class="personal-edit-safe-item-left-value">已设置密保问题账号安全大幅度提升</div>
</el-card> </div>
</el-col> <div class="personal-edit-safe-item-right">
</el-row> <el-button text type="primary">立即设置</el-button>
</div> </div>
</div>
</div>
<div class="personal-edit-safe-box">
<div class="personal-edit-safe-item">
<div class="personal-edit-safe-item-left">
<div class="personal-edit-safe-item-left-label">绑定QQ</div>
<div class="personal-edit-safe-item-left-value">已绑定QQ110****566</div>
</div>
<div class="personal-edit-safe-item-right">
<el-button text type="primary">立即设置</el-button>
</div>
</div>
</div>
</el-card>
</el-col>
</el-row>
</div>
</template> </template>
<script lang="ts"> <script lang="ts">
import { toRefs, reactive, computed, defineComponent } from 'vue'; import { toRefs, reactive, computed, defineComponent,getCurrentInstance,onMounted } from 'vue';
import { formatAxis } from '/@/utils/formatTime'; import { formatAxis } from '/@/utils/formatTime';
import { storeToRefs } from 'pinia';
import { useUserInfo } from '/@/stores/userInfo';
import {getPersonalInfo, editPersonal, resetPwdPersonal} from "/@/api/system/personal";
import type { UploadProps } from 'element-plus'
import {ElMessage} from "element-plus";
import {ElMessageBox} from 'element-plus'
import {getToken} from "/@/utils/gfast"
import { newsInfoList, recommendList } from './mock'; import { newsInfoList, recommendList } from './mock';
import {Session} from "/@/utils/storage";
// //
interface PersonalState { interface PersonalState {
newsInfoList: any; imageUrl:'',
recommendList: any; deptName: '';
personalForm: any; roles: [];
personalForm: any;
newsInfoList: any;
recommendList: any;
} }
export default defineComponent({ export default defineComponent({
name: 'personal', name: 'personals',
setup() { setup() {
const state = reactive<PersonalState>({ const baseURL:string|undefined|boolean = import.meta.env.VITE_API_URL
newsInfoList, const {proxy} = <any>getCurrentInstance();
recommendList, const stores = useUserInfo();
personalForm: { const { userInfos } = storeToRefs(stores);
name: '', const dataParam = reactive({
email: '', token:getToken(),
autograph: '', })
occupation: '', const state = reactive<PersonalState>({
phone: '', newsInfoList,
sex: '', recommendList,
}, imageUrl:'',
}); deptName:'',
// roles:[],
const currentTime = computed(() => { personalForm: {
return formatAxis(new Date()); nickname: '',
}); userEmail: '',
return { describe: '',
currentTime, mobile: '',
...toRefs(state), sex: '',
}; remark:'',
}, avatar:'',
lastLoginIp:'',
lastLoginTime:''
},
});
// const handleUpload =
const handleUpload = () => {
// console.log(state.personalForm)
editPersonal(state.personalForm).then((res:any)=>{
const userInfo = res.data.userInfo
userInfo.avatar = proxy.getUpFileUrl(userInfo.avatar)
// token
Session.set('token', res.data.token);
//
Session.set('userInfo', userInfo);
useUserInfo().setUserInfos();
ElMessage.success('已更新');
});
};
//
const currentTime = computed(() => {
return formatAxis(new Date());
});
const handleAvatarSuccess: UploadProps['onSuccess'] = (
response,
uploadFile
) => {
if(response.code == 0){
state.imageUrl = response.data.path;
state.personalForm.avatar = response.data.path;
handleUpload();
}
};
/** 重置密码按钮操作 */
const handleEditPass = ()=> {
ElMessageBox.prompt('请输入"' + state.personalForm.nickname + '"的新密码', "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消"
}).then(({ value }) => {
if(!value || value==''){
ElMessage.success('密码不能为空');
return
}
resetPwdPersonal({password:value}).then(() => {
ElMessage.success("修改成功,新密码是:" + value);
});
}).catch(() => {});
};
//
const initUserInfo = () => {
getPersonalInfo().then((res:any)=>{
const user = res.data.user;
state.imageUrl = user.avatar;
state.personalForm = {
nickname:user.userNickname,
userEmail:user.userEmail,
describe: user.describe,
mobile: user.mobile,
sex: String(user.sex),
remark:user.remark,
avatar:user.avatar,
lastLoginIp:user.lastLoginIp,
lastLoginTime:user.lastLoginTime
}
state.deptName = res.data.deptName;
state.roles = res.data.roles;
})
};
//
onMounted(() => {
initUserInfo();
});
return {
proxy,
baseURL,
userInfos,
currentTime,
handleUpload,
handleEditPass,
handleAvatarSuccess,
dataParam,
...toRefs(state),
};
},
}); });
</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: 130px;
height: 130px; height: 130px;
border-radius: 3px; border-radius: 3px;
:deep(.el-upload) { :deep(.el-upload) {
height: 100%; height: 100%;
} }
.personal-user-left-upload { .avatar-uploader{
img { border: 1px dashed var(--el-border-color);
width: 100%; border-radius: 6px;
height: 100%; cursor: pointer;
border-radius: 3px; position: relative;
} overflow: hidden;
&:hover { transition: var(--el-transition-duration-fast);
img { text-align: center;
animation: logoAnimation 0.3s ease-in-out; font-size: 20px;
} }
} .personal-user-left-upload {
} img {
} width: 100%;
.personal-user-right { height: 100%;
flex: 1; border-radius: 3px;
padding: 0 15px; }
.personal-title { &:hover {
font-size: 18px; img {
@include text-ellipsis(1); animation: logoAnimation 0.3s ease-in-out;
} }
.personal-item { }
display: flex; }
align-items: center; }
font-size: 13px; .personal-user-right {
.personal-item-label { flex: 1;
color: var(--el-text-color-secondary); padding: 0 15px;
@include text-ellipsis(1); .personal-title {
} font-size: 18px;
.personal-item-value { @include text-ellipsis(1);
@include text-ellipsis(1); }
} .personal-item {
} display: flex;
} align-items: center;
} font-size: 13px;
.personal-info { line-height: 26px;
.personal-info-more { .personal-item-label {
float: right; color: var(--el-text-color-secondary);
color: var(--el-text-color-secondary); @include text-ellipsis(1);
font-size: 13px; }
&:hover { .personal-item-value {
color: var(--el-color-primary); @include text-ellipsis(1);
cursor: pointer; }
} }
} }
.personal-info-box { }
height: 130px; .personal-info {
overflow: hidden; .personal-info-more {
.personal-info-ul { float: right;
list-style: none; color: var(--el-text-color-secondary);
.personal-info-li { font-size: 13px;
font-size: 13px; &:hover {
padding-bottom: 10px; color: var(--el-color-primary);
.personal-info-li-title { cursor: pointer;
display: inline-block; }
@include text-ellipsis(1); }
color: var(--el-text-color-secondary); .personal-info-box {
text-decoration: none; height: 130px;
} overflow: hidden;
& a:hover { .personal-info-ul {
color: var(--el-color-primary); list-style: none;
cursor: pointer; .personal-info-li {
} font-size: 13px;
} padding-bottom: 10px;
} .personal-info-li-title {
} display: inline-block;
} @include text-ellipsis(1);
.personal-recommend-row { color: var(--el-text-color-secondary);
.personal-recommend-col { text-decoration: none;
.personal-recommend { }
position: relative; & a:hover {
height: 100px; color: var(--el-color-primary);
border-radius: 3px; cursor: pointer;
overflow: hidden; }
cursor: pointer; }
&:hover { }
i { }
right: 0px !important; }
bottom: 0px !important; .personal-recommend-row {
transition: all ease 0.3s; .personal-recommend-col {
} .personal-recommend {
} position: relative;
i { height: 100px;
position: absolute; border-radius: 3px;
right: -10px; overflow: hidden;
bottom: -10px; cursor: pointer;
font-size: 70px; &:hover {
transform: rotate(-30deg); i {
transition: all ease 0.3s; right: 0px !important;
} bottom: 0px !important;
.personal-recommend-auto { transition: all ease 0.3s;
padding: 15px; }
position: absolute; }
left: 0; i {
top: 5%; position: absolute;
color: var(--next-color-white); right: -10px;
.personal-recommend-msg { bottom: -10px;
font-size: 12px; font-size: 70px;
margin-top: 10px; transform: rotate(-30deg);
} transition: all ease 0.3s;
} }
} .personal-recommend-auto {
} padding: 15px;
} position: absolute;
.personal-edit { left: 0;
.personal-edit-title { top: 5%;
position: relative; color: var(--next-color-white);
padding-left: 10px; .personal-recommend-msg {
color: var(--el-text-color-regular); font-size: 12px;
&::after { margin-top: 10px;
content: ''; }
width: 2px; }
height: 10px; }
position: absolute; }
left: 0; }
top: 50%; .personal-edit {
transform: translateY(-50%); .personal-edit-title {
background: var(--el-color-primary); position: relative;
} padding-left: 10px;
} color: var(--el-text-color-regular);
.personal-edit-safe-box { &::after {
border-bottom: 1px solid var(--el-border-color-light, #ebeef5); content: '';
padding: 15px 0; width: 2px;
.personal-edit-safe-item { height: 10px;
width: 100%; position: absolute;
display: flex; left: 0;
align-items: center; top: 50%;
justify-content: space-between; transform: translateY(-50%);
.personal-edit-safe-item-left { background: var(--el-color-primary);
flex: 1; }
overflow: hidden; }
.personal-edit-safe-item-left-label { .personal-edit-safe-box {
color: var(--el-text-color-regular); border-bottom: 1px solid var(--el-border-color-light, #ebeef5);
margin-bottom: 5px; padding: 15px 0;
} .personal-edit-safe-item {
.personal-edit-safe-item-left-value { width: 100%;
color: var(--el-text-color-secondary); display: flex;
@include text-ellipsis(1); align-items: center;
margin-right: 15px; justify-content: space-between;
} .personal-edit-safe-item-left {
} flex: 1;
} overflow: hidden;
&:last-of-type { .personal-edit-safe-item-left-label {
padding-bottom: 0; color: var(--el-text-color-regular);
border-bottom: none; margin-bottom: 5px;
} }
} .personal-edit-safe-item-left-value {
} color: var(--el-text-color-secondary);
@include text-ellipsis(1);
margin-right: 15px;
}
}
}
&:last-of-type {
padding-bottom: 0;
border-bottom: none;
}
}
}
} }
</style> </style>