Compare commits

..

No commits in common. "65f0af06ad2d513d0cab04a086dc4855df3c67f2" and "de832afac848d5b3cc850e077c5038a76e1c232e" have entirely different histories.

2 changed files with 94 additions and 147 deletions

View File

@ -381,7 +381,7 @@ async function VueInit() {
zzSessionStorage.removeItem('isLock') zzSessionStorage.removeItem('isLock')
router.push("/login") router.push("/login")
}).then(() => { }).then(() => {
_vm.$alert(lang === 'zh' ? '由于您长时间未操作,为保护您的数据安全已强制将您下线,如果需要继续操作请重新登' : 'No operation for a long time non-operation, you have been forced logout to protect data security. If continue to operate, please login again!', { _vm.$alert(lang === 'zh' ? '由于您长时间未操作,为保护您的数据安全已强制将您下线,如果需要继续操作请重新登' : 'No operation for a long time non-operation, you have been forced logout to protect data security. If continue to operate, please login again!', {
type: 'warning', type: 'warning',
}) })
}) })

View File

@ -16,17 +16,13 @@
<el-form-item label="Shortname: " prop="UserTypeShortName"> <el-form-item label="Shortname: " prop="UserTypeShortName">
<el-input v-model="form.UserTypeShortName" /> <el-input v-model="form.UserTypeShortName" />
</el-form-item> </el-form-item>
<el-form-item <el-form-item label="是否内部角色: " prop="IsInternal">
:label="$t('system:role:form:isInternal')"
prop="IsInternal"
>
<el-radio-group v-model="form.IsInternal"> <el-radio-group v-model="form.IsInternal">
<el-radio <el-radio
v-for="item of $d.YesOrNo" v-for="item of $d.YesOrNo"
:key="`IsInternal${item.value}`" :key="`IsInternal${item.value}`"
:label="item.value" :label="item.value"
>{{ item.label }}</el-radio >{{ item.label }}</el-radio>
>
</el-radio-group> </el-radio-group>
</el-form-item> </el-form-item>
@ -42,11 +38,7 @@
</el-form-item> </el-form-item>
<el-form-item label="Order: "> <el-form-item label="Order: ">
<el-input-number <el-input-number v-model="form.Order" controls-position="right" :min="0" />
v-model="form.Order"
controls-position="right"
:min="0"
/>
</el-form-item> </el-form-item>
<el-form-item label="PermissionStr: " prop="PermissionStr"> <el-form-item label="PermissionStr: " prop="PermissionStr">
<el-input v-model="form.PermissionStr" /> <el-input v-model="form.PermissionStr" />
@ -66,23 +58,9 @@
<el-input v-model="form.Description" type="textarea" :rows="5" /> <el-input v-model="form.Description" type="textarea" :rows="5" />
</el-form-item> </el-form-item>
<el-form-item label="role: "> <el-form-item label="role: ">
<el-checkbox <el-checkbox v-model="menuExpand" @change="handleCheckedTreeExpand($event)">/</el-checkbox>
v-model="menuExpand" <el-checkbox v-model="menuNodeAll" @change="handleCheckedTreeNodeAll($event)">/</el-checkbox>
@change="handleCheckedTreeExpand($event)" <el-checkbox v-model="form.menuCheckStrictly" @change="handleCheckedTreeConnect($event)"></el-checkbox>
>{{ $t("system:role:form:checkbox:menuExpand") }}</el-checkbox
>
<el-checkbox
v-model="menuNodeAll"
@change="handleCheckedTreeNodeAll($event)"
>{{ $t("system:role:form:checkbox:menuNodeAll") }}</el-checkbox
>
<el-checkbox
v-model="form.menuCheckStrictly"
@change="handleCheckedTreeConnect($event)"
>{{
$t("system:role:form:checkbox:menuCheckStrictly")
}}</el-checkbox
>
<el-tree <el-tree
ref="menu" ref="menu"
class="tree-border" class="tree-border"
@ -98,186 +76,155 @@
</el-form> </el-form>
</template> </template>
<template slot="dialog-footer"> <template slot="dialog-footer">
<el-button <el-button :disabled="btnLoading" size="small" type="primary" @click="model_cfg.visible = false">Cancel
:disabled="btnLoading"
size="small"
type="primary"
@click="model_cfg.visible = false"
>Cancel
</el-button> </el-button>
<el-button <el-button size="small" type="primary" :loading="btnLoading" @click="handleSave">Save</el-button>
size="small"
type="primary"
:loading="btnLoading"
@click="handleSave"
>Save</el-button
>
</template> </template>
</base-model> </base-model>
</template> </template>
<script> <script>
import { addOrUpdateUserType } from "@/api/admin"; import { addOrUpdateUserType } from '@/api/admin'
// import { addOrUpdateUserType } from '@/api/system/role' // import { addOrUpdateUserType } from '@/api/system/role'
// import { getMenuList } from '@/api/system/menu' // import { getMenuList } from '@/api/system/menu'
import { getMenuList } from "@/api/system/menu"; import { getMenuList } from '@/api/system/menu'
import { model_cfg } from "../role"; import { model_cfg } from '../role'
import BaseModel from "@/components/BaseModel"; import BaseModel from '@/components/BaseModel'
export default { export default {
components: { BaseModel }, components: { BaseModel },
dicts: ["UserTypeGroup"], dicts: ['UserTypeGroup'],
props: { props: {
data: { data: {
type: Object, type: Object,
default() { default() {
return { return {
Id: "", Id: '',
UserTypeName: "", UserTypeName: '',
IsInternal: true, IsInternal: true,
UserTypeShortName: "", UserTypeShortName: '',
Order: "", Order: '',
Description: "", Description: '',
PermissionStr: "", PermissionStr: '',
UserTypeEnum: null, UserTypeEnum: null
}; }
}, }
}, }
}, },
data() { data() {
return { return {
menuExpand: false, menuExpand: false,
menuNodeAll: false, menuNodeAll: false,
userTypeGroupOptions: [ userTypeGroupOptions: [{ value: 1, label: 'Trial' }, { value: 2, label: 'Reviewer' }, { value: 3, label: 'Other' }],
{ value: 1, label: "Trial" },
{ value: 2, label: "Reviewer" },
{ value: 3, label: "Other" },
],
model_cfg, model_cfg,
defaultProps: { defaultProps: {
children: "Children", children: 'Children',
label: "MenuName", label: 'MenuName'
}, },
form: { form: {
Id: "", Id: '',
UserType: "", UserType: '',
IsInternal: true, IsInternal: true,
UserTypeShortName: "", UserTypeShortName: '',
Type: null, Type: null,
Description: "", Description: '',
UserTypeGroupIdList: [], UserTypeGroupIdList: [],
menuCheckStrictly: true, menuCheckStrictly: true
}, },
rules: { rules: {
UserTypeName: [ UserTypeName: [{ 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", UserTypeShortName: [{ required: true, message: 'Please specify', trigger: 'blur' }, {
}, max: 50,
], message: 'The maximum length is 50',
UserTypeShortName: [ trigger: 'blur'
{ required: true, message: "Please specify", trigger: "blur" }, }],
{ Description: [{ max: 500, message: 'The maximum length is 500' }],
max: 50, UserTypeGroupIdList: [{ required: true, message: 'Please specify', trigger: 'blur' }],
message: "The maximum length is 50", UserTypeEnum: [{ required: true, message: 'Please select', trigger: 'blur' }]
trigger: "blur",
},
],
Description: [{ max: 500, message: "The maximum length is 500" }],
UserTypeGroupIdList: [
{ required: true, message: "Please specify", trigger: "blur" },
],
UserTypeEnum: [
{ required: true, message: "Please select", trigger: "blur" },
],
}, },
menuOptions: [], menuOptions: [],
btnLoading: false, btnLoading: false
}; }
}, },
mounted() { mounted() {
this.getMenuList(); this.getMenuList()
if (Object.keys(this.data).length && this.data.Id) { if (Object.keys(this.data).length && this.data.Id) {
this.form = { ...this.data }; this.form = { ...this.data }
} }
}, },
methods: { methods: {
handleCheckedTreeConnect(value) { handleCheckedTreeConnect(value) {
this.form.menuCheckStrictly = !!value; this.form.menuCheckStrictly = !!value
}, },
getMenuAllCheckedKeys() { getMenuAllCheckedKeys() {
// //
const checkedKeys = this.$refs.menu.getCheckedKeys(); const checkedKeys = this.$refs.menu.getCheckedKeys()
// //
const halfCheckedKeys = this.$refs.menu.getHalfCheckedKeys(); const halfCheckedKeys = this.$refs.menu.getHalfCheckedKeys()
checkedKeys.unshift.apply(checkedKeys, halfCheckedKeys); checkedKeys.unshift.apply(checkedKeys, halfCheckedKeys)
return checkedKeys; return checkedKeys
}, },
handleCheckedTreeExpand(value) { handleCheckedTreeExpand(value) {
const treeList = this.menuOptions; const treeList = this.menuOptions
for (let i = 0; i < treeList.length; i++) { for (let i = 0; i < treeList.length; i++) {
this.$refs.menu.store.nodesMap[treeList[i].MenuId].expanded = value; this.$refs.menu.store.nodesMap[treeList[i].MenuId].expanded = value
} }
}, },
handleCheckedTreeNodeAll(value, type) { handleCheckedTreeNodeAll(value, type) {
this.$refs.menu.setCheckedNodes(value ? this.menuOptions : []); this.$refs.menu.setCheckedNodes(value ? this.menuOptions : [])
}, },
toTree(arr, ParentId) { toTree(arr, ParentId) {
function loop(ParentId) { function loop(ParentId) {
const res = []; const res = []
for (let i = 0; i < arr.length; i++) { for (let i = 0; i < arr.length; i++) {
const item = arr[i]; const item = arr[i]
item.hasChildren = false; item.hasChildren = false
if (item.ParentId !== ParentId) { if (item.ParentId !== ParentId) {
continue; continue
} }
item.Children = loop(item.MenuId); item.Children = loop(item.MenuId)
res.push(item); res.push(item)
} }
return res; return res
} }
return loop(ParentId); return loop(ParentId)
}, },
getMenuList() { getMenuList() {
getMenuList({}) getMenuList({}).then(res => {
.then((res) => { const menu = this.toTree(res.Result, '00000000-0000-0000-0000-000000000000')
const menu = this.toTree( this.menuOptions = menu
res.Result, console.log(this.menuOptions)
"00000000-0000-0000-0000-000000000000" this.$nextTick(() => {
); this.form.MenuIds.forEach(v => {
this.menuOptions = menu; this.$refs.menu.setChecked(v, true, false)
console.log(this.menuOptions); })
this.$nextTick(() => {
this.form.MenuIds.forEach((v) => {
this.$refs.menu.setChecked(v, true, false);
});
});
}) })
.catch(function () {}); }).catch(function() {
})
}, },
handleSave() { handleSave() {
this.$refs.roleForm.validate((valid) => { this.$refs.roleForm.validate(valid => {
if (!valid) return; if (!valid) return
this.btnLoading = true; this.btnLoading = true
this.model_cfg.showClose = false; this.model_cfg.showClose = false
this.form.MenuIds = this.getMenuAllCheckedKeys(); this.form.MenuIds = this.getMenuAllCheckedKeys()
console.log(this.form.MenuIds); console.log(this.form.MenuIds)
addOrUpdateUserType(this.form) addOrUpdateUserType(this.form).then(res => {
.then((res) => { this.btnLoading = false
this.btnLoading = false; this.$refs['roleForm'].resetFields()
this.$refs["roleForm"].resetFields(); this.$emit('close')
this.$emit("close"); this.model_cfg.showClose = true
this.model_cfg.showClose = true; this.$message.success('Saved successfully!')
this.$message.success("Saved successfully!"); }).catch(() => {
}) this.btnLoading = false
.catch(() => { this.model_cfg.showClose = true
this.btnLoading = false; })
this.model_cfg.showClose = true; })
}); }
}); }
}, }
},
};
</script> </script>