Merge branch 'main' of https://gitea.frp.extimaging.com/XCKJ/irc_web into main
continuous-integration/drone/push Build is passing Details

uat_us
caiyiling 2024-12-26 10:00:49 +08:00
commit 5dd1935997
31 changed files with 2067 additions and 594 deletions

View File

@ -5,3 +5,6 @@ npm install
# 启动服务 # 启动服务
npm run dev npm run dev
# v1.9.0修改
1. 角色修改全局userId实际意义修改为userRoleId用户角色id新增identityUserId新的用户id

View File

@ -30,7 +30,6 @@
</script> </script>
<% } else { %> <% } else { %>
<script> <script>
console.log(2)
window.zzSessionStorage = { window.zzSessionStorage = {
setItem: (item, value) => { setItem: (item, value) => {
return sessionStorage.setItem(item, value) return sessionStorage.setItem(item, value)

View File

@ -44,11 +44,19 @@ export function updateUser(param) {
data: param data: param
}) })
} }
export function updateUserBasicInfo(param) {
export function getUser(userId) {
return request({ return request({
url: `/user/getUser/${userId}`, url: `/user/updateUserBasicInfo`,
method: 'get' method: 'put',
data: param
})
}
export function getUser(params) {
return request({
url: `/user/getUser`,
method: 'get',
params
}) })
} }

View File

@ -3914,4 +3914,21 @@ export function getVisitClinicalDataName(data) {
method: 'post', method: 'post',
data data
}) })
}
// 修改外部人员权限配置
export function configTrialSPMInfo(data) {
return request({
url: `/TrialConfig/configTrialSPMInfo`,
method: 'post',
data
})
}
// 项目添加角色修改权限
export function updateTrialUserRole(data) {
return request({
url: `/TrialMaintenance/updateTrialUserRole`,
method: 'put',
data
})
} }

View File

@ -193,3 +193,19 @@ export function getPublicKey() {
method: 'get', method: 'get',
}) })
} }
// 登陆获取角色
export function getUserLoginRoleList(data) {
return request({
url: `/User/getUserLoginRoleList`,
method: 'post',
data,
})
}
// 登陆角色id获取token
export function loginSelectUserRole(params) {
return request({
url: `/User/loginSelectUserRole`,
method: 'get',
params,
})
}

View File

@ -0,0 +1,116 @@
<template>
<el-dialog
v-if="visible"
:visible.sync="visible"
v-dialogDrag
width="540px"
:close-on-click-modal="false"
:close-on-press-escape="false"
append-to-body
:title="$t('toggleRole:tip:title')"
center
top="30vh"
:show-close="false"
:before-close="cancel"
>
<template v-if="hasRole">
<el-radio-group v-model="form.userRoleId" class="roles">
<el-radio
v-for="item in roles"
:key="item.Id"
:label="item.Id"
:disabled="item.isUserRoleDisabled"
style="margin-bottom: 10px"
>
{{ item.UserTypeShortName }}
</el-radio>
</el-radio-group>
</template>
<div v-else style="text-align: center">
{{ $t('toggleRole:tip:noRole') }}
</div>
<div slot="footer">
<!-- 取消 -->
<el-button size="small" @click="cancel()">
{{ $t('common:button:cancel') }}
</el-button>
<!-- 保存 -->
<el-button
type="primary"
size="small"
@click="save"
:loading="loading"
v-if="hasRole"
>
{{ $t('common:button:confirm') }}
</el-button>
</div>
</el-dialog>
</template>
<script>
export default {
name: 'toggleRole',
props: {
visible: {
type: Boolean,
default: false,
},
loading: {
type: Boolean,
default: false,
},
},
data() {
return {
form: {
userRoleId: null,
},
}
},
created() {
this.form.userRoleId = zzSessionStorage.getItem('userId')
},
computed: {
roles() {
return this.$store.state.user.roles
},
hasRole() {
return this.roles && this.roles.length > 0
},
},
methods: {
cancel() {
this.$emit('update:visible', false)
this.$emit('cancel')
},
async save() {
try {
if (!this.form.userRoleId)
return this.$message.warning(this.$t('toggleRole:ruleMessage:select'))
this.$emit('save', this.form.userRoleId)
} catch (err) {
console.log(err)
}
},
},
}
</script>
<style lang="scss" scoped>
.roles {
width: 100%;
display: flex;
align-content: center;
justify-content: center;
flex-wrap: wrap;
}
/deep/ .el-radio__original {
display: none !important; /* 隐藏原生 radio 输入,但仍然允许交互 */
}
/deep/.el-radio:focus:not(.is-focus):not(:active):not(.is-disabled)
.el-radio__inner {
box-shadow: none !important;
}
</style>

View File

