Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
lltx committed Apr 17, 2020
1 parent be47a42 commit 3559795
Showing 1 changed file with 172 additions and 0 deletions.
172 changes: 172 additions & 0 deletions src/views/admin/menu/menu-form.vue
Original file line number Diff line number Diff line change
@@ -0,0 +1,172 @@
<template>
<!-- 添加或修改菜单对话框 -->
<el-dialog :title="!form.menuId ? '新增' : '修改'"
:visible.sync="visible">
<el-form ref="dataForm" :model="form" :rules="rules" label-width="80px">
<el-row>
<el-col :span="12">
<el-form-item label="菜单类型" prop="type">
<el-radio-group v-model="form.type" size="small">
<el-radio-button label="0">菜单</el-radio-button>
<el-radio-button label="1">按钮</el-radio-button>
</el-radio-group>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="上级菜单">
<treeselect v-model="form.parentId"
:options="menuOptions"
:normalizer="normalizer"
:show-count="true"
placeholder="选择上级菜单"
/>
</el-form-item>
</el-col>
</el-row>
<el-form-item label="图标" prop="icon" v-if="form.type === '0'">
<avue-icon-select v-model="form.icon" :icon-list="iconList"></avue-icon-select>
</el-form-item>
<el-form-item label="名称" prop="name">
<el-input v-model="form.name" placeholder="请输入菜单名称"/>
</el-form-item>
<el-form-item label="路由地址" prop="path" v-if="form.type !== '1'">
<el-input v-model="form.path" placeholder="请输入路由地址"/>
</el-form-item>
<el-form-item label="权限标识" prop="permission" v-if="form.type === '1'">
<el-input v-model="form.permission" placeholder="请权限标识" maxlength="50"/>
</el-form-item>
<el-row>
<el-col :span="12">
<el-form-item label="排序" prop="sort">
<el-input-number v-model="form.sort" controls-position="right" :min="0"/>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="路由缓冲" prop="keepAlive" v-if="form.type !== '1'">
<el-radio-group v-model="form.keepAlive">
<el-radio-button label="0">否</el-radio-button>
<el-radio-button label="1">是</el-radio-button>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="dataFormSubmit">确 定</el-button>
<el-button @click="visible = false">取 消</el-button>
</div>
</el-dialog>
</template>

<script>
import {addObj, fetchMenuTree, getObj, putObj} from '@/api/admin/menu'
import Treeselect from "@riophae/vue-treeselect"
import iconList from '@/const/iconList'
import TableForm from './'
import "@riophae/vue-treeselect/dist/vue-treeselect.css"
export default {
name: "Menu",
components: {Treeselect, TableForm},
data() {
return {
// 遮罩层
loading: true,
// 菜单树选项
menuOptions: [],
// 是否显示弹出层
visible: false,
// 图标
iconList: iconList,
form: {
name: undefined,
path: undefined,
icon: undefined,
permission: undefined,
type: '0',
keepAlive: '0',
sort: 999
},
// 表单校验
rules: {
name: [
{required: true, message: "菜单名称不能为空", trigger: "blur"}
],
sort: [
{required: true, message: "菜单顺序不能为空", trigger: "blur"}
],
path: [
{required: true, message: "路由地址不能为空", trigger: "blur"}
],
keepAlive: [
{required: true, message: "路由缓冲不能为空", trigger: "blur"}
],
permission: [
{required: true, message: "权限标识不能为空", trigger: "blur"}
]
}
};
},
methods: {
init(isEdit, id) {
if (id != null) {
this.form.parentId = id;
}
this.visible = true
this.getTreeselect();
this.$nextTick(() => {
this.$refs['dataForm'].resetFields()
if (isEdit) {
getObj(id).then(response => {
this.form = response.data.data
})
}
})
},
// 表单提交
dataFormSubmit() {
this.$refs['dataForm'].validate((valid) => {
if (valid) {
if (this.form.parentId === undefined) {
this.form.parentId = -1
}
if (this.form.menuId) {
putObj(this.form).then(data => {
this.$message.success('修改成功')
this.visible = false
this.$emit('refreshDataList')
});
} else {
addObj(this.form).then(data => {
this.$message.success('添加成功')
this.visible = false
this.$emit('refreshDataList')
})
}
}
})
},
/** 查询菜单下拉树结构 */
getTreeselect() {
fetchMenuTree().then(response => {
this.menuOptions = [];
const menu = {id: -1, name: '根菜单', children: []};
menu.children = response.data.data;
this.menuOptions.push(menu);
});
},
/** 转换菜单数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children;
}
return {
id: node.id,
label: node.name,
children: node.children
};
}
}
};
</script>

0 comments on commit 3559795

Please sign in to comment.