This commit is contained in:
H0nGzA1
2023-03-21 13:43:24 +08:00
parent ba9f209129
commit 256c6e4ab9

View File

@@ -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>