@ -1,6 +1,5 @@
import { SubjectCheckConfig } from './module/Subject' import { SubjectCheckConfig } from './module/Subject'
console.log(SubjectCheckConfig.moduleType)
export const checkConfig = { export const checkConfig = {
ModuleType: { ModuleType: {
...SubjectCheckConfig.ModuleType ...SubjectCheckConfig.ModuleType

View File

@ -69,7 +69,7 @@ export default {
...mapGetters(['sidebar', 'name', 'device']) ...mapGetters(['sidebar', 'name', 'device'])
}, },
created() { created() {
this.isReviewer = JSON.parse(zzSessionStorage.getItem('IsReviewer')) // this.isReviewer = JSON.parse(zzSessionStorage.getItem('IsReviewer'))
}, },
methods: { methods: {
...mapMutations({ setLanguage: 'lang/setLanguage' }), ...mapMutations({ setLanguage: 'lang/setLanguage' }),

View File

@ -78,6 +78,7 @@ router.beforeEach(async (to, from, next) => {
try { try {
// 获取用户信息 // 获取用户信息
await store.dispatch('user/getInfo') await store.dispatch('user/getInfo')
await store.dispatch('user/getUserInfo')
const accessRoutes = await store.dispatch('permission/generateRoutes') const accessRoutes = await store.dispatch('permission/generateRoutes')
router.addRoutes(accessRoutes) router.addRoutes(accessRoutes)
next({ ...to, replace: true }) next({ ...to, replace: true })

View File

@ -7,6 +7,7 @@ const getters = {
tree: state => state.user.tree, tree: state => state.user.tree,
userName: state => state.user.userName, userName: state => state.user.userName,
userId: state => state.user.userId, userId: state => state.user.userId,
identityUserId: state => state.user.identityUserId,
routes: state => state.permission.routes, routes: state => state.permission.routes,
asyncRoutes: state => state.permission.addRoutes, asyncRoutes: state => state.permission.addRoutes,
visitedViews: state => state.tagsView.visitedViews, visitedViews: state => state.tagsView.visitedViews,

View File

@ -1,5 +1,6 @@
import { getToken, setToken, removeToken, setName, removeName } from '@/utils/auth' import { getToken, setToken, removeToken, setName, removeName } from '@/utils/auth'
import { login, loginOut, getUserMenuTree, getUserPermissions } from '@/api/user' import { login, loginOut, getUserMenuTree, getUserPermissions, getUserLoginRoleList, loginSelectUserRole } from '@/api/user'
import { getUser } from '@/api/admin'
import { resetRouter } from '@/router' import { resetRouter } from '@/router'
import md5 from 'js-md5' import md5 from 'js-md5'
@ -9,6 +10,7 @@ const getDefaultState = () => {
name: '', name: '',
userName: '', userName: '',
userId: '', userId: '',
identityUserId: '',
avatar: '', avatar: '',
permissions: [], permissions: [],
tree: [], tree: [],
@ -16,13 +18,17 @@ const getDefaultState = () => {
TotalNeedSignSystemDocCount: eval(process.env.VUE_APP_WORD_FOR_PERMISSION) ? null : 0, TotalNeedSignSystemDocCount: eval(process.env.VUE_APP_WORD_FOR_PERMISSION) ? null : 0,
TotalNeedSignTrialDocCount: eval(process.env.VUE_APP_WORD_FOR_PERMISSION) ? null : 0, TotalNeedSignTrialDocCount: eval(process.env.VUE_APP_WORD_FOR_PERMISSION) ? null : 0,
TrialStatusStr: null, TrialStatusStr: null,
isTestUser: false isTestUser: false,
roles: []
} }
} }
const state = getDefaultState() const state = getDefaultState()
const mutations = { const mutations = {
SET_ROLES: (state, roles) => {
state.roles = roles
},
RESET_STATE: (state) => { RESET_STATE: (state) => {
Object.assign(state, getDefaultState()) Object.assign(state, getDefaultState())
}, },
@ -49,6 +55,9 @@ const mutations = {
SET_USERID: (state, id) => { SET_USERID: (state, id) => {
state.userId = id state.userId = id
}, },
SET_IDENTITYUSERID: (state, id) => {
state.identityUserId = id
},
SET_ISTESTUSER: (state, isTestUser) => { SET_ISTESTUSER: (state, isTestUser) => {
state.isTestUser = eval(isTestUser) state.isTestUser = eval(isTestUser)
}, },
@ -78,6 +87,9 @@ const mutations = {
} }
const actions = { const actions = {
setRoles({ commit }, roles) {
commit('SET_ROLES', roles)
},
changeUserName({ commit }, userName) { changeUserName({ commit }, userName) {
commit('SET_USERNAME', userName) commit('SET_USERNAME', userName)
}, },
@ -91,7 +103,7 @@ const actions = {
if (UserId) { if (UserId) {
data.UserId = UserId; data.UserId = UserId;
} }
login(data).then(async response => { getUserLoginRoleList(data).then(async response => {
if (response.IsSuccess) { if (response.IsSuccess) {
zzSessionStorage.removeItem('lastWorkbench') zzSessionStorage.removeItem('lastWorkbench')
zzSessionStorage.setItem('my_username', username.trim()) zzSessionStorage.setItem('my_username', username.trim())
@ -99,6 +111,7 @@ const actions = {
zzSessionStorage.setItem('my_EMail', response.Result.BasicInfo.EMail) zzSessionStorage.setItem('my_EMail', response.Result.BasicInfo.EMail)
localStorage.setItem('CompanyInfo', JSON.stringify(response.Result.CompanyInfo)) localStorage.setItem('CompanyInfo', JSON.stringify(response.Result.CompanyInfo))
const data = response.Result const data = response.Result
commit('SET_ROLES', data.BasicInfo.AccountList)
if (data.BasicInfo.IsFirstAdd || data.BasicInfo.LoginState === 1) { if (data.BasicInfo.IsFirstAdd || data.BasicInfo.LoginState === 1) {
try { try {
zzSessionStorage.setItem('userId', data.BasicInfo.Id) zzSessionStorage.setItem('userId', data.BasicInfo.Id)
@ -114,25 +127,25 @@ const actions = {
zzSessionStorage.setItem('IsReviewer', data.BasicInfo.IsReviewer) zzSessionStorage.setItem('IsReviewer', data.BasicInfo.IsReviewer)
zzSessionStorage.setItem('userName', data.BasicInfo.UserName) zzSessionStorage.setItem('userName', data.BasicInfo.UserName)
commit('SET_TOKEN', data.JWTStr) commit('SET_TOKEN', data.JWTStr)
commit('SET_NAME', data.BasicInfo.RealName) // commit('SET_NAME', data.BasicInfo.UserName)
zzSessionStorage.setItem('realName', data.BasicInfo.RealName)
zzSessionStorage.setItem('isTestUser', data.BasicInfo.IsTestUser) zzSessionStorage.setItem('isTestUser', data.BasicInfo.IsTestUser)
commit('SET_ISTESTUSER', data.BasicInfo.IsTestUser) commit('SET_ISTESTUSER', data.BasicInfo.IsTestUser)
commit('SET_USERNAME', data.BasicInfo.UserName) commit('SET_USERNAME', data.BasicInfo.UserName)
commit('SET_USERID', data.BasicInfo.Id) commit('SET_USERID', data.BasicInfo.IdentityUserId)
setToken(data.JWTStr) setToken(data.JWTStr)
setName(data.BasicInfo.RealName) // setName(data.BasicInfo.RealName)
const userString = decodeURIComponent(escape(window.atob(data.JWTStr.split('.')[1].replace(/-/g, '+').replace(/_/g, '/')))) const userString = decodeURIComponent(escape(window.atob(data.JWTStr.split('.')[1].replace(/-/g, '+').replace(/_/g, '/'))))
const user = JSON.parse(userString) const user = JSON.parse(userString)
zzSessionStorage.setItem('userTypeShortName', user.userTypeShortName) // zzSessionStorage.setItem('userId', user.identityUserId)
zzSessionStorage.setItem('userId', user.id) commit('SET_IDENTITYUSERID', user.identityUserId)
zzSessionStorage.setItem('identityUserId', user.identityUserId)
zzSessionStorage.setItem('userTypeEnumInt', user.userTypeEnumInt) zzSessionStorage.setItem('userTypeEnumInt', user.userTypeEnumInt)
var permissions = await getUserPermissions() // var permissions = await getUserPermissions()
var menuTree = await getUserMenuTree() // var menuTree = await getUserMenuTree()
commit('SET_TREE', menuTree.Result) // commit('SET_TREE', menuTree.Result)
commit('SET_PERMISSIONS', permissions.Result) // commit('SET_PERMISSIONS', permissions.Result)
zzSessionStorage.setItem('newTree', JSON.stringify(menuTree.Result)) // zzSessionStorage.setItem('newTree', JSON.stringify(menuTree.Result))
zzSessionStorage.setItem('permissions', JSON.stringify(permissions.Result)) // zzSessionStorage.setItem('permissions', JSON.stringify(permissions.Result))
} catch (e) { } catch (e) {
console.log(e) console.log(e)
} }
@ -146,6 +159,44 @@ const actions = {
}) })
}) })
}, },
loginByRole({ commit }, userInfo) {
const { userRoleId } = userInfo
let params = {
userRoleId
}
return new Promise((resolve, reject) => {
loginSelectUserRole(params).then(async response => {
if (response.IsSuccess) {
const data = response.Result
try {
commit('SET_TOKEN', data)
setToken(data)
const userString = decodeURIComponent(escape(window.atob(data.split('.')[1].replace(/-/g, '+').replace(/_/g, '/'))))
const user = JSON.parse(userString)
zzSessionStorage.setItem('userTypeShortName', user.userTypeShortName)
commit('SET_NAME', user.fullName)
setName(user.fullName)
var permissions = await getUserPermissions()
var menuTree = await getUserMenuTree()
commit('SET_TREE', menuTree.Result)
commit('SET_PERMISSIONS', permissions.Result)
zzSessionStorage.setItem('newTree', JSON.stringify(menuTree.Result))
zzSessionStorage.setItem('permissions', JSON.stringify(permissions.Result))
} catch (e) {
console.log(e)
}
resolve(response.Result)
} else {
reject(response.ErrorMessage)
}
}).catch(() => {
reject()
})
})
},
setTree({ commit }, tree) { setTree({ commit }, tree) {
commit('SET_TREE', tree) commit('SET_TREE', tree)
}, },
@ -170,21 +221,34 @@ const actions = {
commit('SET_PERMISSIONS', JSON.parse(zzSessionStorage.getItem('permissions'))) commit('SET_PERMISSIONS', JSON.parse(zzSessionStorage.getItem('permissions')))
commit('SET_ISTESTUSER', zzSessionStorage.getItem('isTestUser')) commit('SET_ISTESTUSER', zzSessionStorage.getItem('isTestUser'))
const user = JSON.parse(userString) const user = JSON.parse(userString)
commit('SET_NAME', zzSessionStorage.getItem('realName')) commit('SET_NAME', zzSessionStorage.getItem('Name'))
commit('SET_USERID', user.id) commit('SET_IDENTITYUSERID', user.identityUserId)
commit('SET_USERID', user.userRoleId)
commit('SET_USERNAME', zzSessionStorage.getItem('userName')) commit('SET_USERNAME', zzSessionStorage.getItem('userName'))
commit('SET_NEED_SIGN_SYSTEM_DOC_COUNT', parseInt(zzSessionStorage.getItem('TotalNeedSignSystemDocCount'))) commit('SET_NEED_SIGN_SYSTEM_DOC_COUNT', parseInt(zzSessionStorage.getItem('TotalNeedSignSystemDocCount')))
commit('SET_NEED_SIGN_TRIALS_DOC_COUNT', parseInt(zzSessionStorage.getItem('TotalNeedSignTrialDocCount'))) commit('SET_NEED_SIGN_TRIALS_DOC_COUNT', parseInt(zzSessionStorage.getItem('TotalNeedSignTrialDocCount')))
console.log(zzSessionStorage.getItem('TotalNeedSignSystemDocCount')) // console.log(zzSessionStorage.getItem('TotalNeedSignSystemDocCount'))
console.log(zzSessionStorage.getItem('TotalNeedSignTrialDocCount')) // console.log(zzSessionStorage.getItem('TotalNeedSignTrialDocCount'))
zzSessionStorage.setItem('userName', user.name) zzSessionStorage.setItem('userName', user.name)
zzSessionStorage.setItem('userId', user.id) zzSessionStorage.setItem('userId', user.userRoleId)
zzSessionStorage.setItem('identityUserId', user.identityUserId)
zzSessionStorage.setItem('userTypeShortName', user.userTypeShortName) zzSessionStorage.setItem('userTypeShortName', user.userTypeShortName)
zzSessionStorage.setItem('userTypeEnumInt', user.userTypeEnumInt) zzSessionStorage.setItem('userTypeEnumInt', user.userTypeEnumInt)
return user return user
}, },
updateInfo({ commit, state }) { updateInfo({ commit, state }) {
commit('SET_NAME', zzSessionStorage.getItem('realName')) commit('SET_NAME', zzSessionStorage.getItem('Name'))
},
// 获取用户信息
getUserInfo({ commit, state }) {
return new Promise((resolve, reject) => {
getUser().then(res => {
commit('SET_ROLES', res.Result.AccountList)
resolve(res.Result)
}).catch(err => {
reject(err)
})
})
}, },
// user logout // user logout
async logout({ commit, state }) { async logout({ commit, state }) {

View File

@ -5,7 +5,7 @@
:model="user" :model="user"
:rules="userFormRules" :rules="userFormRules"
label-width="150px" label-width="150px"
style="width:800px;" style="width: 800px"
> >
<el-card class="Basic" shadow="never" size="small"> <el-card class="Basic" shadow="never" size="small">
<div slot="header" class="clearfix"> <div slot="header" class="clearfix">
@ -25,7 +25,7 @@
<el-form-item label="Given Name: " prop="FirstName"> <el-form-item label="Given Name: " prop="FirstName">
<el-input v-model="user.FirstName" /> <el-input v-model="user.FirstName" />
</el-form-item> </el-form-item>
<el-form-item label="Gender: " prop="Sex" style="margin-right:40px;"> <el-form-item label="Gender: " prop="Sex" style="margin-right: 40px">
<el-radio-group v-model="user.Sex"> <el-radio-group v-model="user.Sex">
<el-radio :label="1">Male</el-radio> <el-radio :label="1">Male</el-radio>
<el-radio :label="0">Female</el-radio> <el-radio :label="0">Female</el-radio>
@ -37,13 +37,24 @@
<el-form-item label="Phone: " prop="Phone"> <el-form-item label="Phone: " prop="Phone">
<el-input v-model="user.Phone" /> <el-input v-model="user.Phone" />
</el-form-item> </el-form-item>
<el-form-item v-if="type==1" label="Disable:"> <el-form-item v-if="type == 1" label="Disable:">
<el-switch v-model="user.Status" :active-value="0" :inactive-value="1" /> <el-switch
v-model="user.Status"
:active-value="0"
:inactive-value="1"
/>
</el-form-item> </el-form-item>
<el-form-item label="User Type: " prop="UserTypeId"> <el-form-item label="User Type: " prop="UserTypeId">
<el-select ref="userType" v-model="user.UserTypeId" size="small" placeholder="Please select" style="width:100%;" :disabled="user.CanEditUserType === false"> <el-select
ref="userType"
v-model="user.UserTypeId"
size="small"
placeholder="Please select"
style="width: 100%"
:disabled="user.CanEditUserType === false"
>
<el-option <el-option
v-for="(userType,key) of userTypeOptions" v-for="(userType, key) of userTypeOptions"
:key="key" :key="key"
:label="userType.UserType" :label="userType.UserType"
:value="userType.Id" :value="userType.Id"
@ -52,17 +63,28 @@
</el-form-item> </el-form-item>
</el-card> </el-card>
<el-card class="Affiliation" shadow="never" style="margin-top:10px;" size="small"> <el-card
class="Affiliation"
shadow="never"
style="margin-top: 10px"
size="small"
>
<div slot="header" class="clearfix"> <div slot="header" class="clearfix">
<span>Affiliation</span> <span>Affiliation</span>
</div> </div>
<el-form-item prop="IsZhiZhun"> <el-form-item prop="IsZhiZhun">
<el-radio-group v-model="user.IsZhiZhun" @change="OrgnizationTypeChanged"> <el-radio-group
v-model="user.IsZhiZhun"
@change="OrgnizationTypeChanged"
>
<el-radio :label="true">Internal</el-radio> <el-radio :label="true">Internal</el-radio>
<el-radio :label="false">External</el-radio> <el-radio :label="false">External</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item v-show="user.IsZhiZhun === false" label="Organization Name: "> <el-form-item
v-show="user.IsZhiZhun === false"
label="Organization Name: "
>
<el-input v-model="user.OrganizationName" /> <el-input v-model="user.OrganizationName" />
</el-form-item> </el-form-item>
@ -78,19 +100,24 @@
type="primary" type="primary"
size="small" size="small"
:disabled="isDisabled" :disabled="isDisabled"
style="margin:10px 15px" style="margin: 10px 15px"
@click="handleSave" @click="handleSave"
>Save</el-button> >Save</el-button
>
</el-form-item> </el-form-item>
</el-form> </el-form>
</template> </template>
<script> <script>
import { getUser, addUser, updateUser, getUserTypeListByUserType } from '@/api/admin.js' import {
getUser,
addUser,
updateUser,
getUserTypeListByUserType,
} from '@/api/admin.js'
export default { export default {
name: 'UserInfo', name: 'UserInfo',
props: { props: {
userId: { type: String, default: '' } userId: { type: String, default: '' },
}, },
data() { data() {
return { return {
@ -105,60 +132,69 @@ export default {
IsZhiZhun: '', IsZhiZhun: '',
OrganizationName: '', OrganizationName: '',
DepartmentName: '', DepartmentName: '',
PositionName: '' PositionName: '',
}, },
userFormRules: { userFormRules: {
UserName: [ UserName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
], ],
UserTypeId: [ UserTypeId: [
{ required: true, message: 'Please Select', trigger: ['blur', 'change'] } {
required: true,
message: 'Please Select',
trigger: ['blur', 'change'],
},
], ],
IsZhiZhun: [ IsZhiZhun: [
{ required: true, message: 'Please Select', trigger: ['blur', 'change'] } {
required: true,
message: 'Please Select',
trigger: ['blur', 'change'],
},
], ],
OrganizationName: [ OrganizationName: [
{ required: true, message: 'Please specify', trigger: 'blur' } { required: true, message: 'Please specify', trigger: 'blur' },
], ],
LastName: [ LastName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
], ],
FirstName: [ FirstName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
], ],
Phone: [ Phone: [
{ max: 20, min: 7, message: 'The length is 7 to 20', trigger: ['blur'] } {
max: 20,
min: 7,
message: 'The length is 7 to 20',
trigger: ['blur'],
},
], ],
EMail: [ EMail: [
{ {
required: true, required: true,
message: 'Please input the email address', message: 'Please input the email address',
trigger: 'blur' trigger: 'blur',
}, },
{ {
type: 'email', type: 'email',
message: 'Please input the correct email address', message: 'Please input the correct email address',
trigger: ['blur'] trigger: ['blur'],
}, },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
],
Sex: [
{ required: true, message: 'Please specify', trigger: 'blur' }
], ],
Sex: [{ required: true, message: 'Please specify', trigger: 'blur' }],
Status: [ Status: [
{ required: true, message: 'Please specify', trigger: 'blur' } { required: true, message: 'Please specify', trigger: 'blur' },
], ],
DepartmentName: [ DepartmentName: [{ max: 50, message: 'The maximum length is 50' }],
{ max: 50, message: 'The maximum length is 50' }], PositionName: [{ max: 50, message: 'The maximum length is 50' }],
PositionName: [{ max: 50, message: 'The maximum length is 50' }
]
}, },
userTypeOptions: [], userTypeOptions: [],
isDisabled: false, isDisabled: false,
type: 0 // 10 type: 0, // 10
} }
}, },
created() { created() {
@ -172,46 +208,58 @@ export default {
}, },
methods: { methods: {
handleSave() { handleSave() {
this.$refs.userForm.validate(valid => { this.$refs.userForm.validate((valid) => {
if (valid) { if (valid) {
this.isDisabled = true this.isDisabled = true
const selectedUserType = this.userTypeOptions.filter(item => item.Id === this.user.UserTypeId) const selectedUserType = this.userTypeOptions.filter(
(item) => item.Id === this.user.UserTypeId
)
if (selectedUserType.length > 0) { if (selectedUserType.length > 0) {
this.user.UserTypeEnum = selectedUserType[0].UserTypeEnum this.user.UserTypeEnum = selectedUserType[0].UserTypeEnum
} }
if (this.user.Id) { if (this.user.Id) {
updateUser(this.user).then(res => { updateUser(this.user)
this.isDisabled = false .then((res) => {
this.$message.success('Updated successfully') this.isDisabled = false
}).catch(() => { this.isDisabled = false }) this.$message.success('Updated successfully')
})
.catch(() => {
this.isDisabled = false
})
} else { } else {
addUser(this.user).then(res => { addUser(this.user)
this.isDisabled = false .then((res) => {
this.user.Id = res.Result.Id this.isDisabled = false
this.user.UserCode = res.Result.UserCode this.user.Id = res.Result.Id
this.$emit('getUserId', res.Result.Id) this.user.UserCode = res.Result.UserCode
this.$message.success('Added successfully') this.$emit('getUserId', res.Result.Id)
this.$router.push({ path: '/system/user/list' }) this.$message.success('Added successfully')
}).catch(() => { this.isDisabled = false }) this.$router.push({ path: '/system/user/list' })
})
.catch(() => {
this.isDisabled = false
})
} }
} }
}) })
}, },
getUserTypeList() { getUserTypeList() {
getUserTypeListByUserType(0).then(res => { getUserTypeListByUserType(0).then((res) => {
if (res.IsSuccess) { if (res.IsSuccess) {
this.userTypeOptions = res.Result this.userTypeOptions = res.Result
} }
}) })
}, },
getUserInfo() { getUserInfo() {
getUser(this.userId).then(res => { getUser({
IdentityUserId: this.userId,
}).then((res) => {
this.user = res.Result this.user = res.Result
}) })
}, },
OrgnizationTypeChanged(val) { OrgnizationTypeChanged(val) {
this.user.OrganizationName = '' this.user.OrganizationName = ''
} },
} },
} }
</script> </script>

View File

@ -95,7 +95,6 @@ export default {
: 'zh' : 'zh'
/* eslint-disable */ /* eslint-disable */
var reg1 = /^[a-zA-Z0-9_]{4,16}$/ //8 var reg1 = /^[a-zA-Z0-9_]{4,16}$/ //8
console.log(!reg1.test(value))
if (!reg1.test(value)) { if (!reg1.test(value)) {
callback( callback(
lang === 'zh' lang === 'zh'

View File

@ -76,7 +76,8 @@
> >
<!-- 用户名 --> <!-- 用户名 -->
<el-form-item :label="$t('passwordReset:form:userName')" prop="UserId"> <el-form-item :label="$t('passwordReset:form:userName')" prop="UserId">
<el-select <el-input v-model="form.UserName" disabled />
<!-- <el-select
v-model="form.UserId" v-model="form.UserId"
clearable clearable
filterable filterable
@ -94,15 +95,15 @@
item.UserType item.UserType
}}</span> }}</span>
</el-option> </el-option>
</el-select> </el-select> -->
</el-form-item> </el-form-item>
<!-- 用户类型 --> <!-- 用户类型 -->
<el-form-item <!-- <el-form-item
v-if="form.UserId" v-if="form.UserId"
:label="$t('passwordReset:form:userType')" :label="$t('passwordReset:form:userType')"
> >
<el-input v-model="form.UserType" disabled /> <el-input v-model="form.UserType" disabled />
</el-form-item> </el-form-item> -->
<!-- 新密码 --> <!-- 新密码 -->
<el-form-item <el-form-item
class="my_new_pwd" class="my_new_pwd"
@ -338,11 +339,13 @@ export default {
) )
.then((res) => { .then((res) => {
this.formLoading = false this.formLoading = false
this.users = res.Result this.form.UserId = res.Result.Id
if (this.users.length === 1) { this.form.UserName = res.Result.UserName
this.form.UserId = this.users[0].UserId // this.users = res.Result
this.form.UserType = this.users[0].UserType // if (this.users.length === 1) {
} // this.form.UserId = this.users[0].UserId
// this.form.UserType = this.users[0].UserType
// }
// //
this.$message.success( this.$message.success(
this.$t('passwordReset:message:verifiedSuccessfully') this.$t('passwordReset:message:verifiedSuccessfully')

View File

@ -83,7 +83,7 @@
<svg-icon icon-class="password" /> <svg-icon icon-class="password" />
</span> </span>
<!-- password --> <!-- password -->
<!-- <el-input <el-input
:key="passwordType" :key="passwordType"
ref="password" ref="password"
v-model="loginForm.password" v-model="loginForm.password"
@ -100,8 +100,8 @@
<svg-icon <svg-icon
:icon-class="passwordType === 'password' ? 'eye' : 'eye-open'" :icon-class="passwordType === 'password' ? 'eye' : 'eye-open'"
/> />
</span> --> </span>
<el-input <!-- <el-input
:key="passwordType" :key="passwordType"
ref="password" ref="password"
v-model="pwdCover" v-model="pwdCover"
@ -115,7 +115,7 @@
/> />
<span class="show-pwd" @click="hidePassword"> <span class="show-pwd" @click="hidePassword">
<svg-icon :icon-class="!isShowPassword ? 'eye' : 'eye-open'" /> <svg-icon :icon-class="!isShowPassword ? 'eye' : 'eye-open'" />
</span> </span> -->
</el-form-item> </el-form-item>
<!-- Login --> <!-- Login -->
<el-button <el-button
@ -243,6 +243,13 @@
</div> </div>
</el-dialog> </el-dialog>
<browserTip ref="browserTip" /> <browserTip ref="browserTip" />
<toggleRole
v-if="toggleRoleVisible"
:visible.sync="toggleRoleVisible"
:loading="toggleRoleLoading"
@save="loginByRole"
@cancel="cancel"
/>
</div> </div>
</template> </template>
@ -253,9 +260,10 @@ import TopLang from './topLang'
import Vcode from 'vue-puzzle-vcode' import Vcode from 'vue-puzzle-vcode'
import browserTip from '@/views/dictionary/template/browser/tip.vue' import browserTip from '@/views/dictionary/template/browser/tip.vue'
import Img1 from '@/assets/pic-2.png' import Img1 from '@/assets/pic-2.png'
import toggleRole from '@/components/toggleRole'
export default { export default {
name: 'Login', name: 'Login',
components: { TopLang, Vcode, browserTip }, components: { TopLang, Vcode, browserTip, toggleRole },
data() { data() {
return { return {
NODE_ENV: process.env.NODE_ENV, // process.env.NODE_ENV NODE_ENV: process.env.NODE_ENV, // process.env.NODE_ENV
@ -298,6 +306,8 @@ export default {
isShow: false, isShow: false,
showCode: false, showCode: false,
Img1, Img1,
toggleRoleVisible: false,
toggleRoleLoading: false,
} }
}, },
computed: { computed: {
@ -318,6 +328,7 @@ export default {
}, },
}, },
mounted() { mounted() {
zzSessionStorage.clear()
this.loginType = this.$route.query.loginType this.loginType = this.$route.query.loginType
this.location = this.$route.query.location this.location = this.$route.query.location
zzSessionStorage.setItem('loginType', this.loginType) zzSessionStorage.setItem('loginType', this.loginType)
@ -416,37 +427,79 @@ export default {
// this.$alert(this.$t('login:message:login4'), this.$t('common:title:warning')) // this.$alert(this.$t('login:message:login4'), this.$t('common:title:warning'))
this.$message.warning(this.$t('login:message:login4')) this.$message.warning(this.$t('login:message:login4'))
} }
this.$store.dispatch('permission/generateRoutes').then((res) => { if (
this.loading = false Array.isArray(this.$store.state.user.roles) &&
if (res && res.length > 0) { this.$store.state.user.roles.length === 1
this.$store.dispatch('global/getNoticeList') ) {
this.$router.addRoutes(res) this.loginByRole(this.$store.state.user.roles[0].Id)
if (this.loginType === 'DevOps') { return
this.$router.replace({ path: res[0].path }) }
return return (this.toggleRoleVisible = true)
}
if (this.hasPermi(['role:radmin'])) {
this.$router.replace({ path: res[0].path })
return
}
if (
this.hasPermi(['role:air', 'role:rpm', 'role:rcrc', 'role:rir'])
) {
this.$router.replace({ path: '/trials/trials-list' })
} else {
this.$router.replace({ path: '/trials' })
}
} else {
//
this.$message.warning(this.$t('login:message:login2'))
}
})
}) })
.catch(() => { .catch(() => {
this.showCode = true this.showCode = true
this.loading = false this.loading = false
}) })
}, },
loginByRole(userRoleId) {
this.toggleRoleLoading = true
this.$store
.dispatch('user/loginByRole', { userRoleId })
.then((res) => {
this.toggleRoleLoading = false
if (res) {
this.$store
.dispatch('permission/generateRoutes')
.then((res) => {
this.loading = false
if (res && res.length > 0) {
this.$store.dispatch('global/getNoticeList')
this.$router.addRoutes(res)
if (this.loginType === 'DevOps') {
this.$router.replace({ path: res[0].path })
return
}
if (this.hasPermi(['role:radmin'])) {
this.$router.replace({ path: res[0].path })
return
}
if (
this.hasPermi([
'role:air',
'role:rpm',
'role:rcrc',
'role:rir',
])
) {
this.$router.replace({ path: '/trials/trials-list' })
} else {
this.$router.replace({ path: '/trials' })
}
} else {
this.toggleRoleLoading = false
//
this.$message.warning(this.$t('login:message:login2'))
}
})
.catch((err) => {
this.toggleRoleLoading = false
})
} else {
this.toggleRoleLoading = false
}
})
.catch(() => {
this.showCode = true
this.loading = false
this.toggleRoleLoading = false
})
},
cancel() {
this.showCode = true
this.loading = false
this.toggleRoleLoading = false
// this.toggleRoleVisible = false
},
onSuccess() { onSuccess() {
this.isShow = false this.isShow = false
this.loginIn() this.loginIn()

View File

@ -5,24 +5,38 @@
:model="user" :model="user"
:rules="userFormRules" :rules="userFormRules"
label-width="150px" label-width="150px"
style="width:800px;" style="width: 800px"
> >
<el-card class="Basic" shadow="never" size="small"> <el-card class="Basic" shadow="never" size="small">
<div slot="header" class="clearfix"> <div slot="header" class="clearfix">
<span>{{ $t('system:userlist:title:Information') }}</span> <span>{{ $t('system:userlist:title:Information') }}</span>
</div> </div>
<el-form-item v-if="user.UserCode" :label="$t('system:userlist:table:S/N')" prop="UserCode"> <el-form-item
v-if="user.UserCode"
:label="$t('system:userlist:table:S/N')"
prop="UserCode"
>
<el-input v-model="user.UserCode" disabled /> <el-input v-model="user.UserCode" disabled />
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:UserName')" class="my_new_pwd" prop="UserName"> <el-form-item
:label="$t('system:userlist:table:UserName')"
class="my_new_pwd"
prop="UserName"
>
<el-input v-model="user.UserName" /> <el-input v-model="user.UserName" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:LastName')" prop="LastName"> <el-form-item
:label="$t('system:userlist:table:LastName')"
prop="LastName"
>
<el-input v-model="user.LastName" /> <el-input v-model="user.LastName" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:FirstName')" prop="FirstName"> <el-form-item
:label="$t('system:userlist:table:FirstName')"
prop="FirstName"
>
<el-input v-model="user.FirstName" /> <el-input v-model="user.FirstName" />
</el-form-item> </el-form-item>
<!-- <el-form-item :label="$t('system:userlist:table:Gender')" prop="Sex" style="margin-right:40px;"> <!-- <el-form-item :label="$t('system:userlist:table:Gender')" prop="Sex" style="margin-right:40px;">
@ -37,44 +51,101 @@
<el-form-item :label="$t('system:userlist:table:Phone')" prop="Phone"> <el-form-item :label="$t('system:userlist:table:Phone')" prop="Phone">
<el-input v-model="user.Phone" /> <el-input v-model="user.Phone" />
</el-form-item> </el-form-item>
<el-form-item v-if="type==1" :label="$t('system:userlist:table:Disable')"> <el-form-item
<el-switch v-model="user.Status" :active-value="1" :inactive-value="0" /> v-if="type == 1"
:label="$t('system:userlist:table:Disable')"
>
<el-switch
v-model="user.Status"
:active-value="1"
:inactive-value="0"
/>
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:IsTestUser')"> <el-form-item :label="$t('system:userlist:table:IsTestUser')">
<el-radio-group v-model="user.IsTestUser"> <el-radio-group v-model="user.IsTestUser">
<el-radio v-for="item of $d.YesOrNo" :label="item.value">{{ item.label }}</el-radio> <el-radio
v-for="item of $d.YesOrNo"
:key="item.id"
:label="item.value"
>{{ item.label }}</el-radio
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:UserType')" prop="UserTypeId"> <el-form-item
<el-select ref="userType" v-model="user.UserTypeId" size="small" placeholder="Please select" style="width:100%;" :disabled="user.CanEditUserType === false"> :label="$t('system:userlist:table:UserType')"
<el-option prop="UserTypeId"
v-for="(userType,key) of userTypeOptions" >
v-if="userType.UserTypeEnum !== 20" <div style="display: flex; align-items: center">
:key="key" <el-select
:label="userType.UserType" ref="userType"
:value="userType.Id" v-model="user.Roles"
/> size="small"
</el-select> placeholder="Please select"
multiple
style="width: 100%"
:disabled="user.CanEditUserType === false || type === 1"
@change="handleChange"
>
<template v-for="(userType, key) of userTypeOptions">
<el-option
v-if="userType.UserTypeEnum !== 20"
:key="key"
:label="userType.UserType"
:value="userType.Id"
/>
</template>
</el-select>
<el-button
type="primary"
size="small"
style="margin-left: 5px"
v-if="type === 1"
@click.stop="openRoleList"
>
{{ $t('system:userlist:button:roles') }}
</el-button>
</div>
</el-form-item> </el-form-item>
</el-card> </el-card>
<el-card class="Affiliation" shadow="never" style="margin-top:10px;" size="small"> <el-card
class="Affiliation"
shadow="never"
style="margin-top: 10px"
size="small"
>
<div slot="header" class="clearfix"> <div slot="header" class="clearfix">
<span>{{ $t('system:userlist:title:Affiliation') }}</span> <span>{{ $t('system:userlist:title:Affiliation') }}</span>
</div> </div>
<el-form-item prop="IsZhiZhun"> <el-form-item prop="IsZhiZhun">
<el-radio-group v-model="user.IsZhiZhun" @change="OrgnizationTypeChanged"> <el-radio-group
<el-radio :label="true">{{ $t('system:userlist:title:Internal') }}</el-radio> v-model="user.IsZhiZhun"
<el-radio :label="false">{{ $t('system:userlist:title:External') }}</el-radio> @change="OrgnizationTypeChanged"
>
<el-radio :label="true">{{
$t('system:userlist:title:Internal')
}}</el-radio>
<el-radio :label="false">{{
$t('system:userlist:title:External')
}}</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<el-form-item v-show="user.IsZhiZhun === false" :label="$t('system:userlist:table:OrganizationName')"> <el-form-item
v-show="user.IsZhiZhun === false"
:label="$t('system:userlist:table:OrganizationName')"
>
<el-input v-model="user.OrganizationName" /> <el-input v-model="user.OrganizationName" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:Department')" prop="DepartmentName"> <el-form-item
:label="$t('system:userlist:table:Department')"
prop="DepartmentName"
>
<el-input v-model="user.DepartmentName" /> <el-input v-model="user.DepartmentName" />
</el-form-item> </el-form-item>
<el-form-item :label="$t('system:userlist:table:Position')" prop="PositionName"> <el-form-item
:label="$t('system:userlist:table:Position')"
prop="PositionName"
>
<el-input v-model="user.PositionName" /> <el-input v-model="user.PositionName" />
</el-form-item> </el-form-item>
</el-card> </el-card>
@ -83,20 +154,34 @@
type="primary" type="primary"
size="small" size="small"
:disabled="isDisabled" :disabled="isDisabled"
style="margin:10px 15px" style="margin: 10px 15px"
@click="handleSave" @click="handleSave"
>Save</el-button> >Save</el-button
>
</el-form-item> </el-form-item>
<roleList
v-if="visible"
:visible.sync="visible"
:list="user.UserRoleList"
:roles.sync="user.Roles"
:userTypeOptions="userTypeOptions"
/>
</el-form> </el-form>
</template> </template>
<script> <script>
import { getUser, addUser, updateUser, getUserTypeListByUserType } from '@/api/admin.js' import {
getUser,
addUser,
updateUser,
getUserTypeListByUserType,
} from '@/api/admin.js'
import roleList from './roleList.vue'
export default { export default {
name: 'UserInfo', name: 'UserInfo',
props: { props: {
userId: { type: String, default: '' } userId: { type: String, default: '' },
}, },
components: { roleList },
created() { created() {
this.getUserTypeList() this.getUserTypeList()
if (this.userId !== '') { if (this.userId !== '') {
@ -107,26 +192,42 @@ export default {
} }
}, },
methods: { methods: {
updateQueryParam(param, newValue,wurl) { openRoleList() {
this.visible = true
},
handleChange(val) {
this.user.UserRoleList = []
val.forEach((item) => {
let data = this.userTypeOptions.find((d) => d.Id === item)
this.user.UserRoleList.push({
UserTypeEnum: data.UserTypeEnum,
UserTypeId: data.Id,
IsUserRoleDisabled: false,
})
})
},
updateQueryParam(param, newValue, wurl) {
// URL // URL
let url = wurl || window.location.href; let url = wurl || window.location.href
// //
let regex = new RegExp('([?&])' + param + '=.*?(&|$)'); let regex = new RegExp('([?&])' + param + '=.*?(&|$)')
let separator = url.indexOf('?') !== -1 ? '&' : '?'; let separator = url.indexOf('?') !== -1 ? '&' : '?'
// //
if (regex.test(url)) { if (regex.test(url)) {
return url.replace(regex, '$1' + param + '=' + newValue + '$2'); return url.replace(regex, '$1' + param + '=' + newValue + '$2')
} else { } else {
return url + separator + param + '=' + newValue; return url + separator + param + '=' + newValue
} }
}, },
handleSave() { handleSave() {
this.$refs.userForm.validate(valid => { this.$refs.userForm.validate((valid) => {
if (valid) { if (valid) {
this.isDisabled = true this.isDisabled = true
const selectedUserType = this.userTypeOptions.filter(item => item.Id === this.user.UserTypeId) const selectedUserType = this.userTypeOptions.filter(
(item) => item.Id === this.user.UserTypeId
)
let newUrl = this.updateQueryParam('userName', this.user.UserName) let newUrl = this.updateQueryParam('userName', this.user.UserName)
newUrl = this.updateQueryParam('email', this.user.EMail, newUrl) newUrl = this.updateQueryParam('email', this.user.EMail, newUrl)
window.history.pushState({ path: newUrl }, '', newUrl) window.history.pushState({ path: newUrl }, '', newUrl)
@ -136,53 +237,87 @@ export default {
this.user.BaseUrl = `${location.protocol}//${location.host}/login` this.user.BaseUrl = `${location.protocol}//${location.host}/login`
this.user.RouteUrl = `${location.protocol}//${location.host}/email-recompose` this.user.RouteUrl = `${location.protocol}//${location.host}/email-recompose`
if (this.user.Id) { if (this.user.Id) {
updateUser(this.user).then(res => { updateUser(this.user)
this.isDisabled = false .then((res) => {
this.$message.success('Updated successfully') this.isDisabled = false
}).catch(() => { this.isDisabled = false }) this.$message.success('Updated successfully')
})
.catch(() => {
this.isDisabled = false
})
} else { } else {
addUser(this.user).then(res => { addUser(this.user)
this.isDisabled = false .then((res) => {
this.user.Id = res.Result.Id this.isDisabled = false
this.user.UserCode = res.Result.UserCode this.user.Id = res.Result.Id
this.$emit('getUserId', res.Result.Id) this.user.UserCode = res.Result.UserCode
this.$message.success('Added successfully') this.$emit('getUserId', res.Result.Id)
this.$router.push({ path: '/system/user/list' }) this.$message.success('Added successfully')
}).catch(() => { this.isDisabled = false }) this.$router.push({ path: '/system/user/list' })
})
.catch(() => {
this.isDisabled = false
})
} }
} }
}) })
}, },
getUserTypeList() { getUserTypeList() {
getUserTypeListByUserType(0).then(res => { getUserTypeListByUserType(0).then((res) => {
if (res.IsSuccess) { if (res.IsSuccess) {
this.userTypeOptions = res.Result this.userTypeOptions = res.Result
} }
}) })
}, },
getUserInfo() { getUserInfo() {
getUser(this.userId).then(res => { getUser({
IdentityUserId: this.userId,
}).then((res) => {
this.user = res.Result this.user = res.Result
this.user.Roles = []
this.user.UserRoleList = []
res.Result.AccountList.forEach((item) => {
if (!item.IsUserRoleDisabled) {
this.user.Roles.push(item.UserTypeId)
}
this.user.UserRoleList.push({
UserTypeEnum: item.UserTypeEnum,
UserTypeId: item.UserTypeId,
IsUserRoleDisabled: item.IsUserRoleDisabled,
UserTypeShortName: item.UserTypeShortName,
})
})
}) })
}, },
OrgnizationTypeChanged(val) { OrgnizationTypeChanged(val) {
this.user.OrganizationName = '' this.user.OrganizationName = ''
} },
}, },
data() { data() {
var validatePassword = (rule, value, callback) => { var validatePassword = (rule, value, callback) => {
var lang = zzSessionStorage.getItem('lang')?zzSessionStorage.getItem('lang'):'zh' var lang = zzSessionStorage.getItem('lang')
? zzSessionStorage.getItem('lang')
: 'zh'
/* eslint-disable */ /* eslint-disable */
var reg1 = /^[a-zA-Z0-9_]{4,16}$/; //8 var reg1 = /^[a-zA-Z0-9_]{4,16}$/ //8
console.log(!reg1.test(value))
if (!reg1.test(value)) { if (!reg1.test(value)) {
callback(lang==='zh' ? new Error("1新建账号用户名字符长度最小为4个字符最大为16个字符只可使用字母、数字、下划线") : new Error('For a new account, the username must have:1) At least 4 characters;2) At most 16 characters;3)Only letters, numbers, and underscores are allowed.')) callback(
lang === 'zh'
? new Error(
'1新建账号用户名字符长度最小为4个字符最大为16个字符只可使用字母、数字、下划线'
)
: new Error(
'For a new account, the username must have:1) At least 4 characters;2) At most 16 characters;3)Only letters, numbers, and underscores are allowed.'
)
)
} else { } else {
callback(); callback()
} }
} }
return { return {
user: { user: {
Roles: [],
UserRoleList: [],
UserName: '', UserName: '',
LastName: '', LastName: '',
FirstName: '', FirstName: '',
@ -194,65 +329,75 @@ export default {
OrganizationName: '', OrganizationName: '',
DepartmentName: '', DepartmentName: '',
PositionName: '', PositionName: '',
IsTestUser: false IsTestUser: false,
}, },
visible: false,
userFormRules: { userFormRules: {
UserName: [ UserName: [
{ required: true, validator: validatePassword, trigger: 'blur' } { required: true, validator: validatePassword, trigger: 'blur' },
], ],
UserTypeId: [ Roles: [
{ required: true, message: 'Please Select', trigger: ['blur', 'change'] } {
required: true,
message: 'Please Select',
trigger: ['blur', 'change'],
},
], ],
IsZhiZhun: [ IsZhiZhun: [
{ required: true, message: 'Please Select', trigger: ['blur', 'change'] } {
required: true,
message: 'Please Select',
trigger: ['blur', 'change'],
},
], ],
OrganizationName: [ OrganizationName: [
{ required: true, message: 'Please specify', trigger: 'blur' } { required: true, message: 'Please specify', trigger: 'blur' },
], ],
LastName: [ LastName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
], ],
FirstName: [ FirstName: [
{ required: true, message: 'Please specify', trigger: 'blur' }, { required: true, message: 'Please specify', trigger: 'blur' },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
], ],
Phone: [ Phone: [
{ max: 20, min: 7, message: 'The length is 7 to 20', trigger: ['blur'] } {
max: 20,
min: 7,
message: 'The length is 7 to 20',
trigger: ['blur'],
},
], ],
EMail: [ EMail: [
{ {
required: true, required: true,
message: 'Please input the email address', message: 'Please input the email address',
trigger: 'blur' trigger: 'blur',
}, },
{ {
type: 'email', type: 'email',
message: 'Please input the correct email address', message: 'Please input the correct email address',
trigger: ['blur'] trigger: ['blur'],
}, },
{ max: 50, message: 'The maximum length is 50' } { max: 50, message: 'The maximum length is 50' },
],
Sex: [
{ required: true, message: 'Please specify', trigger: 'blur' }
], ],
Sex: [{ required: true, message: 'Please specify', trigger: 'blur' }],
Status: [ Status: [
{ required: true, message: 'Please specify', trigger: 'blur' } { required: true, message: 'Please specify', trigger: 'blur' },
], ],
DepartmentName: [ DepartmentName: [{ max: 50, message: 'The maximum length is 50' }],
{ max: 50, message: 'The maximum length is 50' }], PositionName: [{ max: 50, message: 'The maximum length is 50' }],
PositionName: [{ max: 50, message: 'The maximum length is 50' }
]
}, },
userTypeOptions: [], userTypeOptions: [],
isDisabled: false, isDisabled: false,
type: 0 // 10 type: 0, // 10
} }
} },
} }
</script> </script>
<style scoped> <style scoped>
/deep/ .is-error.my_new_pwd{ ::v-deep .is-error.my_new_pwd {
margin-bottom: 40px; margin-bottom: 40px;
} }
</style> </style>

View File

@ -0,0 +1,196 @@
<template>
<el-dialog
v-if="visible"
:visible.sync="visible"
v-dialogDrag
width="540px"
:close-on-click-modal="false"
:close-on-press-escape="false"
append-to-body
:show-close="false"
:title="$t('system:userlist:roleList:title')"
:before-close="cancel"
>
<el-button
size="mini"
type="primary"
@click.stop="openAdd"
style="float: right"
>
{{ $t('common:button:new') }}
</el-button>
<el-table :data="list" style="width: 100%" max-height="300px">
<el-table-column type="index" width="40" />
<el-table-column
prop="UserTypeShortName"
:label="$t('system:userlist:roleList:table:UserTypeShortName')"
/>
<el-table-column
prop="IsUserRoleDisabled"
:label="$t('system:userlist:roleList:table:IsUserRoleDisabled')"
>
<template slot-scope="scope">
<span> {{ $fd('IsEnable', !scope.row.IsUserRoleDisabled) }}</span>
</template>
</el-table-column>
<el-table-column :label="$t('common:action:action')" width="120px">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
:disabled="scope.row.IsUserRoleDisabled"
@click.stop="scope.row.IsUserRoleDisabled = true"
>
{{ $fd('IsEnable', false) }}
</el-button>
<el-button
size="mini"
type="text"
:disabled="!scope.row.IsUserRoleDisabled"
@click.stop="scope.row.IsUserRoleDisabled = false"
>
{{ $fd('IsEnable', true) }}
</el-button>
</template>
</el-table-column>
</el-table>
<div slot="footer">
<!-- 保存 -->
<el-button type="primary" size="small" @click="save">
{{ $t('common:button:confirm') }}
</el-button>
</div>
<el-dialog
v-if="addVisible"
:visible.sync="addVisible"
v-dialogDrag
:close-on-click-modal="false"
:close-on-press-escape="false"
append-to-body
width="540px"
:title="$t('system:userlist:roleList:addTitle')"
>
<el-form ref="addForm" :model="form" :rules="rule" label-width="80px">
<el-form-item :label="$t('system:userlist:table:UserType')">
<el-select
v-model="form.roles"
size="small"
placeholder=""
multiple
style="width: 100%"
>
<template v-for="item of roleList">
<el-option
:key="item.Id"
:label="item.UserType"
:value="item.Id"
/>
</template>
</el-select>
</el-form-item>
</el-form>
<div slot="footer">
<!-- 保存 -->
<el-button type="primary" size="small" @click="saveAdd">
{{ $t('common:button:confirm') }}
</el-button>
<!-- 取消 -->
<el-button size="small" @click="addVisible = false">
{{ $t('common:button:cancel') }}
</el-button>
</div>
</el-dialog>
</el-dialog>
</template>
<script>
export default {
name: 'roleList',
props: {
visible: {
type: Boolean,
default: false,
},
list: {
type: Array,
default: () => {
return []
},
},
roles: {
type: Array,
default: () => {
return []
},
},
userTypeOptions: {
type: Array,
default: () => {
return []
},
},
},
data() {
return {
addVisible: false,
form: {
roles: [],
},
rule: {
roles: [
{
required: true,
message: 'Please Select',
trigger: ['blur', 'change'],
},
],
},
}
},
computed: {
roleList() {
let arr = this.list.map((item) => item.UserTypeId)
return this.userTypeOptions.filter(
(item) => !arr.includes(item.Id) && item.UserTypeEnum !== 20
)
},
},
methods: {
cancel() {
this.$emit('update:visible', false)
},
openAdd() {
this.addVisible = true
},
save() {
let roles = []
this.list.forEach((item) => {
if (!item.IsUserRoleDisabled) {
roles.push(item.UserTypeId)
}
})
this.$emit('update:roles', roles)
this.$emit('update:visible', false)
},
async saveAdd() {
try {
let validate = await this.$refs.addForm.validate()
if (!validate) return
let arr = this.userTypeOptions.filter((item) =>
this.form.roles.includes(item.Id)
)
arr.forEach((item) => {
this.list.push({
UserTypeEnum: item.UserTypeEnum,
UserTypeId: item.Id,
IsUserRoleDisabled: false,
UserTypeShortName: item.UserTypeShortName,
})
})
this.addVisible = false
} catch (err) {
console.log(err)
}
},
},
}
</script>

View File

@ -35,6 +35,16 @@
<template slot="genderSlot" slot-scope="{ scope }"> <template slot="genderSlot" slot-scope="{ scope }">
{{ scope.row.Sex ? 'Male' : 'Female' }} {{ scope.row.Sex ? 'Male' : 'Female' }}
</template> </template>
<template slot="UserTypeSlot" slot-scope="{ scope }">
{{
Array.isArray(scope.row.UserRoleList) &&
scope.row.UserRoleList.length > 0
? scope.row.UserRoleList.map((item) => item.UserTypeShortName).join(
','
)
: ''
}}
</template>
<template slot="roleSlot" slot-scope="{ scope }"> <template slot="roleSlot" slot-scope="{ scope }">
{{ scope.row.RoleNameList.map((role) => role.RoleName).join(',') }} {{ scope.row.RoleNameList.map((role) => role.RoleName).join(',') }}
</template> </template>
@ -115,7 +125,7 @@ export default {
showOverflowTooltip: true, showOverflowTooltip: true,
}, },
{ {
prop: 'RealName', prop: 'FullName',
label: this.$t('system:userlist:table:RealName'), label: this.$t('system:userlist:table:RealName'),
minWidth: 120, minWidth: 120,
sortable: 'custom', sortable: 'custom',
@ -154,6 +164,7 @@ export default {
prop: 'UserType', prop: 'UserType',
label: this.$t('system:userlist:table:UserType'), label: this.$t('system:userlist:table:UserType'),
minWidth: 100, minWidth: 100,
slot: 'UserTypeSlot',
sortable: 'custom', sortable: 'custom',
showOverflowTooltip: true, showOverflowTooltip: true,
}, },

View File

@ -44,7 +44,6 @@ export default {
this.$i18n.locale = lang this.$i18n.locale = lang
this.setLanguage(lang) this.setLanguage(lang)
this.$updateDictionary() this.$updateDictionary()
console.log(Vue)
this.$upload() this.$upload()
window.location.reload() window.location.reload()
} }

View File

@ -11,7 +11,7 @@
<img v-else src="@/assets/zzlogo4.png" alt="" /> <img v-else src="@/assets/zzlogo4.png" alt="" />
<span style="white-space: nowrap" v-if="NODE_ENV !== 'usa'"> <span style="white-space: nowrap" v-if="NODE_ENV !== 'usa'">
<!-- 中心影像系统EICS --> <!-- 中心影像系统EICS -->
{{ $t("trials:trials:title:eics") }} {{ $t('trials:trials:title:eics') }}
</span> </span>
</div> </div>
<div class="center-menu"> <div class="center-menu">
@ -39,13 +39,17 @@
> >
<i class="el-icon-odometer" /> <i class="el-icon-odometer" />
<!-- 工作台 --> <!-- 工作台 -->
<span slot="title">{{ $t("trials:menuTitle:workbench") }}</span> <span slot="title">{{ $t('trials:menuTitle:workbench') }}</span>
</el-menu-item> </el-menu-item>
<el-menu-item v-if="!hasPermi(['role:zys','role:zyss','role:zybs'])" index="2" :disabled="TotalNeedSignSystemDocCount !== 0"> <el-menu-item
v-if="!hasPermi(['role:zys', 'role:zyss', 'role:zybs'])"
index="2"
:disabled="TotalNeedSignSystemDocCount !== 0"
>
<i class="el-icon-box" /> <i class="el-icon-box" />
<!-- 我的项目 --> <!-- 我的项目 -->
<span slot="title"> <span slot="title">
{{ $t("trials:tab:trials") }} {{ $t('trials:tab:trials') }}
</span> </span>
</el-menu-item> </el-menu-item>
<el-menu-item <el-menu-item
@ -63,7 +67,7 @@
> >
<i class="el-icon-chat-dot-square" /> <i class="el-icon-chat-dot-square" />
<!-- 通知消息 --> <!-- 通知消息 -->
<span slot="title">{{ $t("trials:tab:notice") }}</span> <span slot="title">{{ $t('trials:tab:notice') }}</span>
</el-menu-item> </el-menu-item>
<el-submenu index="4" class="my_info"> <el-submenu index="4" class="my_info">
@ -75,128 +79,214 @@
</span> </span>
<!-- 账户信息 --> <!-- 账户信息 -->
<el-menu-item v-if="!hasPermi(['role:air'])" index="4-2">{{ <el-menu-item v-if="!hasPermi(['role:air'])" index="4-2">{{
$t("trials:trials-myinfo:title:accountInfo") $t('trials:trials-myinfo:title:accountInfo')
}}</el-menu-item> }}</el-menu-item>
<!-- 管理后台 --> <!-- 管理后台 -->
<el-menu-item <el-menu-item
v-if="hasPermi(['role:dev', 'role:oa', 'role:admin'])" v-if="hasPermi(['role:dev', 'role:oa', 'role:admin'])"
index="4-4" index="4-4"
>{{ $t("trials:trials-myinfo:title:system") }}</el-menu-item >{{ $t('trials:trials-myinfo:title:system') }}</el-menu-item
> >
<!-- 切换角色 -->
<el-menu-item index="4-5" v-if="hasRole">{{
$t('trials:trials-myinfo:title:toggleRole')
}}</el-menu-item>
<!-- 退出 --> <!-- 退出 -->
<el-menu-item index="4-3">{{ <el-menu-item index="4-3">{{
$t("trials:trials-myinfo:button:loginout") $t('trials:trials-myinfo:button:loginout')
}}</el-menu-item> }}</el-menu-item>
</el-submenu> </el-submenu>
</el-menu> </el-menu>
<TopLang v-if="VUE_APP_OSS_CONFIG_REGION !== 'oss-us-west-1'&& NODE_ENV !== 'usa'" /> <TopLang
v-if="
VUE_APP_OSS_CONFIG_REGION !== 'oss-us-west-1' && NODE_ENV !== 'usa'
"
/>
</div> </div>
<toggleRole
v-if="toggleRoleVisible"
:visible.sync="toggleRoleVisible"
:loading="toggleRoleLoading"
@save="loginByRole"
/>
</div> </div>
</template> </template>
<script> <script>
import { mapGetters, mapMutations } from "vuex"; import { mapGetters, mapMutations } from 'vuex'
import TopLang from "./topLang"; import TopLang from './topLang'
import NoticeMarquee from "./noticeMarquee"; import NoticeMarquee from './noticeMarquee'
import toggleRole from '@/components/toggleRole'
export default { export default {
components: { TopLang, NoticeMarquee }, components: { TopLang, NoticeMarquee, toggleRole },
data() { data() {
return { return {
activeIndex: "2", activeIndex: '2',
isReviewer: false, isReviewer: false,
userTypeShortName: zzSessionStorage.getItem("userTypeShortName"), userTypeShortName: zzSessionStorage.getItem('userTypeShortName'),
notice: "", notice: '',
VUE_APP_OSS_CONFIG_REGION: process.env.VUE_APP_OSS_CONFIG_REGION, VUE_APP_OSS_CONFIG_REGION: process.env.VUE_APP_OSS_CONFIG_REGION,
NODE_ENV: process.env.NODE_ENV, NODE_ENV: process.env.NODE_ENV,
}; toggleRoleVisible: false,
toggleRoleLoading: false,
}
}, },
computed: { computed: {
...mapGetters([ ...mapGetters([
"sidebar", 'sidebar',
"name", 'name',
"userName", 'userName',
"device", 'device',
"TotalNeedSignSystemDocCount", 'TotalNeedSignSystemDocCount',
"language", 'language',
]), ]),
roles() {
return this.$store.state.user.roles
},
hasRole() {
return this.roles && this.roles.length > 1
},
}, },
watch: { watch: {
$route(v) { $route(v) {
this.changeRoute(v); this.changeRoute(v)
}, },
}, },
created() { created() {
console.log(!this.hasPermi(["role:air"])); // this.isReviewer = JSON.parse(zzSessionStorage.getItem('IsReviewer'))
this.isReviewer = JSON.parse(zzSessionStorage.getItem("IsReviewer")); this.changeRoute(this.$route)
this.changeRoute(this.$route);
}, },
methods: { methods: {
...mapMutations({ setLanguage: "lang/setLanguage" }), ...mapMutations({ setLanguage: 'lang/setLanguage' }),
changeRoute(v) { changeRoute(v) {
if (v.path === "/trials/trials-workbench") { if (v.path === '/trials/trials-workbench') {
this.activeIndex = "1"; this.activeIndex = '1'
} }
if ( if (
v.path === "/trials/trials-list" || v.path === '/trials/trials-list' ||
~v.path.indexOf("/trials/trials-panel") ~v.path.indexOf('/trials/trials-panel')
) { ) {
this.activeIndex = "2"; this.activeIndex = '2'
} }
if (v.path === "/trials/trials-notice") { if (v.path === '/trials/trials-notice') {
this.activeIndex = "3"; this.activeIndex = '3'
} }
if (v.path === "/trials/trials-myinfo") { if (v.path === '/trials/trials-myinfo') {
this.activeIndex = "4-2"; this.activeIndex = '4-2'
} }
}, },
handleSelect(key, keyPath) { handleSelect(key, keyPath) {
switch (key) { switch (key) {
case "4-2": case '4-2':
this.go("/trials/trials-myinfo"); this.go('/trials/trials-myinfo')
break; break
case "4-3": case '4-3':
this.logout(); this.logout()
break; break
case "4-4": case '4-4':
this.go("/dashboard/list"); this.go('/dashboard/list')
break; break
case "1": case '4-5':
this.go("/trials/trials-workbench"); // this.go('/dashboard/list')
break; // console.log('')
case "2": this.$store.dispatch('user/getUserInfo').then((res) => {
if (~this.$route.path.indexOf("/trials/trials-panel")) { this.toggleRoleVisible = true
return; })
break
case '1':
this.go('/trials/trials-workbench')
break
case '2':
if (~this.$route.path.indexOf('/trials/trials-panel')) {
return
} }
var lastWorkbench = zzSessionStorage.getItem("lastWorkbench"); var lastWorkbench = zzSessionStorage.getItem('lastWorkbench')
if (lastWorkbench) { if (lastWorkbench) {
this.go(lastWorkbench); this.go(lastWorkbench)
} else { } else {
this.go("/trials/trials-list"); this.go('/trials/trials-list')
} }
break; break
case "3": case '3':
this.go("/trials/trials-notice"); this.go('/trials/trials-notice')
break; break
} }
}, },
toggleSideBar() { toggleSideBar() {
this.$store.dispatch("app/toggleSideBar"); this.$store.dispatch('app/toggleSideBar')
}, },
async logout() { async logout() {
await this.$store.dispatch("user/logout"); await this.$store.dispatch('user/logout')
this.$router.push(`/login`); this.$router.push(`/login`)
this.$i18n.locale = "zh"; this.$i18n.locale = 'zh'
this.setLanguage("zh"); this.setLanguage('zh')
this.$updateDictionary(); this.$updateDictionary()
}, },
go(value) { go(value) {
this.$router.push({ path: value }); this.$router.push({ path: value })
}, },
account() { account() {
this.$router.push({ name: "Account" }); this.$router.push({ name: 'Account' })
},
loginByRole(userRoleId) {
if (this.$store.state.user.userId === userRoleId) {
this.toggleRoleVisible = false
this.toggleRoleLoading = false
return false
}
this.toggleRoleLoading = true
this.$store
.dispatch('user/loginByRole', { userRoleId })
.then((res) => {
if (res) {
this.$store
.dispatch('permission/generateRoutes')
.then(async (res) => {
if (res && res.length > 0) {
await this.$store.dispatch('global/getNoticeList')
this.$router.addRoutes(res)
this.toggleRoleLoading = false
if (this.loginType === 'DevOps') {
this.$router.replace({ path: res[0].path })
return
}
if (this.hasPermi(['role:radmin'])) {
this.$router.replace({ path: res[0].path })
return
}
if (
this.hasPermi([
'role:air',
'role:rpm',
'role:rcrc',
'role:rir',
])
) {
this.$router.replace({ path: '/trials/trials-list' })
} else {
this.$router.replace({ path: '/trials' })
}
window.location.reload()
} else {
//
this.toggleRoleLoading = false
this.$message.warning(this.$t('login:message:login2'))
}
})
.catch((err) => {
this.toggleRoleLoading = false
})
} else {
this.toggleRoleLoading = false
}
})
.catch(() => {
this.toggleRoleLoading = false
})
}, },
}, },
}; }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>

View File

@ -108,6 +108,35 @@
{{ $t('trials:trials-myinfo:button:update') }} {{ $t('trials:trials-myinfo:button:update') }}
</el-button> </el-button>
</el-form-item> </el-form-item>
<el-form-item
:label="$t('trials:trials-myinfo:form:toggleRole')"
style="position: relative"
prop="VerificationCode"
v-if="hasRole"
>
<el-radio-group v-model="userRoleId" class="roles" v-if="hasRole">
<el-radio
v-for="item in roles"
:key="item.Id"
:label="item.Id"
:disabled="item.isUserRoleDisabled"
style="margin-bottom: 10px"
>
{{ item.UserTypeShortName }}
</el-radio>
</el-radio-group>
<!-- 修改 -->
<el-button
:disabled="!userRoleId"
class="saveBtn"
:loading="toggleRoleLoading"
type="primary"
size="small"
@click="toggleRole"
>
{{ $t('trials:trials-myinfo:button:toggleRole') }}
</el-button>
</el-form-item>
</el-form> </el-form>
</div> </div>
<password /> <password />
@ -142,6 +171,8 @@ export default {
data() { data() {
return { return {
userForm: {}, userForm: {},
userRoleId: null,
toggleRoleLoading: false,
sendDisabled: true, sendDisabled: true,
sendTitle: this.$t('trials:trials-myinfo:button:getVCode'), sendTitle: this.$t('trials:trials-myinfo:button:getVCode'),
rule: { rule: {
@ -174,7 +205,35 @@ export default {
}, },
} }
}, },
created() {
this.userRoleId = zzSessionStorage.getItem('userId')
},
computed: {
roles() {
return this.$store.state.user.roles
},
hasRole() {
return this.roles && this.roles.length > 1
},
},
methods: { methods: {
//
toggleRole() {
if (
this.userRoleId === zzSessionStorage.getItem('userId') ||
this.toggleRoleLoading
)
return false
this.toggleRoleLoading = true
this.$store
.dispatch('user/loginByRole', { userRoleId: this.userRoleId })
.then((res) => {
window.location.reload()
})
.catch(() => {
this.toggleRoleLoading = false
})
},
setNewEmail() { setNewEmail() {
setNewEmail(this.userForm.EMail, this.userForm.VerificationCode).then( setNewEmail(this.userForm.EMail, this.userForm.VerificationCode).then(
() => { () => {

View File

@ -107,11 +107,11 @@ export default {
spinner: 'el-icon-loading', spinner: 'el-icon-loading',
background: 'rgba(0, 0, 0, 0.07)', background: 'rgba(0, 0, 0, 0.07)',
}) })
getUser(this.userId) getUser()
.then(async (res) => { .then(async (res) => {
this.user = res.Result this.user = res.Result
/* eslint-disable */ /* eslint-disable */
zzSessionStorage.setItem('realName', this.user.RealName) zzSessionStorage.setItem('Name', this.user.FullName)
await store.dispatch('user/updateInfo') await store.dispatch('user/updateInfo')
loading.close() loading.close()
}) })

View File

@ -82,7 +82,7 @@
</div> </div>
</template> </template>
<script> <script>
import { updateUser } from "@/api/admin.js"; import { updateUserBasicInfo } from "@/api/admin.js";
export default { export default {
name: "mine", name: "mine",
props: { props: {
@ -179,7 +179,7 @@ export default {
// this.user.OrganizationName = 'ZhiZhun' // this.user.OrganizationName = 'ZhiZhun'
// } // }
if (this.user.Id) { if (this.user.Id) {
updateUser(this.user) updateUserBasicInfo(this.user)
.then((res) => { .then((res) => {
this.isDisabled = false; this.isDisabled = false;
this.$message.success( this.$message.success(

View File

@ -109,15 +109,13 @@ export default {
this.TrialSiteId = row.TrialSiteId this.TrialSiteId = row.TrialSiteId
this.config.title = this.$t( this.config.title = this.$t(
'trials:trials-panel:setting:personnel-manage:dicomAETitle' 'trials:trials-panel:setting:personnel-manage:dicomAETitle'
).replace('xxx', `${row.TrialSiteCode}${row.TrialSiteAliasName}`) )
.replace('xxx', `${row.TrialSiteCode}`)
.replace('yyy', `${row.TrialSiteAliasName}`)
this.siteData = row this.siteData = row
this.config.visible = true this.config.visible = true
this.getList() this.getList()
console.log(
this.hasPermi([
'trials:trials-panel:setting:personnel-manage:edit-site',
])
)
}, },
// dicomAE // dicomAE
async getList() { async getList() {

View File

@ -47,26 +47,26 @@
:disabled="loading" :disabled="loading"
@click="config.visible = false" @click="config.visible = false"
> >
{{ $t("common:button:cancel") }} {{ $t('common:button:cancel') }}
</el-button> </el-button>
<el-button type="primary" size="small" :loading="loading" @click="save"> <el-button type="primary" size="small" :loading="loading" @click="save">
{{ $t("common:button:save") }} {{ $t('common:button:save') }}
</el-button> </el-button>
</template> </template>
</base-model> </base-model>
</template> </template>
<script> <script>
import { addOrUpdateTrialSiteDicomAE } from "@/api/trials"; import { addOrUpdateTrialSiteDicomAE } from '@/api/trials'
import BaseModel from "@/components/BaseModel"; import BaseModel from '@/components/BaseModel'
export default { export default {
name: "dicomForm", name: 'dicomForm',
components: { BaseModel }, components: { BaseModel },
data() { data() {
return { return {
config: { config: {
visible: false, visible: false,
title: null, title: null,
width: "600px", width: '600px',
appendToBody: true, appendToBody: true,
}, },
form: { form: {
@ -80,128 +80,127 @@ export default {
CallingAE: [ CallingAE: [
{ {
required: true, required: true,
message: this.$t("common:ruleMessage:specify"), message: this.$t('common:ruleMessage:specify'),
trigger: "blur", trigger: 'blur',
}, },
{ {
pattern: /[a-zA-Z0-9]/, pattern: /[a-zA-Z0-9]/,
message: this.$t("common:ruleMessage:CallingAEPattern"), message: this.$t('common:ruleMessage:CallingAEPattern'),
trigger: "blur", trigger: 'blur',
}, },
{ {
min: 1, min: 1,
max: 16, max: 16,
message: this.$t("common:ruleMessage:CallingAEPattern"), message: this.$t('common:ruleMessage:CallingAEPattern'),
trigger: "blur", trigger: 'blur',
}, },
], ],
Ip: [ Ip: [
{ {
required: true, required: true,
message: this.$t("common:ruleMessage:specify"), message: this.$t('common:ruleMessage:specify'),
trigger: "blur", trigger: 'blur',
}, },
{ {
validator: (rule, value, callback) => { validator: (rule, value, callback) => {
if ( if (
value === "" || value === '' ||
typeof value === "undefined" || typeof value === 'undefined' ||
value == null value == null
) { ) {
callback(new Error(this.$t("common:ruleMessage:ipPattern"))); callback(new Error(this.$t('common:ruleMessage:ipPattern')))
} else { } else {
const reg = const reg =
/^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/; /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/
if (!reg.test(value) && value !== "") { if (!reg.test(value) && value !== '') {
callback(new Error(this.$t("common:ruleMessage:ipPattern"))); callback(new Error(this.$t('common:ruleMessage:ipPattern')))
} else { } else {
callback(); callback()
} }
} }
}, },
message: this.$t("common:ruleMessage:ipPattern"), message: this.$t('common:ruleMessage:ipPattern'),
trigger: "blur", trigger: 'blur',
}, },
], ],
Port: [ Port: [
{ {
required: true, required: true,
message: this.$t("common:ruleMessage:specify"), message: this.$t('common:ruleMessage:specify'),
trigger: "blur", trigger: 'blur',
}, },
{ {
type: "number", type: 'number',
min: 0, min: 0,
max: 65535, max: 65535,
message: this.$t("common:ruleMessage:portPattern"), message: this.$t('common:ruleMessage:portPattern'),
trigger: "blur", trigger: 'blur',
}, },
{ {
validator: (rule, value, callback) => { validator: (rule, value, callback) => {
if ( if (
value && value &&
(String(value).includes(".") || (String(value).includes('.') ||
new RegExp(/\D/g).test(String(value))) new RegExp(/\D/g).test(String(value)))
) { ) {
callback(new Error(this.$t("common:ruleMessage:portPattern"))); callback(new Error(this.$t('common:ruleMessage:portPattern')))
} else { } else {
callback(); callback()
} }
}, },
trigger: "blur", trigger: 'blur',
}, },
], ],
}, },
siteData: {}, siteData: {},
loading: false, loading: false,
status: "add", status: 'add',
}; }
}, },
methods: { methods: {
open(siteData, data = null, status = "add") { open(siteData, data = null, status = 'add') {
this.siteData = siteData; this.siteData = siteData
this.status = status; this.status = status
Object.keys(this.form).forEach((key) => { Object.keys(this.form).forEach((key) => {
this.form[key] = null; this.form[key] = null
}); })
if (data && status === "edit") { if (data && status === 'edit') {
Object.keys(this.form).forEach((key) => { Object.keys(this.form).forEach((key) => {
this.form[key] = data[key]; this.form[key] = data[key]
}); })
this.form.Ip = data.IP; this.form.Ip = data.IP
} }
this.config.title = this.$t( this.config.title = this.$t(
"trials:trials-panel:setting:personnel-manage:dicomAETitle" 'trials:trials-panel:setting:personnel-manage:dicomAETitle'
).replace( )
"xxx", .replace('xxx', `${siteData.TrialSiteCode}`)
`${siteData.TrialSiteCode}${siteData.TrialSiteAliasName}` .replace('yyy', `${siteData.TrialSiteAliasName}`)
); this.config.visible = true
this.config.visible = true;
}, },
// //
async save() { async save() {
try { try {
let validate = await this.$refs.dicomForm.validate(); let validate = await this.$refs.dicomForm.validate()
if (!validate) return false; if (!validate) return false
this.loading = true; this.loading = true
this.form.TrialSiteId = this.siteData.TrialSiteId; this.form.TrialSiteId = this.siteData.TrialSiteId
this.form.TrialId = this.$route.query.trialId; this.form.TrialId = this.$route.query.trialId
let res = await addOrUpdateTrialSiteDicomAE(this.form); let res = await addOrUpdateTrialSiteDicomAE(this.form)
this.loading = false; this.loading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.status === "add" this.status === 'add'
? this.$t("common:message:savedSuccessfully") ? this.$t('common:message:savedSuccessfully')
: this.$t("common:message:savedFail"); : this.$t('common:message:savedFail')
this.$emit("getList"); this.$emit('getList')
this.$emit("save"); this.$emit('save')
this.config.visible = false; this.config.visible = false
} }
} catch (err) { } catch (err) {
console.log(err); console.log(err)
this.loading = false; this.loading = false
} }
}, },
}, },
}; }
</script> </script>
<style lang="scss" scoped></style> <style lang="scss" scoped></style>

View File

@ -150,12 +150,7 @@
min-width="100" min-width="100"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-button <el-button size="small" type="text" @click="getCrcList(scope.row)">
v-if="scope.row.UserCount > 0"
size="small"
type="text"
@click="getCrcList(scope.row)"
>
{{ {{
scope.row.UserNameList.length > 0 scope.row.UserNameList.length > 0
? scope.row.UserNameList.join(', ') ? scope.row.UserNameList.join(', ')
@ -412,7 +407,7 @@
> >
<!-- 姓名 --> <!-- 姓名 -->
<el-table-column <el-table-column
prop="UserRealName" prop="FullName"
:label="$t('trials:internalStaff:table:name')" :label="$t('trials:internalStaff:table:name')"
min-width="100" min-width="100"
show-overflow-tooltip show-overflow-tooltip

View File

@ -16,7 +16,12 @@
<el-select v-model="listQuery.UserTypeId" clearable class="mr"> <el-select v-model="listQuery.UserTypeId" clearable class="mr">
<el-option <el-option
v-for="item of userTypeOptions" v-for="item of userTypeOptions"
v-show="item.UserTypeEnum !== 8 && item.UserTypeEnum !== 31 && item.UserTypeEnum !== 26 && item.UserTypeEnum !== 27" v-show="
item.UserTypeEnum !== 8 &&
item.UserTypeEnum !== 31 &&
item.UserTypeEnum !== 26 &&
item.UserTypeEnum !== 27
"
:key="item.Id" :key="item.Id"
:label="item.UserTypeShortName" :label="item.UserTypeShortName"
:value="item.Id" :value="item.Id"
@ -32,8 +37,13 @@
<!-- 状态 --> <!-- 状态 -->
<el-form-item :label="$t('trials:staff:table:status')"> <el-form-item :label="$t('trials:staff:table:status')">
<el-select v-model="listQuery.IsDeleted" clearable class="mr"> <el-select v-model="listQuery.IsDeleted" clearable class="mr">
<el-option v-for="item of $d.IsUserExitTrial" :label="item.label" :value="item.value" :key="item.id" /> <el-option
<!-- <el-option label="加入" :value="false" />--> v-for="item of $d.IsUserExitTrial"
:label="item.label"
:value="item.value"
:key="item.id"
/>
<!-- <el-option label="加入" :value="false" />-->
</el-select> </el-select>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@ -42,14 +52,20 @@
{{ $t('common:button:search') }} {{ $t('common:button:search') }}
</el-button> </el-button>
<!-- 重置 --> <!-- 重置 -->
<el-button type="primary" icon="el-icon-refresh-left" @click="handleReset"> <el-button
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }} {{ $t('common:button:reset') }}
</el-button> </el-button>
<!-- 添加系统用户 --> <!-- 添加系统用户 -->
<el-button <el-button
v-hasPermi="['trials:trials-panel:setting:personnel-manage:add-internal-staff']" v-hasPermi="[
'trials:trials-panel:setting:personnel-manage:add-internal-staff',
]"
type="primary" type="primary"
style="margin-left:10px" style="margin-left: 10px"
icon="el-icon-plus" icon="el-icon-plus"
@click="handleAdd('Add')" @click="handleAdd('Add')"
> >
@ -57,7 +73,9 @@
</el-button> </el-button>
<!-- 添加外部人员 --> <!-- 添加外部人员 -->
<el-button <el-button
v-hasPermi="['trials:trials-panel:setting:personnel-manage:add-external-staff']" v-hasPermi="[
'trials:trials-panel:setting:personnel-manage:add-external-staff',
]"
type="primary" type="primary"
icon="el-icon-plus" icon="el-icon-plus"
@click="handleAdd('External')" @click="handleAdd('External')"
@ -88,7 +106,7 @@
<el-table-column type="index" width="50" /> <el-table-column type="index" width="50" />
<!-- 姓名 --> <!-- 姓名 -->
<el-table-column <el-table-column
prop="UserRealName" prop="FullName"
:label="$t('trials:staff:table:name')" :label="$t('trials:staff:table:name')"
show-overflow-tooltip show-overflow-tooltip
sortable sortable
@ -109,7 +127,24 @@
show-overflow-tooltip show-overflow-tooltip
sortable sortable
width="140" width="140"
/> >
<template slot-scope="scope">
<el-button
v-if="
Array.isArray(scope.row.TrialUserRoleList) &&
scope.row.TrialUserRoleList.length > 0
"
type="text"
@click.stop="openRoleList(scope.row)"
>
<span>{{
scope.row.TrialUserRoleList.map(
(item) => item.UserTypeShortName
).join(',')
}}</span>
</el-button>
</template>
</el-table-column>
<!-- 联系电话 --> <!-- 联系电话 -->
<el-table-column <el-table-column
prop="Phone" prop="Phone"
@ -143,8 +178,12 @@
min-width="40" min-width="40"
> >
<template slot-scope="scope"> <template slot-scope="scope">
<el-tag v-if="scope.row.IsDeleted" type="danger">{{ $fd('IsUserExitTrial', scope.row.IsDeleted) }}</el-tag> <el-tag v-if="scope.row.IsDeleted" type="danger">{{
<el-tag v-else>{{ $fd('IsUserExitTrial', scope.row.IsDeleted) }}</el-tag> $fd('IsUserExitTrial', scope.row.IsDeleted)
}}</el-tag>
<el-tag v-else>{{
$fd('IsUserExitTrial', scope.row.IsDeleted)
}}</el-tag>
</template> </template>
</el-table-column> </el-table-column>
<!-- 加入日期 --> <!-- 加入日期 -->
@ -156,7 +195,11 @@
width="160" width="160"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.JoinTime?moment(scope.row.JoinTime).format('YYYY-MM-DD'):'' }} {{
scope.row.JoinTime
? moment(scope.row.JoinTime).format('YYYY-MM-DD')
: ''
}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 退出日期 --> <!-- 退出日期 -->
@ -168,25 +211,29 @@
width="160" width="160"
> >
<template slot-scope="scope"> <template slot-scope="scope">
{{ scope.row.RemoveTime? moment(scope.row.RemoveTime).format('YYYY-MM-DD'):'' }} {{
scope.row.RemoveTime
? moment(scope.row.RemoveTime).format('YYYY-MM-DD')
: ''
}}
</template> </template>
</el-table-column> </el-table-column>
<!-- 授权时间 --> <!-- 授权时间 -->
<el-table-column <!-- <el-table-column
prop="CreateTime" prop="CreateTime"
:label="$t('trials:staff:table:authorizationTime')" :label="$t('trials:staff:table:authorizationTime')"
show-overflow-tooltip show-overflow-tooltip
sortable sortable
width="180" width="180"
/> /> -->
<!-- 禁用时间 --> <!-- 禁用时间 -->
<el-table-column <!-- <el-table-column
prop="DeletedTime" prop="DeletedTime"
:label="$t('trials:staff:table:disableTime')" :label="$t('trials:staff:table:disableTime')"
show-overflow-tooltip show-overflow-tooltip
sortable sortable
min-width="60" min-width="60"
/> /> -->
<el-table-column <el-table-column
v-if="hasPermi(['trials:trials-panel:setting:personnel-manage:status'])" v-if="hasPermi(['trials:trials-panel:setting:personnel-manage:status'])"
@ -199,7 +246,9 @@
circle circle
:title="$t('trials:staff:action:status')" :title="$t('trials:staff:action:status')"
icon="el-icon-edit-outline" icon="el-icon-edit-outline"
:disabled="hasPermi(['role:pm']) && scope.row.UserTypeEnum*1===1" :disabled="
hasPermi(['role:pm']) && scope.row.UserTypeEnum * 1 === 1
"
@click="handleStatus(scope.row)" @click="handleStatus(scope.row)"
/> />
</template> </template>
@ -207,30 +256,60 @@
</el-table> </el-table>
<!-- 分页组件 --> <!-- 分页组件 -->
<div class="pagination" style="text-align:right"> <div class="pagination" style="text-align: right">
<pagination :total="total" :page.sync="listQuery.PageIndex" :limit.sync="listQuery.PageSize" @pagination="getList" /> <pagination
:total="total"
:page.sync="listQuery.PageIndex"
:limit.sync="listQuery.PageSize"
@pagination="getList"
/>
</div> </div>
<!-- 分配参与人员模态框 --> <!-- 分配参与人员模态框 -->
<base-model v-if="staff_model.visible" :config="staff_model"> <base-model v-if="staff_model.visible" :config="staff_model">
<template slot="dialog-body"> <template slot="dialog-body">
<StaffForm v-if="isAdd == 'Add'" @closeDialog="closeDialog" /> <StaffForm v-if="isAdd == 'Add'" @closeDialog="closeDialog" />
<StaffExternalForm v-else @closeDialog="closeDialog" @getList="getList" /> <StaffExternalForm
v-else
@closeDialog="closeDialog"
@getList="getList"
/>
</template> </template>
</base-model> </base-model>
<!-- 修改参与者人员状态 --> <!-- 修改参与者人员状态 -->
<base-model v-if="status_model.visible" :config="status_model"> <base-model v-if="status_model.visible" :config="status_model">
<template slot="dialog-body"> <template slot="dialog-body">
<el-form ref="statusForm" :model="statusForm" label-width="110px" size="small" :rules="statusRules"> <el-form
ref="statusForm"
:model="statusForm"
label-width="110px"
size="small"
:rules="statusRules"
>
<!-- Status --> <!-- Status -->
<el-form-item :label="$t('trials:staff:table:status')" prop="isDeleted"> <el-form-item
<el-radio-group v-model="statusForm.isDeleted" @change="handleIsDeletedChanged"> :label="$t('trials:staff:table:status')"
<el-radio v-for="item of $d.IsUserExitTrial" :label="item.value" :key="item.id">{{ item.label }}</el-radio> prop="isDeleted"
>
<el-radio-group
v-model="statusForm.isDeleted"
@change="handleIsDeletedChanged"
>
<el-radio
v-for="item of $d.IsUserExitTrial"
:label="item.value"
:key="item.id"
>{{ item.label }}</el-radio
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 退出日期 --> <!-- 退出日期 -->
<el-form-item v-if="statusForm.isDeleted" :label="$t('trials:staff:table:exitTime')" prop="removeTime"> <el-form-item
v-if="statusForm.isDeleted"
:label="$t('trials:staff:table:exitTime')"
prop="removeTime"
>
<el-date-picker <el-date-picker
v-model="statusForm.removeTime" v-model="statusForm.removeTime"
type="date" type="date"
@ -240,7 +319,11 @@
/> />
</el-form-item> </el-form-item>
<!-- 加入日期 --> <!-- 加入日期 -->
<el-form-item v-else :label="$t('trials:staff:table:joinTime')" prop="joinTime"> <el-form-item
v-else
:label="$t('trials:staff:table:joinTime')"
prop="joinTime"
>
<el-date-picker <el-date-picker
v-model="statusForm.joinTime" v-model="statusForm.joinTime"
type="date" type="date"
@ -250,21 +333,114 @@
/> />
</el-form-item> </el-form-item>
</el-form> </el-form>
</template> </template>
<template slot="dialog-footer"> <template slot="dialog-footer">
<el-button :disabled="btnLoading" size="small" type="primary" @click="status_model.visible = false"> <el-button
:disabled="btnLoading"
size="small"
type="primary"
@click="status_model.visible = false"
>
{{ $t('common:button:cancel') }} {{ $t('common:button:cancel') }}
</el-button> </el-button>
<el-button size="small" type="primary" :loading="btnLoading" @click="saveStatus"> <el-button
size="small"
type="primary"
:loading="btnLoading"
@click="saveStatus"
>
{{ $t('common:button:save') }} {{ $t('common:button:save') }}
</el-button> </el-button>
</template> </template>
</base-model> </base-model>
<!-- 修改参与者人员角色 -->
<base-model v-if="role_model.visible" :config="role_model">
<template slot="dialog-body">
<el-table :data="roleList" style="width: 100%" max-height="300px">
<el-table-column type="index" width="40" />
<el-table-column
prop="UserTypeShortName"
:label="
$t(
'trials:trials-panel:setting:personnel-manage:table:UserTypeShortName'
)
"
/>
<el-table-column
prop="IsDeleted"
:label="
$t(
'trials:trials-panel:setting:personnel-manage:table:IsUserRoleDisabled'
)
"
>
<template slot-scope="scope">
<span> {{ $fd('IsEnable', !scope.row.IsDeleted) }}</span>
</template>
</el-table-column>
<el-table-column
prop="IsDeleted"
:label="
$t(
'trials:trials-panel:setting:personnel-manage:table:enableTime'
)
"
min-width="120px"
>
<template slot-scope="scope">
<span v-if="!scope.row.IsDeleted">
{{ scope.row.UpdateTime }}
</span>
</template>
</el-table-column>
<el-table-column
prop="IsDeleted"
:label="
$t(
'trials:trials-panel:setting:personnel-manage:table:forbiddenTime'
)
"
min-width="120px"
>
<template slot-scope="scope">
<span v-if="scope.row.IsDeleted">
{{ scope.row.UpdateTime }}
</span>
</template>
</el-table-column>
<el-table-column :label="$t('common:action:action')" width="120px">
<template slot-scope="scope">
<el-button
size="mini"
type="text"
:disabled="scope.row.IsDeleted"
@click.stop="changeRoleStatus(scope.row, true)"
>
{{ $fd('IsEnable', false) }}
</el-button>
<el-button
size="mini"
type="text"
:disabled="!scope.row.IsDeleted"
@click.stop="changeRoleStatus(scope.row, false)"
>
{{ $fd('IsEnable', true) }}
</el-button>
</template>
</el-table-column>
</el-table>
</template>
</base-model>
</div> </div>
</template> </template>
<script> <script>
import { getMaintenanceList, getTrialUserTypeList, updateTrialUser, trialUserListExport } from '@/api/trials' import {
getMaintenanceList,
getTrialUserTypeList,
updateTrialUser,
trialUserListExport,
updateTrialUserRole,
} from '@/api/trials'
import Pagination from '@/components/Pagination' import Pagination from '@/components/Pagination'
import StaffForm from './staffForm' import StaffForm from './staffForm'
import StaffExternalForm from './staffExternalForm' import StaffExternalForm from './staffExternalForm'
@ -278,7 +454,7 @@ const getListQueryDefault = () => {
OrganizationName: '', OrganizationName: '',
IsDeleted: null, IsDeleted: null,
PageIndex: 1, PageIndex: 1,
PageSize: 20 PageSize: 20,
} }
} }
export default { export default {
@ -290,8 +466,16 @@ export default {
listQuery: getListQueryDefault(), listQuery: getListQueryDefault(),
listLoading: false, listLoading: false,
total: 0, total: 0,
staff_model: { visible: false, title: this.$t('trials:staff:dialogTitle:add'), width: '1200px' }, staff_model: {
status_model: { visible: false, title: this.$t('trials:staff:dialogTitle:status'), width: '500px' }, visible: false,
title: this.$t('trials:staff:dialogTitle:add'),
width: '1200px',
},
status_model: {
visible: false,
title: this.$t('trials:staff:dialogTitle:status'),
width: '500px',
},
userTypeOptions: [], userTypeOptions: [],
isAdd: 'Add', isAdd: 'Add',
staffStatus: null, staffStatus: null,
@ -301,14 +485,33 @@ export default {
moment, moment,
statusForm: { isDeleted: false, removeTime: '', joinTime: '' }, statusForm: { isDeleted: false, removeTime: '', joinTime: '' },
statusRules: { statusRules: {
removeTime: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: ['blur'] }], removeTime: [
joinTime: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: ['blur'] }] {
required: true,
message: this.$t('common:ruleMessage:select'),
trigger: ['blur'],
},
],
joinTime: [
{
required: true,
message: this.$t('common:ruleMessage:select'),
trigger: ['blur'],
},
],
}, },
pickerOption: { pickerOption: {
disabledDate: time => { disabledDate: (time) => {
return time.getTime() > Date.now() return time.getTime() > Date.now()
} },
} },
roleList: [],
role_model: {
visible: false,
title: this.$t('trials:staff:dialogTitle:role'),
width: '800px',
},
} }
}, },
mounted() { mounted() {
@ -317,15 +520,48 @@ export default {
this.getList() this.getList()
}, },
methods: { methods: {
//
async changeRoleStatus(row, status) {
try {
let message = this.$t('trials:staff:comfirm:changeRoleStatus').replace(
'xxx',
this.$fd('IsEnable', !status)
)
let comfirm = await this.$confirm(message)
if (!comfirm) return false
let data = {
IdList: [row.Id],
IsDeleted: status,
}
let res = await updateTrialUserRole(data)
if (res.IsSuccess) {
row.IsDeleted = status
this.$message.success(
this.$t('trials:trials-myinfo:message:updateSuccessfully')
)
this.getList()
}
} catch (err) {
console.log(err)
}
},
openRoleList(row) {
this.roleList = row.TrialUserRoleList
this.role_model.visible = true
},
// //
getList() { getList() {
this.listLoading = true this.listLoading = true
this.listQuery.TrialId = this.trialId this.listQuery.TrialId = this.trialId
getMaintenanceList(this.listQuery).then(res => { getMaintenanceList(this.listQuery)
this.listLoading = false .then((res) => {
this.list = res.Result.CurrentPageData this.listLoading = false
this.total = res.Result.TotalCount this.list = res.Result.CurrentPageData
}).catch(() => { this.listLoading = false }) this.total = res.Result.TotalCount
})
.catch(() => {
this.listLoading = false
})
}, },
// //
handleAdd(type) { handleAdd(type) {
@ -347,7 +583,7 @@ export default {
}, },
// //
saveStatus() { saveStatus() {
this.$refs.statusForm.validate(valid => { this.$refs.statusForm.validate((valid) => {
if (!valid) return if (!valid) return
this.btnLoading = true this.btnLoading = true
const param = { const param = {
@ -355,17 +591,18 @@ export default {
trialId: this.trialId, trialId: this.trialId,
isDeleted: this.statusForm.isDeleted, isDeleted: this.statusForm.isDeleted,
removeTime: this.statusForm.removeTime, removeTime: this.statusForm.removeTime,
joinTime: this.statusForm.joinTime joinTime: this.statusForm.joinTime,
} }
updateTrialUser(param) updateTrialUser(param)
.then(res => { .then((res) => {
this.btnLoading = false this.btnLoading = false
if (res.IsSuccess) { if (res.IsSuccess) {
this.status_model.visible = false this.status_model.visible = false
this.getList() this.getList()
this.$message.success(this.$t('common:message:savedSuccessfully')) this.$message.success(this.$t('common:message:savedSuccessfully'))
} }
}).catch(() => { })
.catch(() => {
this.btnLoading = false this.btnLoading = false
}) })
}) })
@ -408,39 +645,43 @@ export default {
handleExport() { handleExport() {
this.listLoading = true this.listLoading = true
this.listQuery.TrialId = this.trialId this.listQuery.TrialId = this.trialId
trialUserListExport({ ...this.listQuery }).then((data) => { trialUserListExport({ ...this.listQuery })
this.listLoading = false .then((data) => {
}).catch(() => { this.listLoading = false }) this.listLoading = false
})
.catch(() => {
this.listLoading = false
})
}, },
// //
getUserType() { getUserType() {
getTrialUserTypeList().then(res => { getTrialUserTypeList().then((res) => {
this.userTypeOptions = res.Result this.userTypeOptions = res.Result
}) })
} },
} },
} }
</script> </script>
<style lang="scss"> <style lang="scss">
.participant-list{ .participant-list {
.filter-box{ .filter-box {
display: flex; display: flex;
padding: 5px; padding: 5px;
.base-search-form{ .base-search-form {
.el-form-item{ .el-form-item {
margin-bottom: 0px; margin-bottom: 0px;
} }
} }
.mr{ .mr {
margin-right: 5px; margin-right: 5px;
width: 120px; width: 120px;
} }
} }
.el-dialog__header{ .el-dialog__header {
padding:10px; padding: 10px;
} }
.el-dialog__body{ .el-dialog__body {
padding:10px; padding: 10px;
} }
} }
</style> </style>

View File

@ -19,8 +19,12 @@
<el-button size="mini" type="primary" icon="el-icon-refresh-left" @click="handleReset"> <el-button size="mini" type="primary" icon="el-icon-refresh-left" @click="handleReset">
{{ $t('common:button:reset') }} {{ $t('common:button:reset') }}
</el-button> </el-button>
<!-- 权限配置 -->
<el-button type="primary" size="mini" style="margin-left:auto" :loading="assignLoadStatus" @click="openPermission">
{{ $t('trials:staff:button:permissionConfiguration') }}
</el-button>
<!-- 发送邮件 --> <!-- 发送邮件 -->
<el-button type="primary" size="mini" style="margin-left:auto" :disabled="selectArr.length === 0" :loading="assignLoadStatus" icon="el-icon-message" @click="sendEmail"> <el-button type="primary" size="mini" style="margin-left:10px" :disabled="selectArr.length === 0" :loading="assignLoadStatus" icon="el-icon-message" @click="sendEmail">
{{ $t('trials:staff:button:sendEmail') }} {{ $t('trials:staff:button:sendEmail') }}
</el-button> </el-button>
<!-- 添加 --> <!-- 添加 -->
@ -113,12 +117,52 @@
</div> </div>
</el-main> </el-main>
<StaffExternalAdd ref="StaffExternalAdd" :user-type-options="userTypeOptions" @getList="refeshList" /> <StaffExternalAdd ref="StaffExternalAdd" :user-type-options="userTypeOptions" @getList="refeshList" />
<base-model v-if="model_config.visible" :config="model_config">
<template slot="dialog-body">
<el-form :model="permission" :rules="permissionRole" ref="permissionForm" label-width="140px" class="demo-ruleForm">
<el-form-item :label="$t('trials:externalStaff:form:IsSPMJoinReReadingApproval')" prop="IsSPMJoinReReadingApproval">
<el-radio-group v-model="permission.IsSPMJoinReReadingApproval">
<el-radio v-for="item in $d.YesOrNo" :key="item.id" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item :label="$t('trials:externalStaff:form:IsSPMJoinReviewerSelect')" prop="IsSPMJoinReviewerSelect">
<el-radio-group v-model="permission.IsSPMJoinReviewerSelect">
<el-radio v-for="item in $d.YesOrNo" :key="item.id" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item :label="$t('trials:externalStaff:form:IsSPMJoinSiteSurvey')" prop="IsSPMJoinSiteSurvey">
<el-radio-group v-model="permission.IsSPMJoinSiteSurvey">
<el-radio v-for="item in $d.YesOrNo" :key="item.id" :label="item.value">{{ item.label }}</el-radio>
</el-radio-group>
</el-form-item>
</el-form>
</template>
<template slot="dialog-footer">
<el-button
:disabled="assignLoadStatus"
size="small"
type="primary"
@click="model_config.visible = false"
>
{{ $t('common:button:cancel') }}
</el-button>
<el-button
size="small"
type="primary"
:loading="assignLoadStatus"
@click="savePermission"
>
{{ $t('common:button:save') }}
</el-button>
</template>
</base-model>
</el-container> </el-container>
</template> </template>
<script> <script>
import { getTrialExternalUserList, addTrialUsers, getUserTypeList, sendExternalUserJoinEmail } from '@/api/trials' import { getTrialExternalUserList, addTrialUsers, getUserTypeList, sendExternalUserJoinEmail, getTrialConfigInfo, configTrialSPMInfo } from '@/api/trials'
import { deleteTrialExternalUser } from '@/api/trials/setting.js' import { deleteTrialExternalUser } from '@/api/trials/setting.js'
import StaffExternalAdd from './staffExternalAdd' import StaffExternalAdd from './staffExternalAdd'
import BaseModel from '@/components/BaseModel'
const getListQueryDefault = () => { const getListQueryDefault = () => {
return { return {
Phone: '', Phone: '',
@ -127,7 +171,7 @@ const getListQueryDefault = () => {
} }
} }
export default { export default {
components: { StaffExternalAdd }, components: { StaffExternalAdd,BaseModel },
data() { data() {
return { return {
list: [], list: [],
@ -135,10 +179,19 @@ export default {
listQuery: getListQueryDefault(), listQuery: getListQueryDefault(),
selectArr: [], selectArr: [],
assignLoadStatus: false, assignLoadStatus: false,
isAdmin: JSON.parse(zzSessionStorage.getItem('IsAdmin')), // isAdmin: JSON.parse(zzSessionStorage.getItem('IsAdmin')),
userTypeOptions: [], userTypeOptions: [],
stateList: ['WaitSent', 'HasSend', 'UserConfirmed', 'UserReject', 'OverTime'], stateList: ['WaitSent', 'HasSend', 'UserConfirmed', 'UserReject', 'OverTime'],
trialId: '' trialId: '',
model_config:{
visible: false, title: this.$t('trials:staff:dialogTitle:permissionConfiguration'), width: '500px', appendToBody: true
},
permission:{
IsSPMJoinReReadingApproval: false,
IsSPMJoinReviewerSelect: false,
IsSPMJoinSiteSurvey: false,
},
permissionRole:{}
} }
}, },
mounted() { mounted() {
@ -147,6 +200,46 @@ export default {
this.getList() this.getList()
}, },
methods: { methods: {
//
async getPermission(){
try{
let res = await getTrialConfigInfo(this.trialId);
if(res.IsSuccess){
Object.keys(this.permission).forEach(key=>{
this.permission[key] = res.Result[key]
})
}
}catch(err){
console.log(err)
}
},
//
async openPermission(){
try{
await this.getPermission();
this.model_config.visible = true;
}catch(err){
console.log(err);
}
},
//
async savePermission(){
try{
let validate =await this.$refs.permissionForm.validate();
if(!validate) return false;
this.assignLoadStatus = true;
let data = Object.assign({ Id: this.trialId },this.permission)
let res = await configTrialSPMInfo(data);
this.assignLoadStatus = false;
if(res.IsSuccess){
this.model_config.visible = false;
this.$message.success(this.$t("common:message:updatedSuccessfully"))
}
}catch(err){
this.assignLoadStatus = false;
console.log(err)
}
},
refeshList() { refeshList() {
this.getList() this.getList()
this.$emit('getList') this.$emit('getList')

View File

@ -1,19 +1,39 @@
<template> <template>
<el-container class="participant-container"> <el-container class="participant-container">
<el-header style="height:50px"> <el-header style="height: 50px">
<div class="filter-container"> <div class="filter-container">
<!-- 姓名 --> <!-- 姓名 -->
<span>{{ $t('trials:staff:table:name') }}:</span> <span>{{ $t('trials:staff:table:name') }}:</span>
<el-input v-model="listQuery.UserRealName" size="mini" class="mr" clearable /> <el-input
v-model="listQuery.UserRealName"
size="mini"
class="mr"
clearable
/>
<!-- 用户名 --> <!-- 用户名 -->
<span>{{ $t('trials:staff:table:uid') }}:</span> <span>{{ $t('trials:staff:table:uid') }}:</span>
<el-input v-model="listQuery.UserName" size="mini" class="mr" clearable /> <el-input
v-model="listQuery.UserName"
size="mini"
class="mr"
clearable
/>
<!-- 单位 --> <!-- 单位 -->
<span>{{ $t('trials:staff:table:organization') }}:</span> <span>{{ $t('trials:staff:table:organization') }}:</span>
<el-input v-model="listQuery.OrganizationName" size="mini" class="mr" clearable /> <el-input
v-model="listQuery.OrganizationName"
size="mini"
class="mr"
clearable
/>
<!-- 用户类型 --> <!-- 用户类型 -->
<span>{{ $t('trials:staff:table:userType') }}:</span> <span>{{ $t('trials:staff:table:userType') }}:</span>
<el-select v-model="listQuery.UserTypeEnum" size="mini" clearable class="mr"> <el-select
v-model="listQuery.UserTypeEnum"
size="mini"
clearable
class="mr"
>
<el-option <el-option
v-for="item of userTypeOptions" v-for="item of userTypeOptions"
:key="item.Id" :key="item.Id"
@ -24,15 +44,33 @@
</el-option> </el-option>
</el-select> </el-select>
<!-- 查询 --> <!-- 查询 -->
<el-button type="primary" size="mini" icon="el-icon-search" @click="handleSearch"> <el-button
type="primary"
size="mini"
icon="el-icon-search"
@click="handleSearch"
>
{{ $t('common:button:search') }} {{ $t('common:button:search') }}
</el-button> </el-button>
<!-- 重置 --> <!-- 重置 -->
<el-button size="mini" type="primary" icon="el-icon-refresh-left" @click="handleReset"> <el-button
size="mini"
type="primary"
icon="el-icon-refresh-left"
@click="handleReset"
>
{{ $t('common:button:reset') }} {{ $t('common:button:reset') }}
</el-button> </el-button>
<el-button type="primary" size="mini" style="margin-left:auto" :disabled="selectArr.length === 0" :loading="assignLoadStatus" icon="el-icon-plus" @click="handleAssign"> <el-button
type="primary"
size="mini"
style="margin-left: auto"
:disabled="selectArr.length === 0"
:loading="assignLoadStatus"
icon="el-icon-plus"
@click="handleAssign"
>
{{ $t('common:button:add') }} {{ $t('common:button:add') }}
</el-button> </el-button>
</div> </div>
@ -55,7 +93,7 @@
<el-table-column type="index" width="50" /> <el-table-column type="index" width="50" />
<!-- 姓名 --> <!-- 姓名 -->
<el-table-column <el-table-column
prop="UserRealName" prop="FullName"
:label="$t('trials:staff:table:name')" :label="$t('trials:staff:table:name')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
@ -95,23 +133,31 @@
/> />
<!-- 用户类型 --> <!-- 用户类型 -->
<el-table-column <el-table-column
prop="UserType" prop="UserTypeShortName"
:label="$t('trials:staff:table:userType')" :label="$t('trials:staff:table:userType')"
show-overflow-tooltip show-overflow-tooltip
sortable="custom" sortable="custom"
min-width="100" min-width="100"
/> />
</el-table> </el-table>
</div> </div>
</el-main> </el-main>
<div class="pagination" style="text-align: right;margin-top:5px;"> <div class="pagination" style="text-align: right; margin-top: 5px">
<pagination :total="total" :page.sync="listQuery.PageIndex" :limit.sync="listQuery.PageSize" @pagination="getList" /> <pagination
:total="total"
:page.sync="listQuery.PageIndex"
:limit.sync="listQuery.PageSize"
@pagination="getList"
/>
</div> </div>
</el-container> </el-container>
</template> </template>
<script> <script>
import { getTrialUserScreeningList, addTrialUsers, getUserTypeList } from '@/api/trials' import {
getTrialUserScreeningList,
addTrialUsers,
getUserTypeList,
} from '@/api/trials'
import Pagination from '@/components/Pagination' import Pagination from '@/components/Pagination'
const getListQueryDefault = () => { const getListQueryDefault = () => {
return { return {
@ -120,7 +166,7 @@ const getListQueryDefault = () => {
OrganizationName: '', OrganizationName: '',
UserTypeEnum: '', UserTypeEnum: '',
PageIndex: 1, PageIndex: 1,
PageSize: 20 PageSize: 20,
} }
} }
export default { export default {
@ -132,9 +178,9 @@ export default {
listQuery: getListQueryDefault(), listQuery: getListQueryDefault(),
selectArr: [], selectArr: [],
assignLoadStatus: false, assignLoadStatus: false,
isAdmin: JSON.parse(zzSessionStorage.getItem('IsAdmin')), // isAdmin: JSON.parse(zzSessionStorage.getItem('IsAdmin')),
userTypeOptions: [], userTypeOptions: [],
trialId: '' trialId: '',
} }
}, },
mounted() { mounted() {
@ -147,40 +193,44 @@ export default {
const loading = this.$loading({ const loading = this.$loading({
target: document.querySelector('.participant-table-list'), target: document.querySelector('.participant-table-list'),
fullscreen: false, fullscreen: false,
lock: true lock: true,
}) })
this.listQuery.TrialId = this.trialId this.listQuery.TrialId = this.trialId
getTrialUserScreeningList(this.listQuery).then(res => { getTrialUserScreeningList(this.listQuery)
loading.close() .then((res) => {
this.list = res.Result.CurrentPageData loading.close()
this.total = res.Result.TotalCount this.list = res.Result.CurrentPageData
}).catch(() => { loading.close() }) this.total = res.Result.TotalCount
})
.catch(() => {
loading.close()
})
}, },
handleAssign() { handleAssign() {
this.$confirm(this.$t('trials:staff:message:addStaff'), { this.$confirm(this.$t('trials:staff:message:addStaff'), {
type: 'warning', type: 'warning',
distinguishCancelAndClose: true distinguishCancelAndClose: true,
}) }).then(() => {
.then(() => { const loading = this.$loading({
const loading = this.$loading({ target: document.querySelector('.participant-table-list'),
target: document.querySelector('.participant-table-list'), fullscreen: false,
fullscreen: false, lock: true,
lock: true
})
this.assignLoadStatus = true
addTrialUsers(this.selectArr)
.then(res => {
this.assignLoadStatus = false
loading.close()
if (res.IsSuccess) {
this.$emit('closeDialog')
this.$message.success(this.$t('common:message:addedSuccessfully'))
}
}).catch(() => {
loading.close()
this.assignLoadStatus = false
})
}) })
this.assignLoadStatus = true
addTrialUsers(this.selectArr)
.then((res) => {
this.assignLoadStatus = false
loading.close()
if (res.IsSuccess) {
this.$emit('closeDialog')
this.$message.success(this.$t('common:message:addedSuccessfully'))
}
})
.catch(() => {
loading.close()
this.assignLoadStatus = false
})
})
}, },
handleSearch() { handleSearch() {
this.listQuery.PageIndex = 1 this.listQuery.PageIndex = 1
@ -211,34 +261,34 @@ export default {
} }
}, },
getUserType() { getUserType() {
getUserTypeList(2).then(res => { getUserTypeList(2).then((res) => {
this.userTypeOptions = res.Result this.userTypeOptions = res.Result
}) })
} },
} },
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.participant-container{ .participant-container {
height: 100%; height: 100%;
.el-header{ .el-header {
.filter-container{ .filter-container {
display: flex; display: flex;
align-items: center; align-items: center;
span{ span {
font-size:13px; font-size: 13px;
margin-right:5px; margin-right: 5px;
} }
.mr{ .mr {
margin-right: 5px; margin-right: 5px;
width: 120px; width: 120px;
} }
} }
} }
.el-main{ .el-main {
padding: 0px; padding: 0px;
} }
.el-footer{ .el-footer {
padding: 0 20px; padding: 0 20px;
} }
} }

View File

@ -471,7 +471,6 @@ export default {
...mapState('user', ['isTestUser']) ...mapState('user', ['isTestUser'])
}, },
mounted() { mounted() {
console.log('isTestUser: ',this.isTestUser)
this.getUserTobeDoneRecord() this.getUserTobeDoneRecord()
this.getNeedSignTrialDocTrialIdList() this.getNeedSignTrialDocTrialIdList()
this.getUserInfo() this.getUserInfo()
@ -491,7 +490,7 @@ export default {
}, },
methods: { methods: {
getUserInfo() { getUserInfo() {
getUser(this.userId).then(async res => { getUser().then(async res => {
this.user = res.Result this.user = res.Result
}).catch(() => { loading.close() }) }).catch(() => { loading.close() })
}, },
@ -507,7 +506,6 @@ export default {
}, },
getNeedSignTrialDocTrialIdList() { getNeedSignTrialDocTrialIdList() {
getNeedSignTrialDocTrialIdList().then(res => { getNeedSignTrialDocTrialIdList().then(res => {
console.log(res)
this.trialIdList = res.Result this.trialIdList = res.Result
this.$nextTick(() => { this.$nextTick(() => {
var list = document.querySelectorAll('div[tab-data]') var list = document.querySelectorAll('div[tab-data]')

View File

@ -17,36 +17,78 @@
<!-- 用户基本信息 --> <!-- 用户基本信息 -->
{{ $t('trials:trials-myinfo:title:basicInfo') }} {{ $t('trials:trials-myinfo:title:basicInfo') }}
</div> </div>
<el-form ref="userForm" label-position="right" :model="user" :rules="userFormRules" label-width="120px"> <el-form
ref="userForm"
label-position="right"
:model="user"
:rules="userFormRules"
label-width="120px"
>
<el-form-item v-if="user.Code" label="ID: " prop="Code"> <el-form-item v-if="user.Code" label="ID: " prop="Code">
<el-input v-model="user.Code" disabled /> <el-input v-model="user.Code" disabled />
</el-form-item> </el-form-item>
<!-- --> <!-- -->
<el-form-item :disabled="user.UserTypeEnum === 8" :label="$t('trials:trials-myinfo:form:surname')" prop="LastName"> <el-form-item
<el-input v-model="user.LastName" :placeholder="$t('trials:trials-myinfo:form:surname')"/> :disabled="user.UserTypeEnum === 8"
:label="$t('trials:trials-myinfo:form:surname')"
prop="LastName"
>
<el-input
v-model="user.LastName"
:placeholder="$t('trials:trials-myinfo:form:surname')"
/>
</el-form-item> </el-form-item>
<!-- --> <!-- -->
<el-form-item :disabled="user.UserTypeEnum === 8" :label="$t('trials:trials-myinfo:form:givenname')" prop="FirstName"> <el-form-item
<el-input v-model="user.FirstName" :placeholder="$t('trials:trials-myinfo:form:givenname')"/> :disabled="user.UserTypeEnum === 8"
:label="$t('trials:trials-myinfo:form:givenname')"
prop="FirstName"
>
<el-input
v-model="user.FirstName"
:placeholder="$t('trials:trials-myinfo:form:givenname')"
/>
</el-form-item> </el-form-item>
<!-- 性别 --> <!-- 性别 -->
<el-form-item :label="$t('trials:trials-myinfo:form:gender')" prop="Sex" style="margin-right:40px;"> <el-form-item
:label="$t('trials:trials-myinfo:form:gender')"
prop="Sex"
style="margin-right: 40px"
>
<el-radio-group v-model="user.Sex"> <el-radio-group v-model="user.Sex">
<el-radio :label="1">Male</el-radio> <el-radio :label="1">Male</el-radio>
<el-radio :label="0">Female</el-radio> <el-radio :label="0">Female</el-radio>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
<!-- 单位 --> <!-- 单位 -->
<el-form-item :label="$t('trials:trials-myinfo:form:organization')" prop="OrganizationName"> <el-form-item
<el-input v-model="user.OrganizationName" :placeholder="$t('trials:trials-myinfo:form:organization')"/> :label="$t('trials:trials-myinfo:form:organization')"
prop="OrganizationName"
>
<el-input
v-model="user.OrganizationName"
:placeholder="$t('trials:trials-myinfo:form:organization')"
/>
</el-form-item> </el-form-item>
<!-- 部门 --> <!-- 部门 -->
<el-form-item :label="$t('trials:trials-myinfo:form:department')" prop="DepartmentName"> <el-form-item
<el-input v-model="user.DepartmentName" :placeholder="$t('trials:trials-myinfo:form:organization')"/> :label="$t('trials:trials-myinfo:form:department')"
prop="DepartmentName"
>
<el-input
v-model="user.DepartmentName"
:placeholder="$t('trials:trials-myinfo:form:organization')"
/>
</el-form-item> </el-form-item>
<!-- 职位 --> <!-- 职位 -->
<el-form-item :label="$t('trials:trials-myinfo:form:position')" prop="PositionName"> <el-form-item
<el-input v-model="user.PositionName" :placeholder="$t('trials:trials-myinfo:form:position')"/> :label="$t('trials:trials-myinfo:form:position')"
prop="PositionName"
>
<el-input
v-model="user.PositionName"
:placeholder="$t('trials:trials-myinfo:form:position')"
/>
</el-form-item> </el-form-item>
</el-form> </el-form>
<!-- 保存 --> <!-- 保存 -->
@ -68,39 +110,97 @@
</div> </div>
<el-form label-position="right" label-width="180px"> <el-form label-position="right" label-width="180px">
<!-- 用户名 --> <!-- 用户名 -->
<el-form-item :label="$t('trials:trials-myinfo:form:userName')" style="margin-bottom: 5px;" prop="UserName"> <el-form-item
:label="$t('trials:trials-myinfo:form:userName')"
style="margin-bottom: 5px"
prop="UserName"
>
<span>{{ user.UserName }}</span> <span>{{ user.UserName }}</span>
</el-form-item> </el-form-item>
<el-form-item label="" style="position: relative" prop="UserName"> <el-form-item label="" style="position: relative" prop="UserName">
<el-input v-model="userForm.UserName" :placeholder="$t('trials:trials-myinfo:form:userName')"/> <el-input
v-model="userForm.UserName"
:placeholder="$t('trials:trials-myinfo:form:userName')"
/>
<!-- 修改 --> <!-- 修改 -->
<el-button :disabled="!userForm.UserName" class="saveBtn" type="primary" size="small" @click="setNewUserName"> <el-button
:disabled="!userForm.UserName"
class="saveBtn"
type="primary"
size="small"
@click="setNewUserName"
>
{{ $t('trials:trials-myinfo:button:update') }} {{ $t('trials:trials-myinfo:button:update') }}
</el-button> </el-button>
</el-form-item> </el-form-item>
<!-- 电话 --> <!-- 电话 -->
<el-form-item :label="$t('trials:trials-myinfo:form:phone')" style="margin-bottom: 5px;" prop="UserName"> <el-form-item
:label="$t('trials:trials-myinfo:form:phone')"
style="margin-bottom: 5px"
prop="UserName"
>
<span>{{ user.Phone }}</span> <span>{{ user.Phone }}</span>
</el-form-item> </el-form-item>
<el-form-item label="" style="position: relative" prop="UserName"> <el-form-item label="" style="position: relative" prop="UserName">
<el-input v-model="userForm.Phone" :placeholder="$t('trials:trials-myinfo:form:phone')"/> <el-input
v-model="userForm.Phone"
:placeholder="$t('trials:trials-myinfo:form:phone')"
/>
<!-- 修改 --> <!-- 修改 -->
<el-button :disabled="!userForm.Phone" class="saveBtn" type="primary" size="small" @click="setNewPhone"> <el-button
:disabled="!userForm.Phone"
class="saveBtn"
type="primary"
size="small"
@click="setNewPhone"
>
{{ $t('trials:trials-myinfo:button:update') }} {{ $t('trials:trials-myinfo:button:update') }}
</el-button> </el-button>
</el-form-item> </el-form-item>
<!-- 邮箱 --> <!-- 邮箱 -->
<el-form-item :label="$t('trials:trials-myinfo:form:email')" style="margin-bottom: 5px;" prop="UserName"> <el-form-item
:label="$t('trials:trials-myinfo:form:email')"
style="margin-bottom: 5px"
prop="UserName"
>
<span>{{ user.EMail }}</span> <span>{{ user.EMail }}</span>
</el-form-item> </el-form-item>
<el-form-item label="" style="margin-bottom: 10px;position: relative" prop="EMail"> <el-form-item
<el-input v-model="userForm.EMail" @input="handleEmailChange" :placeholder="$t('trials:trials-myinfo:form:email')"/> label=""
<el-button class="sendCode" :disabled="sendDisabled" type="primary" size="mini" @click="sendVerificationCode">{{ sendTitle }}</el-button> style="margin-bottom: 10px; position: relative"
prop="EMail"
>
<el-input
v-model="userForm.EMail"
@input="handleEmailChange"
:placeholder="$t('trials:trials-myinfo:form:email')"
/>
<el-button
class="sendCode"
:disabled="sendDisabled"
type="primary"
size="mini"
@click="sendVerificationCode"
>{{ sendTitle }}</el-button
>
</el-form-item> </el-form-item>
<el-form-item label="" style="position: relative" prop="VerificationCode"> <el-form-item
<el-input v-model="userForm.VerificationCode" :placeholder="$t('trials:researchForm:form:verifyCode')"/> label=""
style="position: relative"
prop="VerificationCode"
>
<el-input
v-model="userForm.VerificationCode"
:placeholder="$t('trials:researchForm:form:verifyCode')"
/>
<!-- 修改 --> <!-- 修改 -->
<el-button :disabled="!userForm.EMail || !userForm.VerificationCode" class="saveBtn" type="primary" size="small" @click="setNewEmail"> <el-button
:disabled="!userForm.EMail || !userForm.VerificationCode"
class="saveBtn"
type="primary"
size="small"
@click="setNewEmail"
>
{{ $t('trials:trials-myinfo:button:update') }} {{ $t('trials:trials-myinfo:button:update') }}
</el-button> </el-button>
</el-form-item> </el-form-item>
@ -111,18 +211,52 @@
<!-- 修改密码 --> <!-- 修改密码 -->
{{ $t('trials:trials-myinfo:title:updatePaasord') }} {{ $t('trials:trials-myinfo:title:updatePaasord') }}
</div> </div>
<el-form ref="passwordForm" label-position="right" :model="password" :rules="passwordFormRules" label-width="180px"> <el-form
ref="passwordForm"
label-position="right"
:model="password"
:rules="passwordFormRules"
label-width="180px"
>
<!-- 旧密码 --> <!-- 旧密码 -->
<el-form-item :label="$t('recompose:form:oldPassword')" prop="OldPassWord"> <el-form-item
<el-input v-model="password.OldPassWord" type="password" show-password auto-complete="new-password" :placeholder="$t('recompose:form:oldPassword')"/> :label="$t('recompose:form:oldPassword')"
prop="OldPassWord"
>
<el-input
v-model="password.OldPassWord"
type="password"
show-password
auto-complete="new-password"
:placeholder="$t('recompose:form:oldPassword')"
/>
</el-form-item> </el-form-item>
<!-- 新密码 --> <!-- 新密码 -->
<el-form-item class="my_new_pwd" :label="$t('recompose:form:newPassword')" prop="NewPassWord"> <el-form-item
<el-input v-model="password.NewPassWord" type="password" show-password auto-complete="new-password" :placeholder="$t('recompose:form:newPassword')"/> class="my_new_pwd"
:label="$t('recompose:form:newPassword')"
prop="NewPassWord"
>
<el-input
v-model="password.NewPassWord"
type="password"
show-password
auto-complete="new-password"
:placeholder="$t('recompose:form:newPassword')"
/>
</el-form-item> </el-form-item>
<!-- 确认密码 --> <!-- 确认密码 -->
<el-form-item :label="$t('recompose:form:confirmPassword')" prop="ConfirmPassWord"> <el-form-item
<el-input v-model="password.ConfirmPassWord" type="password" show-password auto-complete="new-password" :placeholder="$t('recompose:form:confirmPassword')"/> :label="$t('recompose:form:confirmPassword')"
prop="ConfirmPassWord"
>
<el-input
v-model="password.ConfirmPassWord"
type="password"
show-password
auto-complete="new-password"
:placeholder="$t('recompose:form:confirmPassword')"
/>
</el-form-item> </el-form-item>
</el-form> </el-form>
<el-button <el-button
@ -139,13 +273,23 @@
</template> </template>
<script> <script>
import { getUserTypeList, getUser, updateUser, modifyPassword } from '@/api/admin.js' import {
import { sendVerificationCode, setNewEmail, setNewPhone, setNewUserName } from '@/api/system/user.js' getUserTypeList,
getUser,
updateUser,
modifyPassword,
} from '@/api/admin.js'
import {
sendVerificationCode,
setNewEmail,
setNewPhone,
setNewUserName,
} from '@/api/system/user.js'
import md5 from 'js-md5' import md5 from 'js-md5'
var timer = '' var timer = ''
var countdown = 60 var countdown = 60
import store from '@/store' import store from '@/store'
import {mapGetters, mapMutations} from 'vuex' import { mapGetters, mapMutations } from 'vuex'
export default { export default {
name: 'TrialsMyinfo', name: 'TrialsMyinfo',
@ -158,38 +302,102 @@ export default {
sendDisabled: true, sendDisabled: true,
sendTitle: this.$t('trials:trials-myinfo:button:getVCode'), sendTitle: this.$t('trials:trials-myinfo:button:getVCode'),
userFormRules: { userFormRules: {
UserName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }], UserName: [
UserTypeId: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: ['blur', 'change'] }], {
IsZhiZhun: [{ required: true, message: this.$t('common:ruleMessage:select'), trigger: ['blur', 'change'] }], required: true,
OrganizationName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }], message: this.$t('common:ruleMessage:specify'),
LastName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, { max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` }], trigger: 'blur',
FirstName: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, { max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` }], },
Sex: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }], ],
Status: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }] UserTypeId: [
{
required: true,
message: this.$t('common:ruleMessage:select'),
trigger: ['blur', 'change'],
},
],
IsZhiZhun: [
{
required: true,
message: this.$t('common:ruleMessage:select'),
trigger: ['blur', 'change'],
},
],
OrganizationName: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
],
LastName: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
{ max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` },
],
FirstName: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
{ max: 50, message: `${this.$t('common:ruleMessage:maxLength')} 50` },
],
Sex: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
],
Status: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
],
}, },
passwordFormRules: { passwordFormRules: {
OldPassWord: [{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }], OldPassWord: [
{
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
],
NewPassWord: [ NewPassWord: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, {
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
{ {
required: true, required: true,
trigger: 'blur', trigger: 'blur',
validator: this.$validatePassword validator: this.$validatePassword,
}, },
], ],
ConfirmPassWord: [ ConfirmPassWord: [
{ required: true, message: this.$t('common:ruleMessage:specify'), trigger: 'blur' }, {
required: true,
message: this.$t('common:ruleMessage:specify'),
trigger: 'blur',
},
{ {
required: true, required: true,
trigger: 'blur', trigger: 'blur',
validator: this.$validatePassword validator: this.$validatePassword,
}, },
] ],
} },
} }
}, },
computed: { computed: {
...mapGetters(['userId', 'name']) ...mapGetters(['userId', 'name']),
}, },
mounted() { mounted() {
this.getUserInfo() this.getUserInfo()
@ -198,7 +406,7 @@ export default {
methods: { methods: {
...mapMutations({ setLanguage: 'lang/setLanguage' }), ...mapMutations({ setLanguage: 'lang/setLanguage' }),
handleSave() { handleSave() {
this.$refs.userForm.validate(valid => { this.$refs.userForm.validate((valid) => {
console.log(valid) console.log(valid)
if (valid) { if (valid) {
this.isDisabled = true this.isDisabled = true
@ -212,17 +420,24 @@ export default {
// this.user.OrganizationName = 'ZhiZhun' // this.user.OrganizationName = 'ZhiZhun'
// } // }
if (this.user.Id) { if (this.user.Id) {
updateUser(this.user).then(res => { updateUser(this.user)
this.isDisabled = false .then((res) => {
this.$message.success(this.$t('trials:trials-myinfo:message:updateSuccessfully')) this.isDisabled = false
this.getUserInfo() this.$message.success(
}).catch(() => { this.isDisabled = false }) this.$t('trials:trials-myinfo:message:updateSuccessfully')
)
this.getUserInfo()
})
.catch(() => {
this.isDisabled = false
})
} }
} }
}) })
}, },
handleEmailChange() { handleEmailChange() {
var reg = /^[A-Za-z0-9]+([_\.][A-Za-z0-9]+)*@([A-Za-z0-9\-]+\.)+[A-Za-z]{2,6}$/ var reg =
/^[A-Za-z0-9]+([_\.][A-Za-z0-9]+)*@([A-Za-z0-9\-]+\.)+[A-Za-z]{2,6}$/
if (this.userForm.EMail && reg.test(this.userForm.EMail)) { if (this.userForm.EMail && reg.test(this.userForm.EMail)) {
this.sendDisabled = false this.sendDisabled = false
} else { } else {
@ -233,11 +448,13 @@ export default {
sendVerificationCode(this.userForm.EMail).then(() => { sendVerificationCode(this.userForm.EMail).then(() => {
this.settime(this) this.settime(this)
// //
this.$message.success(this.$t('trials:trials-myinfo:message:sendSuccessfully')) this.$message.success(
this.$t('trials:trials-myinfo:message:sendSuccessfully')
)
}) })
}, },
save() { save() {
this.$refs.passwordForm.validate(valid => { this.$refs.passwordForm.validate((valid) => {
if (valid) { if (valid) {
if (this.password.NewPassWord !== this.password.ConfirmPassWord) { if (this.password.NewPassWord !== this.password.ConfirmPassWord) {
this.$alert(this.$t('passwordReset:formRule:passwordsDiffer')) this.$alert(this.$t('passwordReset:formRule:passwordsDiffer'))
@ -246,12 +463,14 @@ export default {
const param = { const param = {
UserId: this.userId, UserId: this.userId,
NewPassWord: md5(this.password.NewPassWord), NewPassWord: md5(this.password.NewPassWord),
OldPassWord: md5(this.password.OldPassWord) OldPassWord: md5(this.password.OldPassWord),
} }
modifyPassword(param).then(res => { modifyPassword(param).then((res) => {
if (res.IsSuccess) { if (res.IsSuccess) {
// , // ,
this.$message.success(this.$t('trials:trials-myinfo:message:modifyPWSuccessfully')) this.$message.success(
this.$t('trials:trials-myinfo:message:modifyPWSuccessfully')
)
setTimeout(() => { setTimeout(() => {
this.logout() this.logout()
}, 1000) }, 1000)
@ -261,26 +480,36 @@ export default {
}) })
}, },
setNewEmail() { setNewEmail() {
setNewEmail(this.userForm.EMail, this.userForm.VerificationCode).then(() => { setNewEmail(this.userForm.EMail, this.userForm.VerificationCode).then(
this.userForm.EMail = '' () => {
this.userForm.VerificationCode = '' this.userForm.EMail = ''
this.$message.success(this.$t('trials:trials-myinfo:message:updateSuccessfully')) this.userForm.VerificationCode = ''
this.getUserInfo() this.$message.success(
}) this.$t('trials:trials-myinfo:message:updateSuccessfully')
)
this.getUserInfo()
}
)
}, },
setNewUserName() { setNewUserName() {
setNewUserName(this.userForm.UserName).then(() => { setNewUserName(this.userForm.UserName).then(() => {
this.$store.dispatch('user/changeUserName', this.userForm.UserName).then((res) => { this.$store
this.userForm.UserName = '' .dispatch('user/changeUserName', this.userForm.UserName)
this.$message.success(this.$t('trials:trials-myinfo:message:updateSuccessfully')) .then((res) => {
this.getUserInfo() this.userForm.UserName = ''
}) this.$message.success(
this.$t('trials:trials-myinfo:message:updateSuccessfully')
)
this.getUserInfo()
})
}) })
}, },
setNewPhone() { setNewPhone() {
setNewPhone(this.userForm.Phone).then(() => { setNewPhone(this.userForm.Phone).then(() => {
this.userForm.Phone = '' this.userForm.Phone = ''
this.$message.success(this.$t('trials:trials-myinfo:message:updateSuccessfully')) this.$message.success(
this.$t('trials:trials-myinfo:message:updateSuccessfully')
)
this.getUserInfo() this.getUserInfo()
}) })
}, },
@ -290,36 +519,42 @@ export default {
lock: true, lock: true,
text: 'Loading', text: 'Loading',
spinner: 'el-icon-loading', spinner: 'el-icon-loading',
background: 'rgba(0, 0, 0, 0.07)' background: 'rgba(0, 0, 0, 0.07)',
}) })
getUser(this.userId).then(async res => { getUser()
this.user = res.Result .then(async (res) => {
/* eslint-disable */ this.user = res.Result
zzSessionStorage.setItem('realName', this.user.RealName) /* eslint-disable */
await store.dispatch('user/updateInfo') zzSessionStorage.setItem('Name', this.user.FullName)
loading.close() await store.dispatch('user/updateInfo')
}).catch(() => { loading.close() }) loading.close()
})
.catch(() => {
loading.close()
})
}, },
settime(obj) { settime(obj) {
if (countdown === 0) { if (countdown === 0) {
obj.sendDisabled = false obj.sendDisabled = false
obj.sendTitle = this.$t('trials:trials-myinfo:button:getVCode')// '' obj.sendTitle = this.$t('trials:trials-myinfo:button:getVCode') // ''
countdown = 60 countdown = 60
clearTimeout(timer) clearTimeout(timer)
return return
} else { } else {
obj.sendDisabled = true obj.sendDisabled = true
obj.sendTitle = `${this.$t('trials:trials-myinfo:button:wait')}(${countdown}s)` obj.sendTitle = `${this.$t(
'trials:trials-myinfo:button:wait'
)}(${countdown}s)`
countdown-- countdown--
// eslint-disable-next-line no-self-assign // eslint-disable-next-line no-self-assign
countdown = countdown countdown = countdown
timer = setTimeout(function() { timer = setTimeout(function () {
obj.settime(obj) obj.settime(obj)
}, 1000) }, 1000)
} }
}, },
getUserTypeList() { getUserTypeList() {
getUserTypeList().then(res => { getUserTypeList().then((res) => {
if (res.IsSuccess) { if (res.IsSuccess) {
this.userTypeOptions = res.Result this.userTypeOptions = res.Result
} }
@ -337,56 +572,93 @@ export default {
this.$i18n.locale = 'zh' this.$i18n.locale = 'zh'
this.setLanguage('zh') this.setLanguage('zh')
this.$updateDictionary() this.$updateDictionary()
} },
} },
} }
</script> </script>
<style lang="scss" scoped> <style lang="scss" scoped>
.trial-myinfo{ .trial-myinfo {
background: #f3f3f3; background: #f3f3f3;
flex: 1;overflow: auto;display: flex;flex-direction: row;justify-content: space-around; flex: 1;
.trial-myinfo-head{ overflow: auto;
position: absolute;top: 40px;left: -10%;font-size: 14px; display: flex;
flex-direction: row;
justify-content: space-around;
.trial-myinfo-head {
position: absolute;
top: 40px;
left: -10%;
font-size: 14px;
} }
.trial-myinfo-left{ .trial-myinfo-left {
overflow: auto; overflow: auto;
background: #fff;width: calc(50% - 9px);margin: 6px 0; background: #fff;
width: calc(50% - 9px);
margin: 6px 0;
padding-bottom: 50px; padding-bottom: 50px;
.trial-myinfo-left-top{ .trial-myinfo-left-top {
width: 70%;padding-top: 100px;position: relative;margin: 0 auto;margin-bottom: 10px; width: 70%;
.trial-myinfo-body{ padding-top: 100px;
width:160px;height:160px;border-radius: 50%;background: #428bca;display: flex;justify-content: center;align-items: center; position: relative;
div{ margin: 0 auto;
color:#fff;font-size: 30px; margin-bottom: 10px;
.trial-myinfo-body {
width: 160px;
height: 160px;
border-radius: 50%;
background: #428bca;
display: flex;
justify-content: center;
align-items: center;
div {
color: #fff;
font-size: 30px;
} }
} }
} }
} }
.saveBtn{ .saveBtn {
position: absolute;right: -10px;top:2px;transform: translateX(100%) position: absolute;
right: -10px;
top: 2px;
transform: translateX(100%);
} }
.trial-info-btn{ .trial-info-btn {
position: absolute;bottom: -60px;left: calc(100% + 10px);min-width: 97px; position: absolute;
bottom: -60px;
left: calc(100% + 10px);
min-width: 97px;
} }
.trial-myinfo-left-bottom{ .trial-myinfo-left-bottom {
width: 70%;padding-top: 100px;position: relative;margin: 0 auto; width: 70%;
padding-top: 100px;
position: relative;
margin: 0 auto;
} }
.trial-myinfo-right{ .trial-myinfo-right {
overflow: auto; overflow: auto;
background: #fff;width: calc(50% - 9px);margin: 6px 0; background: #fff;
width: calc(50% - 9px);
margin: 6px 0;
padding-bottom: 50px; padding-bottom: 50px;
.sendCode { .sendCode {
position: absolute;right: -10px;top: 50%;transform: translate(100%, -50%); position: absolute;
right: -10px;
top: 50%;
transform: translate(100%, -50%);
} }
.trial-myinfo-right-box{ .trial-myinfo-right-box {
width: 70%;padding-top: 100px;position: relative;margin: 0 auto; width: 70%;
padding-top: 100px;
position: relative;
margin: 0 auto;
} }
} }
} }
</style> </style>
<style scoped> <style scoped>
/deep/ .is-error.my_new_pwd{ ::v-deep .is-error.my_new_pwd {
margin-bottom: 40px; margin-bottom: 40px;
} }
</style> </style>