Files
orange-admin/orange-admin-web/src/views/upms/formEditSysMenu/index.vue
2020-04-12 09:32:34 +08:00

279 lines
10 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<template>
<el-form ref="form" :model="formData" :rules="rules" label-width="110px" size="mini" label-position="right" @submit.native.prevent>
<el-row :gutter="20" class="full-width-input">
<el-col :span="12">
<el-form-item label="上级菜单">
<el-cascader :options="menuTree" v-model="parentMenuPath" :props="menuProps" placeholder="选择父菜单"
:disabled="!canEditParent" :clearable="true" :change-on-select="true" size="mini"
@change="onParentMenuChange" />
</el-form-item>
</el-col>
<el-col :span="12" >
<el-form-item label="菜单名称" prop="menuName">
<el-input v-model="formData.menuName" placeholder="菜单名称" clearable />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="菜单类型" prop="menuType">
<el-select v-model="formData.menuType" :disabled="isEdit" placeholder="菜单类型" @change="onMenuTypeChange">
<el-option v-for="item in getValidMenuType" :key="item.id" :value="item.id" :label="item.name" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="显示顺序" prop="showOrder">
<el-input-number v-model="formData.showOrder" controls-position="right"
:min="1" :max="99999" placeholder="请输入显示顺序"></el-input-number>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="菜单路由">
<el-input v-model="formData.formRouterName" placeholder="菜单路由" :disabled="formData.menuType !== 1" />
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="菜单图标" prop="icon">
<icon-select v-model="formData.icon" :height="28" />
</el-form-item>
</el-col>
<el-col :span="24">
<el-card shadow="never">
<div slot="header" class="card-header">
<span>权限字列表</span>
<el-input size="mini" v-model="permCodeNameFilter" placeholder="输入权限字名称过滤" style="width: 250px;" clearable suffix-icon="el-icon-search" />
</div>
<el-scrollbar style="height: 210px;" wrap-class="scrollbar_dropdown__wrap">
<el-tree ref="permCodeTree" v-show="formData.menuType" :check-strictly="true"
:props="treeProps" node-key="permCodeId" :default-expanded-keys="defaultExpandedKeys"
show-checkbox :data="getPermCodeTree" :filter-node-method="filterPermCodeNode"></el-tree>
</el-scrollbar>
</el-card>
</el-col>
</el-row>
<!-- 弹窗按钮 -->
<el-row type="flex" justify="end" class="dialog-btn-layer mt20">
<el-button size="mini" @click="onCancel(false)" >取消</el-button>
<el-button type="primary" size="mini" @click="onSubmit"
:disabled="!(checkPermCodeExist('formSysMenu:fragmentSysMenu:add') || checkPermCodeExist('formSysMenu:fragmentSysMenu:update'))">
确定
</el-button>
</el-row>
</el-form>
</template>
<script>
import { treeDataTranslate, findTreeNodePath, findTreeNode, findItemFromList } from '@/utils'
import { SystemController } from '@/api'
import IconSelect from '@/components/IconSelect/index.vue'
export default {
props: {
menuId: {
type: String
},
parentId: {
type: String
},
menuList: {
type: Array,
default: undefined
},
rowData: {
type: Object,
default: undefined
}
},
components: {
IconSelect
},
data () {
return {
// 是否自动用上级菜单的名称过滤权限字列表当这个开关打开后会使用getAutoFilterString返回的字符串当做过滤字符串
autoFilter: false,
permCodeNameFilter: undefined,
allowParentList: [],
formData: {
menuId: undefined,
parentId: undefined,
menuName: undefined,
showOrder: undefined,
menuType: undefined,
icon: undefined,
formRouterName: undefined
},
menuProps: {
label: 'menuName',
value: 'menuId'
},
parentMenuType: undefined,
parentMenuPath: [],
menuTree: [],
permCodeList: [],
selectPermCode: undefined,
defaultExpandedKeys: [],
rules: {
menuName: [{required: true, message: '请输入菜单名称', trigger: 'blur'}],
showOrder: [{required: true, message: '请输入菜单显示顺序', trigger: 'blur'}],
formRouterName: [{required: true, message: '请输入菜单路由名称', trigger: 'blur'}]
},
treeProps: {
label: 'showName'
}
};
},
methods: {
getAutoFilterString () {
let node = findTreeNode(this.menuTree, this.parentMenuPath[this.parentMenuPath.length - 1], 'menuId');
return node ? node.menuName : undefined;
},
onMenuTypeChange (value) {
if (this.autoFilter && value === this.SysMenuType.BUTTON && (this.permCodeNameFilter == null || this.permCodeNameFilter === '')) {
this.permCodeNameFilter = this.getAutoFilterString();
}
},
filterPermCodeNode (value, data) {
if (!value) return true;
if (data.showName.indexOf(value) !== -1) {
this.allowParentList.push(data.permCodeId);
return true;
} else {
return this.allowParentList.indexOf(data.parentId) !== -1;
}
},
onParentMenuChange (value, isInit) {
if (!isInit) this.formData.menuType = undefined;
this.parentMenuType = undefined;
if (Array.isArray(value) && value.length > 0) {
let node = findTreeNode(this.menuTree, value[value.length - 1], 'menuId');
if (node) this.parentMenuType = node.menuType;
}
},
onCancel (isSuccess) {
if (this.observer != null) {
this.observer.cancel(isSuccess);
}
},
onSubmit () {
return new Promise((resolve, reject) => {
this.$refs['form'].validate((valid) => {
if (valid) {
let params = {};
params.sysMenu = {...this.formData};
if (this.parentMenuPath.length > 0) {
params.sysMenu.parentId = this.parentMenuPath[this.parentMenuPath.length - 1];
}
if ([this.SysMenuType.MENU, this.SysMenuType.BUTTON, this.SysMenuType.FRAGMENT].indexOf(params.sysMenu.menuType) !== -1) {
let tempList = this.$refs.permCodeTree.getHalfCheckedKeys();
tempList = tempList.concat(this.$refs.permCodeTree.getCheckedKeys());
params.permCodeIdListString = tempList.join(',');
}
if (this.isEdit) {
SystemController.updateMenu(this, params).then(res => {
resolve(res);
this.$message.success('编辑成功');
this.onCancel(true);
}).catch(e => {
reject(e);
});
} else {
SystemController.addMenu(this, params).then(res => {
resolve(res);
this.$message.success('添加成功');
this.onCancel(true);
}).catch(e => {
reject(e);
});
}
} else {
reject();
}
});
});
},
formatMenuTree () {
this.menuTree = [];
if (Array.isArray(this.menuList)) {
this.menuTree = this.menuList.filter((item) => {
return item.menuType !== this.SysMenuType.BUTTON && item.menuId !== this.formData.menuId;
});
}
this.menuTree = treeDataTranslate(this.menuTree, 'menuId', 'parentId');
},
initData () {
this.defaultExpandedKeys = [];
this.formatMenuTree();
this.parentMenuPath = findTreeNodePath(this.menuTree, this.formData.parentId, 'menuId');
this.onParentMenuChange(this.parentMenuPath, true);
this.onMenuTypeChange(this.formData.menuType);
SystemController.getPermCodeList(this, {}).then(res => {
this.permCodeList = res.data;
if (Array.isArray(this.formData.permCodeIdList) && this.formData.permCodeIdList.length > 0) {
let tempList = [];
this.permCodeList.forEach((item) => {
if (findItemFromList(this.formData.permCodeIdList, item.permCodeId) != null) {
tempList.push(item.permCodeId);
}
});
this.defaultExpandedKeys = tempList;
this.$refs.permCodeTree.setCheckedKeys(tempList);
this.$nextTick(() => {
this.allowParentList = [];
if (this.permCodeNameFilter != null && this.permCodeNameFilter !== '') this.$refs.permCodeTree.filter(this.permCodeNameFilter);
});
}
}).catch(e => {});
}
},
computed: {
getValidMenuType () {
let allList = this.SysMenuType.getList();
if (this.parentMenuType == null) {
return allList;
} else {
return allList.filter((item) => {
switch (Number.parseInt(this.parentMenuType)) {
case this.SysMenuType.DIRECTORY: return item.id === this.SysMenuType.MENU;
case this.SysMenuType.MENU: return [this.SysMenuType.FRAGMENT, this.SysMenuType.BUTTON].indexOf(item.id) !== -1;
case this.SysMenuType.FRAGMENT: return item.id === this.SysMenuType.BUTTON;
default: return false;
}
});
}
},
isEdit () {
return this.formData.menuId != null;
},
// 判断是否新建一个目录
isNew () {
return this.formData.parentId == null && this.formData.menuId == null;
},
canEditParent () {
return this.parentId == null;
},
getPermCodeTree () {
if (this.permCodeList != null) {
return treeDataTranslate(this.permCodeList, 'permCodeId', 'parentId');
} else {
return [];
}
}
},
mounted () {
if (this.rowData != null) {
this.formData = {...this.formData, ...this.rowData};
}
if (this.parentId != null) this.formData.parentId = this.parentId;
this.initData();
},
watch: {
permCodeNameFilter (val) {
this.allowParentList = [];
this.$refs.permCodeTree.filter(val);
}
}
};
</script>