|
@@ -1,7 +1,7 @@
|
|
|
<!--
|
|
|
* @Author: Badguy
|
|
|
* @Date: 2022-02-15 11:37:42
|
|
|
- * @LastEditTime: 2022-02-15 17:38:03
|
|
|
+ * @LastEditTime: 2022-02-17 17:59:58
|
|
|
* @LastEditors: your name
|
|
|
* @Description: 编辑账号
|
|
|
* have a nice day!
|
|
@@ -11,7 +11,7 @@
|
|
|
<div class="account-edit">
|
|
|
<div class="account-edit-header">
|
|
|
<div class="title">
|
|
|
- <div class="title-left">编辑账号</div>
|
|
|
+ <div class="title-left">{{ pageTitle }}</div>
|
|
|
<!-- <div class="account-status">
|
|
|
是否启用
|
|
|
<el-radio
|
|
@@ -30,7 +30,7 @@
|
|
|
<button
|
|
|
type="submmit"
|
|
|
class="btn-save"
|
|
|
- @click="saveEdit"
|
|
|
+ @click="handleClickSave"
|
|
|
>保存</button>
|
|
|
</div>
|
|
|
</div>
|
|
@@ -67,11 +67,11 @@
|
|
|
</el-form-item>
|
|
|
</el-col>
|
|
|
<el-col :span="2">
|
|
|
- <el-button
|
|
|
+ <button
|
|
|
+ type="reset"
|
|
|
class="btn-reset-pwd"
|
|
|
- size="small"
|
|
|
@click="resetPwd"
|
|
|
- >重置密码</el-button>
|
|
|
+ >重置密码</button>
|
|
|
</el-col>
|
|
|
<el-col :span="8">
|
|
|
<el-form-item
|
|
@@ -81,7 +81,7 @@
|
|
|
<el-input
|
|
|
v-model="accountForm.desc"
|
|
|
maxlength="128"
|
|
|
- placeholder="描述内容描述内容描述内容描述内容描述内容描述内容"
|
|
|
+ placeholder="描述内容···"
|
|
|
size="small"
|
|
|
/>
|
|
|
</el-form-item>
|
|
@@ -104,7 +104,7 @@
|
|
|
query-type="all"
|
|
|
:query-id="permissionTreeQueryId"
|
|
|
:checked-keys="permissionTreeChckedKeys"
|
|
|
- @get-tree-data="getPermissionTreeChecked"
|
|
|
+ @getTreeData="getPermissionTreeChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -112,7 +112,7 @@
|
|
|
<div class="content-card content-card-large">
|
|
|
<RulesOfCompetency
|
|
|
title="权限规则"
|
|
|
- @get-data="getRulesOfCompetency"
|
|
|
+ @getData="getRulesOfCompetency"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -120,7 +120,7 @@
|
|
|
<div class="content-card content-card-large">
|
|
|
<LoginPolicy
|
|
|
:checked-list="loginPolicyCheckedList"
|
|
|
- @get-checked-list="getLoginPolicyChecked"
|
|
|
+ @getCheckedList="getLoginPolicyChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -137,7 +137,7 @@
|
|
|
nodekey="GroupId"
|
|
|
:default-props="accountGroupTreeProps"
|
|
|
:checked-id-list="accountGroupTreeCheckedList"
|
|
|
- @get-tree-data="getAccountGroupChecked"
|
|
|
+ @getTreeData="getAccountGroupChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -145,12 +145,12 @@
|
|
|
<div class="content-card content-card-large">
|
|
|
<RoleList
|
|
|
title="角色列表"
|
|
|
- role-type="roleByUpId"
|
|
|
+ :role-type="roleType"
|
|
|
:group-ids="accountGroupTreeCheckedList"
|
|
|
:check-box-list="roleListCheckedList"
|
|
|
:number="8"
|
|
|
- @check-change="getRoleListChecked"
|
|
|
- @check-click="selectRole"
|
|
|
+ @checkChange="getRoleListChecked"
|
|
|
+ @checkClick="selectRole"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -167,7 +167,7 @@
|
|
|
<div class="content-card content-card-small">
|
|
|
<LoginPolicy
|
|
|
:checked-list="loginPolicyCheckedList"
|
|
|
- @get-checked-list="getLoginPolicyChecked"
|
|
|
+ @getCheckedList="getLoginPolicyChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -184,7 +184,7 @@
|
|
|
nodekey="GroupId"
|
|
|
:default-props="accountGroupTreeProps"
|
|
|
:checked-id-list="accountGroupTreeCheckedList"
|
|
|
- @get-tree-data="getAccountGroupChecked"
|
|
|
+ @getTreeData="getAccountGroupChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -195,7 +195,7 @@
|
|
|
query-type="group"
|
|
|
:query-id="permissionTreeQueryId"
|
|
|
:checked-keys="permissionTreeChckedKeys"
|
|
|
- @get-tree-data="getPermissionTreeChecked"
|
|
|
+ @getTreeData="getPermissionTreeChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -203,14 +203,14 @@
|
|
|
<div class="content-card content-card-medium">
|
|
|
<RulesOfCompetency
|
|
|
title="权限规则"
|
|
|
- @get-data="getRulesOfCompetency"
|
|
|
+ @getData="getRulesOfCompetency"
|
|
|
/>
|
|
|
</div>
|
|
|
|
|
|
<div class="content-card content-card-small">
|
|
|
<LoginPolicy
|
|
|
:checked-list="loginPolicyCheckedList"
|
|
|
- @get-checked-list="getLoginPolicyChecked"
|
|
|
+ @getCheckedList="getLoginPolicyChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -224,11 +224,11 @@
|
|
|
<div class="content-card content-card-large">
|
|
|
<RoleList
|
|
|
title="角色列表"
|
|
|
- role-type="onlyRole"
|
|
|
+ :role-type="roleType"
|
|
|
:check-box-list="roleListCheckedList"
|
|
|
:number="8"
|
|
|
@check-change="getRoleListChecked"
|
|
|
- @check-click="selectRole"
|
|
|
+ @checkClick="selectRole"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
@@ -247,13 +247,13 @@
|
|
|
<div class="content-card content-card-large">
|
|
|
<LoginPolicy
|
|
|
:checked-list="loginPolicyCheckedList"
|
|
|
- @get-checked-list="getLoginPolicyChecked"
|
|
|
+ @getCheckedList="getLoginPolicyChecked"
|
|
|
/>
|
|
|
</div>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
|
</div>
|
|
|
- <Dialog :flag="dialogVisible">
|
|
|
+ <!-- <Dialog :flag="dialogVisible">
|
|
|
<div class="closeDialog">
|
|
|
<div class="title">删除账号</div>
|
|
|
<div class="content">是否确定要删除该账号?</div>
|
|
@@ -266,7 +266,7 @@
|
|
|
<el-button size="medium">取消</el-button>
|
|
|
</div>
|
|
|
</div>
|
|
|
- </Dialog>
|
|
|
+ </Dialog> -->
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
@@ -277,11 +277,12 @@ import RulesOfCompetency from '@/components/rulesofcompetency/index.vue'
|
|
|
import LoginPolicy from '@/components/loginpolicy/index.vue'
|
|
|
import RoleList from '@/components/rolelist/index.vue'
|
|
|
import PermissionList from '@/components/permissionlist/index.vue'
|
|
|
-import Dialog from '@/layout/components/Dialog'
|
|
|
+// import Dialog from '@/layout/components/Dialog'
|
|
|
|
|
|
import { RoleAuths } from '@/api/apiAuthority'
|
|
|
-import { getAccountDetails, editAccount } from '@/api/Account.js'
|
|
|
+import { getAccountDetails, editAccount, addAccount } from '@/api/Account.js'
|
|
|
import { generatePassword } from '@/utils/pwdRules'
|
|
|
+import { mapGetters } from 'vuex'
|
|
|
|
|
|
export default {
|
|
|
components: {
|
|
@@ -290,21 +291,19 @@ export default {
|
|
|
RulesOfCompetency,
|
|
|
LoginPolicy,
|
|
|
RoleList,
|
|
|
- PermissionList,
|
|
|
- Dialog
|
|
|
+ PermissionList
|
|
|
+ // Dialog
|
|
|
},
|
|
|
data() {
|
|
|
return {
|
|
|
- appId: 0,
|
|
|
+ doesAccountExist: this.$route.meta.doesAccountExist, // 控制账号新增/编辑
|
|
|
userId: this.$route.query.userId,
|
|
|
- groupId: this.$route.query.groupId,
|
|
|
openRole: 0,
|
|
|
openGroup: 0,
|
|
|
pwdStruc: '',
|
|
|
pwdLengthBegin: 0,
|
|
|
pwdLengthEnd: 0,
|
|
|
- pwd: '',
|
|
|
- permissionTreeQueryId: '1',
|
|
|
+ permissionTreeQueryId: '',
|
|
|
permissionTreeChckedKeys: [], // 权限树初始勾选项
|
|
|
permissionTreeChckedTemp: [], // 权限树当前勾选项
|
|
|
rulesOfCompetency: null, // 当前编辑的权限规则
|
|
@@ -314,9 +313,10 @@ export default {
|
|
|
accountGroupTreeCheckedTemp: [], // 账号组树当前勾选项
|
|
|
roleListCheckedList: [], // 角色列表初始勾选项
|
|
|
roleListCheckedTemp: [], // 角色列表当前勾选项
|
|
|
+ roleType: '',
|
|
|
permissionList: [],
|
|
|
currentSelectedRoleId: 0,
|
|
|
- dialogVisible: false,
|
|
|
+ // dialogVisible: false,
|
|
|
pwdRules: {
|
|
|
UserName: [
|
|
|
{ required: true, message: '请输入账号名称', trigger: 'blur' },
|
|
@@ -340,12 +340,19 @@ export default {
|
|
|
}
|
|
|
}
|
|
|
},
|
|
|
+ computed: {
|
|
|
+ ...mapGetters(['systemSet', 'authArrs']),
|
|
|
+ pageTitle() {
|
|
|
+ return this.doesAccountExist ? '编辑账号' : '新增账号'
|
|
|
+ }
|
|
|
+ },
|
|
|
created() {
|
|
|
+ // 获取系统配置
|
|
|
let obj
|
|
|
- if (typeof this.$store.state.app.systemSet === 'string') {
|
|
|
- obj = JSON.parse(this.$store.state.app.systemSet)
|
|
|
+ if (typeof this.systemSet === 'string') {
|
|
|
+ obj = JSON.parse(this.systemSet)
|
|
|
} else {
|
|
|
- obj = this.$store.state.app.systemSet
|
|
|
+ obj = this.systemSet
|
|
|
}
|
|
|
// console.log(obj)
|
|
|
const { OpenRole, OpenGroup, PwdStruc, PwdLengthBegin, PwdLengthEnd } = obj
|
|
@@ -354,11 +361,13 @@ export default {
|
|
|
this.pwdStruc = PwdStruc
|
|
|
this.pwdLengthBegin = PwdLengthBegin
|
|
|
this.pwdLengthEnd = PwdLengthEnd
|
|
|
- this.getAccountInfo()
|
|
|
- const { GroupId } = this.$route.query
|
|
|
- this.appId = GroupId
|
|
|
- if (OpenRole) {
|
|
|
- this.title = '角色'
|
|
|
+ },
|
|
|
+ mounted() {
|
|
|
+ this.openRole && (this.roleType = this.openGroup ? 'roleByUpId' : 'onlyRole')
|
|
|
+ if (this.doesAccountExist) {
|
|
|
+ this.getAccountInfo()
|
|
|
+ } else {
|
|
|
+ this.resetPwd()
|
|
|
}
|
|
|
},
|
|
|
methods: {
|
|
@@ -369,19 +378,34 @@ export default {
|
|
|
UserId: this.userId
|
|
|
})
|
|
|
if (res.code === 0) {
|
|
|
- // console.log(res.returnData)
|
|
|
+ console.log(res.returnData)
|
|
|
const { UserDesc, UserName, GroupList, TacList, AuthList, RoleList } = res.returnData
|
|
|
this.accountForm.name = UserName
|
|
|
this.accountForm.desc = UserDesc
|
|
|
this.accountGroupTreeCheckedList = GroupList
|
|
|
this.loginPolicyCheckedList = TacList
|
|
|
- // console.log(this.checkedIdList)
|
|
|
this.$store.state.auth.authList = AuthList
|
|
|
|
|
|
- AuthList.forEach(item => {
|
|
|
- this.permissionTreeChckedKeys.push(item.AuthId)
|
|
|
- })
|
|
|
- this.roleListCheckedList = RoleList
|
|
|
+ AuthList &&
|
|
|
+ AuthList.length &&
|
|
|
+ AuthList.forEach(auth => {
|
|
|
+ this.permissionTreeChckedKeys.push(auth.AuthId)
|
|
|
+ })
|
|
|
+ GroupList &&
|
|
|
+ GroupList.length &&
|
|
|
+ GroupList.forEach(group => {
|
|
|
+ this.accountGroupTreeCheckedList.push(group.GroupId)
|
|
|
+ })
|
|
|
+ RoleList &&
|
|
|
+ RoleList.length &&
|
|
|
+ RoleList.forEach(role => {
|
|
|
+ role.IsSelected && this.roleListCheckedList.push(role.RoleId)
|
|
|
+ })
|
|
|
+ TacList &&
|
|
|
+ TacList &&
|
|
|
+ TacList.forEach(tac => {
|
|
|
+ tac.IsSelected && this.loginPolicyCheckedList.push(tac.TacId)
|
|
|
+ })
|
|
|
} else {
|
|
|
this.$message.error(res.message)
|
|
|
}
|
|
@@ -389,11 +413,13 @@ export default {
|
|
|
console.log('出错了', error)
|
|
|
}
|
|
|
},
|
|
|
+ // 随机生成密码
|
|
|
resetPwd() {
|
|
|
this.accountForm.pwd = generatePassword(this.pwdStruc, this.pwdLengthBegin, this.pwdLengthEnd)
|
|
|
},
|
|
|
// 获取当前权限树勾选项
|
|
|
getPermissionTreeChecked(arr) {
|
|
|
+ console.log('权限树勾选', arr)
|
|
|
this.permissionTreeChckedTemp = arr
|
|
|
},
|
|
|
// 获取当前编辑的权限规则
|
|
@@ -402,6 +428,7 @@ export default {
|
|
|
},
|
|
|
// 获取当前勾选的登录策略
|
|
|
getLoginPolicyChecked(arr) {
|
|
|
+ console.log('登录策略勾选', arr)
|
|
|
this.loginPolicyCheckedTemp = arr
|
|
|
},
|
|
|
// 获取当前勾选的账号组
|
|
@@ -412,7 +439,7 @@ export default {
|
|
|
getRoleListChecked(arr) {
|
|
|
this.roleListCheckedTemp = arr
|
|
|
},
|
|
|
- // 点击角色后
|
|
|
+ // 点击角色后显示对应权限列表
|
|
|
async selectRole(data) {
|
|
|
if (this.currentSelectedRoleId === data.RoleId) return
|
|
|
try {
|
|
@@ -420,6 +447,7 @@ export default {
|
|
|
RoleId: data.RoleId
|
|
|
}
|
|
|
const result = await RoleAuths(params)
|
|
|
+ // console.log(result.returnData)
|
|
|
this.permissionList = result.returnData
|
|
|
this.currentSelectedRoleId = data.RoleId
|
|
|
} catch (error) {
|
|
@@ -431,33 +459,58 @@ export default {
|
|
|
Competen(data) {
|
|
|
console.log(data)
|
|
|
},
|
|
|
- // 账号编辑修改
|
|
|
- async saveEdit() {
|
|
|
- const treeData = []
|
|
|
- this.permissionTreeChckedTemp.forEach(item => {
|
|
|
- treeData.push(item.AuthList)
|
|
|
- })
|
|
|
- treeData.forEach((item, index) => {
|
|
|
- this.$store.getters.authArrs.forEach(item2 => {
|
|
|
- if (item.AuthId === item2.AuthId) {
|
|
|
- treeData[index] = item2.AuthList
|
|
|
- }
|
|
|
- })
|
|
|
- })
|
|
|
-
|
|
|
+ // 账号编辑保存
|
|
|
+ handleClickSave() {
|
|
|
+ // const treeData = []
|
|
|
+ // this.permissionTreeChckedTemp.forEach(item => {
|
|
|
+ // treeData.push(item.AuthList)
|
|
|
+ // })
|
|
|
+ // treeData.forEach((item, index) => {
|
|
|
+ // this.authArrs.forEach(item2 => {
|
|
|
+ // if (item.AuthId === item2.AuthId) {
|
|
|
+ // treeData[index] = item2.AuthList
|
|
|
+ // }
|
|
|
+ // })
|
|
|
+ // })
|
|
|
+ // const params = {
|
|
|
+ // AuthList: treeData,
|
|
|
+ // GroupList: this.accountGroupTreeCheckedTemp,
|
|
|
+ // RoleList: this.roleListCheckedTemp,
|
|
|
+ // Status: 0,
|
|
|
+ // TacList: this.loginPolicyCheckedTemp,
|
|
|
+ // UserDesc: this.accountForm.desc,
|
|
|
+ // UserName: this.accountForm.name,
|
|
|
+ // UserPwd: this.accountForm.pwd
|
|
|
+ // }
|
|
|
+ // if (this.doesAccountExist) {
|
|
|
+ // this.saveEditAccount({
|
|
|
+ // ...params,
|
|
|
+ // UserId: this.userId
|
|
|
+ // })
|
|
|
+ // } else {
|
|
|
+ // this.saveAddAccount(params)
|
|
|
+ // }
|
|
|
+ },
|
|
|
+ // 编辑账号
|
|
|
+ async saveEditAccount(params) {
|
|
|
try {
|
|
|
- const res = await editAccount({
|
|
|
- UserDesc: this.accountForm.desc,
|
|
|
- UserName: this.accountForm.name,
|
|
|
- UserPwd: this.accountForm.pwd,
|
|
|
- AuthList: treeData,
|
|
|
- RoleList: this.roleListCheckedTemp,
|
|
|
- GroupId: this.groupId,
|
|
|
- UserId: this.userId,
|
|
|
- AuthTo: treeData,
|
|
|
- GroupList: this.accountGroupTreeCheckedTemp,
|
|
|
- TacList: this.loginPolicyCheckedTemp ? this.loginPolicyCheckedTemp : []
|
|
|
- })
|
|
|
+ const res = await editAccount(params)
|
|
|
+ if (res.code === 0) {
|
|
|
+ this.$message.success(res.message)
|
|
|
+ setTimeout(() => {
|
|
|
+ this.$router.push('/account')
|
|
|
+ })
|
|
|
+ } else {
|
|
|
+ this.$message.error(res.message)
|
|
|
+ }
|
|
|
+ } catch (error) {
|
|
|
+ console.log('出错了', error)
|
|
|
+ }
|
|
|
+ },
|
|
|
+ // 新增账号
|
|
|
+ async saveAddAccount(params) {
|
|
|
+ try {
|
|
|
+ const res = await addAccount(params)
|
|
|
if (res.code === 0) {
|
|
|
this.$message.success(res.message)
|
|
|
setTimeout(() => {
|
|
@@ -510,6 +563,7 @@ export default {
|
|
|
border-radius: 6px;
|
|
|
color: #fff;
|
|
|
border: none;
|
|
|
+ cursor: pointer;
|
|
|
}
|
|
|
.btn-delete {
|
|
|
width: 80px;
|
|
@@ -526,8 +580,14 @@ export default {
|
|
|
padding-top: 35px;
|
|
|
box-sizing: border-box;
|
|
|
.btn-reset-pwd {
|
|
|
+ width: 72px;
|
|
|
+ height: 32px;
|
|
|
background: #6e81bc;
|
|
|
+ border: none;
|
|
|
+ border-radius: 6px;
|
|
|
color: #fff;
|
|
|
+ font-size: 14px;
|
|
|
+ cursor: pointer;
|
|
|
margin-top: 4px;
|
|
|
margin-left: -25px;
|
|
|
}
|