django-vue-admin/web/src/layout/header-aside/components/header-user/userinfo.vue

290 lines
9.5 KiB
Vue

<template>
<d2-container class="page">
<el-tabs v-model="activeName" @tab-click="handleClick">
<el-tab-pane label="用户设置" name="userInfo">
<el-row :gutter="20">
<el-col :span="10" :offset="6">
<el-form
ref="userInfoForm"
label-width="100px"
:model="userInfo"
required-asterisk
:rules="userInforules"
:label-position="position"
center
>
<el-form-item prop="avatar" label="头像">
<d2p-cropper-uploader :value="userInfo.avatar || '/image/avatar.png'" @input="handleAvatarSuccess"/>
</el-form-item>
<el-form-item prop="username" label="账号">
<el-input v-model="userInfo.username" disabled></el-input>
</el-form-item>
<el-form-item prop="name" required label="昵称">
<el-input v-model="userInfo.name" clearable></el-input>
</el-form-item>
<el-form-item label="电话号码" required prop="mobile">
<el-input v-model="userInfo.mobile" clearable disabled></el-input>
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="userInfo.email" clearable></el-input>
</el-form-item>
<el-form-item label="性別" prop="gender">
<el-radio-group v-model="userInfo.gender">
<el-radio :label="1">男</el-radio>
<el-radio :label="0">女</el-radio>
<el-radio :label="-1">未知</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="用户名" prop="dept">
<el-input :value="userInfo.username" clearable disabled></el-input>
</el-form-item>
<el-form-item label="所属部门" prop="dept">
<el-input :value="userInfo.dept_info && userInfo.dept_info.dept_name" clearable disabled></el-input>
</el-form-item>
<el-form-item label="当前角色" prop="role">
<el-select :value="userInfo.role" multiple placeholder="请选择" disabled size="mini" style="width: 100%;">
<el-option
v-for="item in userInfo.role_info"
:key="item.id"
:label="item.name"
:value="item.id">
</el-option>
</el-select>
</el-form-item>
<el-form-item>
<el-button @click="updateInfo" type="primary">
<i class="fa fa-check"></i>
更新
</el-button>
<el-button @click="resetForm('info')" type="info">
<i class="fa fa-reply-all"></i>
重置
</el-button>
</el-form-item>
</el-form>
</el-col>
</el-row>
</el-tab-pane>
<el-tab-pane label="密码设置" name="passwrod">
<el-row :gutter="20">
<el-col :span="10" :offset="6">
<el-form
ref="userPasswordForm"
:model="userPasswordInfo"
required-asterisk
label-width="100px"
:label-position="position"
:rules="passwordRules"
center
>
<el-form-item label="原密码" required prop="oldPassword">
<el-input
v-model="userPasswordInfo.oldPassword"
placeholder="请输入原始密码"
clearable
></el-input>
</el-form-item>
<el-form-item required prop="newPassword" label="新密码">
<el-input
type="password"
v-model="userPasswordInfo.newPassword"
placeholder="请输入新密码"
clearable
></el-input>
</el-form-item>
<el-form-item required prop="newPassword2" label="确认密码">
<el-input
type="password"
v-model="userPasswordInfo.newPassword2"
placeholder="请再次输入新密码"
clearable
></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="settingPassword">
<i class="fa fa-check"></i>提交
</el-button>
<el-button @click="resetForm('passwordForm')" type="info">
<i class="fa fa-reply-all"></i>
</el-button>
</el-form-item>
</el-form>
</el-col>
</el-row>
</el-tab-pane>
</el-tabs>
</d2-container>
</template>
<script>
import util from '@/libs/util.js'
import { request } from '@/api/service'
import { mapActions } from 'vuex'
export default {
name: 'userInfo',
data () {
var validatePass = (rule, value, callback) => {
const pwdRegex = new RegExp('(?=.*[0-9])(?=.*[a-zA-Z]).{8,30}')
if (value === '') {
callback(new Error('请输入密码'))
} else if (value === this.userPasswordInfo.oldPassword) {
callback(new Error('原密码与新密码一致'))
} else if (!pwdRegex.test(value)) {
callback(new Error('您的密码复杂度太低(密码中必须包含字母、数字)'))
} else {
if (this.userPasswordInfo.newPassword2 !== '') {
this.$refs.userPasswordForm.validateField('newPassword2')
}
callback()
}
}
var validatePass2 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入密码'))
} else if (value !== this.userPasswordInfo.newPassword) {
callback(new Error('两次输入密码不一致!'))
} else {
callback()
}
}
return {
position: 'left',
activeName: 'userInfo',
action: util.baseURL() + 'api/system/file/',
headers: {
Authorization: 'JWT ' + util.cookies.get('token')
},
fileList: [],
userInfo: {
name: '',
gender: '',
mobile: '',
avatar: '',
email: ''
},
userInforules: {
name: [{ required: true, message: '请输入昵称', trigger: 'blur' }],
mobile: [{ pattern: /^1[3-9]\d{9}$/, message: '请输入正确手机号' }]
},
userPasswordInfo: {
oldPassword: '',
newPassword: '',
newPassword2: ''
},
passwordRules: {
oldPassword: [
{
required: true,
message: '请输入原密码',
trigger: 'blur'
}
],
newPassword: [{ validator: validatePass, trigger: 'blur' }],
newPassword2: [{ validator: validatePass2, trigger: 'blur' }]
}
}
},
mounted () {
this.getCurrentUserInfo()
},
methods: {
...mapActions('d2admin/account', ['logout']),
/**
* 获取当前用户信息
*/
getCurrentUserInfo () {
const _self = this
return request({
url: '/api/system/user/user_info/',
method: 'get',
params: {}
}).then((res) => {
_self.userInfo = res.data
})
},
/**
* 更新用户信息
*/
updateInfo () {
const _self = this
_self.$refs.userInfoForm.validate((valid) => {
if (valid) {
const userInfo = _self.userInfo
delete userInfo.role
request({
url: '/api/system/user/update_user_info/',
method: 'put',
data: userInfo
}).then((res) => {
_self.$message.success('修改成功')
_self.getCurrentUserInfo()
})
} else {
// 校验失败
// 登录表单校验失败
this.$message.error('表单校验失败,请检查')
}
})
},
// 重置
resetForm (name) {
const _self = this
if (name === 'info') {
_self.getCurrentUserInfo()
} else {
_self.userPasswordForm = {}
}
},
// tab切换
handleClick (tab, event) {
const _self = this
if (tab.paneName === 'userInfo') {
_self.$refs.userPasswordForm.resetFields()
_self.getCurrentUserInfo()
} else {
_self.$refs.userInfoForm.resetFields()
}
},
/**
* 重新设置密码
*/
settingPassword () {
const _self = this
_self.$refs.userPasswordForm.validate((valid) => {
if (valid) {
const userId = util.cookies.get('uuid')
if (userId) {
const params = JSON.parse(JSON.stringify(_self.userPasswordInfo))
params.oldPassword = _self.$md5(params.oldPassword)
params.newPassword = _self.$md5(params.newPassword)
params.newPassword2 = _self.$md5(params.newPassword2)
request({
url: '/api/system/user/' + userId + '/change_password/',
method: 'put',
data: params
}).then((res) => {
_self.activeName = 'userInfo'
_self.$message.success('修改成功')
_self.logout({})
})
}
} else {
// 校验失败
// 登录表单校验失败
this.$message.error('表单校验失败,请检查')
}
})
},
/**
* 头像上传
* @param res
* @param file
*/
handleAvatarSuccess (res, file) {
this.userInfo.avatar = res
}
}
}
</script>