<template>
|
<div class="personal layout-pd">
|
<el-row>
|
<!-- 个人信息 -->
|
<el-col :xs="24" :sm="16">
|
<el-card shadow="hover" header="个人信息">
|
<div class="personal-user">
|
<div class="personal-user-left">
|
<el-upload class="h100 personal-user-left-upload" action="https://jsonplaceholder.typicode.com/posts/" multiple :limit="1">
|
<img src="https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500" />
|
</el-upload>
|
</div>
|
<div class="personal-user-right">
|
<el-row>
|
<!-- <el-col :span="24" class="personal-title mb18">{{ currentTime }},admin,生活变的再糟糕,也不妨碍我变得更好! </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">{{state.personalForm.name}}</div>
|
</el-col>
|
<el-col :xs="24" :sm="16" class="personal-item mb6">
|
<div class="personal-item-label">身份:</div>
|
<div class="personal-item-value">
|
<el-tag style="margin-right:20px" type="warning" v-for="item in state.personalForm.roles" :key="item">{{item.roleText}}</el-tag>
|
</div>
|
</el-col>
|
</el-row>
|
</el-col>
|
<el-col :span="24">
|
<el-row>
|
<div v-for="item in userInfos.clientInfos" :key="item.code">
|
<el-tag style="margin-right:20px" type="primary" >{{item.clientName}}</el-tag>
|
</div>
|
</el-row>
|
</el-col>
|
</el-row>
|
</div>
|
</div>
|
</el-card>
|
</el-col>
|
|
<!-- 消息通知 -->
|
<el-col :xs="24" :sm="8" class="pl15 personal-info">
|
<el-card shadow="hover">
|
<template #header>
|
<span>消息通知</span>
|
<span class="personal-info-more">更多</span>
|
</template>
|
<div class="personal-info-box">
|
<ul class="personal-info-ul">
|
<li v-for="(v, k) in state.newsInfoList" :key="k" class="personal-info-li">
|
<a :href="v.link" target="_block" class="personal-info-li-title">{{ v.title }}</a>
|
</li>
|
</ul>
|
</div>
|
</el-card>
|
</el-col>
|
|
|
|
<!-- 更新信息 -->
|
<el-col :span="24">
|
<el-card shadow="hover" class="mt15 personal-edit" header="更新信息">
|
<div class="personal-edit-title">基本信息</div>
|
<el-form :model="state.personalForm" size="default" label-width="40px" class="mt35 mb35">
|
<el-row :gutter="35">
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-form-item label="姓名">
|
<el-input v-model="state.personalForm.name" placeholder="请输入昵称" clearable></el-input>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-form-item label="邮箱">
|
<el-input v-model="state.personalForm.email" placeholder="请输入邮箱" clearable></el-input>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-form-item label="手机">
|
<el-input v-model="state.personalForm.phone" placeholder="请输入手机" clearable></el-input>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-form-item label="性别">
|
<el-select v-model="state.personalForm.sex" placeholder="请选择性别" clearable class="w100">
|
<el-option label="男" :value="0"></el-option>
|
<el-option label="女" :value="1"></el-option>
|
</el-select>
|
</el-form-item>
|
</el-col>
|
<el-col :xs="24" :sm="12" :md="8" :lg="6" :xl="4" class="mb20">
|
<el-form-item>
|
<el-button type="primary" @click="updatePat">
|
<el-icon>
|
<ele-Position />
|
</el-icon>
|
更新个人信息
|
</el-button>
|
</el-form-item>
|
</el-col>
|
</el-row>
|
</el-form>
|
<div class="personal-edit-title mb15">账号安全</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">账户密码</div>
|
<div class="personal-edit-safe-item-left-value">当前密码强度:一般</div>
|
</div>
|
<div class="personal-edit-safe-item-right">
|
<el-button text type="primary" @click="updataPSWD">立即修改</el-button>
|
</div>
|
</div>
|
</div>
|
|
</el-card>
|
</el-col>
|
</el-row>
|
<editTemplate ref="editTemplateRef"></editTemplate>
|
</div>
|
</template>
|
|
<script setup lang="ts" name="personal">
|
import editTemplate from '/@/views/personal/component/editUserInfo.vue'
|
import { reactive, computed, onMounted, ref } from 'vue';
|
import { formatAxis } from '/@/utils/formatTime';
|
import { storeToRefs } from 'pinia';
|
import { useUserInfo } from '/@/stores/userInfo';
|
import { recommendList } from './mock';
|
import {getUserDetail2} from '/@/api/Patients'
|
import {editUserInfo} from '/@/api/login'
|
import { ElLoading } from 'element-plus';
|
const stores = useUserInfo();
|
const { userInfos } = storeToRefs(stores);
|
// 定义变量内容
|
const state = reactive<PersonalState>({
|
newsInfoList:[],
|
recommendList,
|
personalForm: {
|
id:0,
|
code:'',
|
name: '',
|
email: '',
|
phone: '',
|
sex: 0,
|
roles:[]
|
},
|
isShowDialog:false,
|
});
|
const editTemplateRef=ref()
|
|
// 当前时间提示语
|
const currentTime = computed(() => {
|
return formatAxis(new Date());
|
});
|
const updatePat=()=>{
|
const data={
|
id: state.personalForm.id,
|
code:state.personalForm.code,
|
userGender: state.personalForm.sex,
|
userName: state.personalForm.name,
|
userMobile: state.personalForm.phone,
|
userEmail:state.personalForm.email
|
}
|
console.log(data)
|
const loading = ElLoading.service({
|
lock: true,
|
text: 'Loading',
|
background: 'rgba(0, 0, 0, 0.7)',
|
})
|
editUserInfo(data).then(res=>{
|
console.log(res.data)
|
}).finally(()=>{
|
loading.close()
|
getDetail()
|
})
|
}
|
// 获取当前用户信息
|
const getDetail = () => {
|
getUserDetail2(`code=${userInfos.value.code}`).then((res) => {
|
state.personalForm.id=res.data.id
|
state.personalForm.code=res.data.code
|
state.personalForm.name = res.data.userName
|
state.personalForm.phone = res.data.userMobile
|
state.personalForm.email = res.data.userEmail
|
state.personalForm.sex = res.data.userGender
|
state.personalForm.roles=res.data.roles
|
|
console.log(state.personalForm,'0000000')
|
})
|
|
}
|
const updataPSWD=()=>{
|
editTemplateRef.value.openDialog(state.personalForm)
|
}
|
onMounted(()=>{
|
console.log(userInfos,'00000')
|
getDetail()
|
})
|
</script>
|
|
<style scoped lang="scss">
|
@import '../../theme/mixins/index.scss';
|
.personal {
|
.personal-user {
|
height: 130px;
|
display: flex;
|
align-items: center;
|
.personal-user-left {
|
width: 100px;
|
height: 130px;
|
border-radius: 3px;
|
:deep(.el-upload) {
|
height: 100%;
|
}
|
.personal-user-left-upload {
|
img {
|
width: 100%;
|
height: 100%;
|
border-radius: 3px;
|
}
|
&:hover {
|
img {
|
animation: logoAnimation 0.3s ease-in-out;
|
}
|
}
|
}
|
}
|
.personal-user-right {
|
flex: 1;
|
padding: 0 15px;
|
.personal-title {
|
font-size: 18px;
|
@include text-ellipsis(1);
|
}
|
.personal-item {
|
display: flex;
|
align-items: center;
|
font-size: 13px;
|
.personal-item-label {
|
color: var(--el-text-color-secondary);
|
@include text-ellipsis(1);
|
}
|
.personal-item-value {
|
@include text-ellipsis(1);
|
|
}
|
}
|
}
|
}
|
.personal-info {
|
.personal-info-more {
|
float: right;
|
color: var(--el-text-color-secondary);
|
font-size: 13px;
|
&:hover {
|
color: var(--el-color-primary);
|
cursor: pointer;
|
}
|
}
|
.personal-info-box {
|
height: 130px;
|
overflow: hidden;
|
.personal-info-ul {
|
list-style: none;
|
.personal-info-li {
|
font-size: 13px;
|
padding-bottom: 10px;
|
.personal-info-li-title {
|
display: inline-block;
|
@include text-ellipsis(1);
|
color: var(--el-text-color-secondary);
|
text-decoration: none;
|
}
|
& a:hover {
|
color: var(--el-color-primary);
|
cursor: pointer;
|
}
|
}
|
}
|
}
|
}
|
.personal-recommend-row {
|
.personal-recommend-col {
|
.personal-recommend {
|
position: relative;
|
height: 100px;
|
border-radius: 3px;
|
overflow: hidden;
|
cursor: pointer;
|
&:hover {
|
i {
|
right: 0px !important;
|
bottom: 0px !important;
|
transition: all ease 0.3s;
|
}
|
}
|
i {
|
position: absolute;
|
right: -10px;
|
bottom: -10px;
|
font-size: 70px;
|
transform: rotate(-30deg);
|
transition: all ease 0.3s;
|
}
|
.personal-recommend-auto {
|
padding: 15px;
|
position: absolute;
|
left: 0;
|
top: 5%;
|
color: var(--next-color-white);
|
.personal-recommend-msg {
|
font-size: 12px;
|
margin-top: 10px;
|
}
|
}
|
}
|
}
|
}
|
.personal-edit {
|
.personal-edit-title {
|
position: relative;
|
padding-left: 10px;
|
color: var(--el-text-color-regular);
|
&::after {
|
content: '';
|
width: 2px;
|
height: 10px;
|
position: absolute;
|
left: 0;
|
top: 50%;
|
transform: translateY(-50%);
|
background: var(--el-color-primary);
|
}
|
}
|
.personal-edit-safe-box {
|
border-bottom: 1px solid var(--el-border-color-light, #ebeef5);
|
padding: 15px 0;
|
.personal-edit-safe-item {
|
width: 100%;
|
display: flex;
|
align-items: center;
|
justify-content: space-between;
|
.personal-edit-safe-item-left {
|
flex: 1;
|
overflow: hidden;
|
.personal-edit-safe-item-left-label {
|
color: var(--el-text-color-regular);
|
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>
|