123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286 |
- <template>
- <div class="box">
- <div>
- <div style="margin-bottom: 10px">
- <el-button type="primary" v-if="hasPerm('menu:add')" @click="addMenu">添加菜单</el-button>
- </div>
- <div>
- <el-table
- :data="tableData"
- border
- row-key="id"
- :height="800 + 'px'"
- :tree-props="{children: 'children'}"
- default-expand-all>
- <el-table-column prop="title" label="菜单名称"></el-table-column>
- <el-table-column
- prop="weight"
- label="菜单层级"
- :filters="[{ text: '菜单', value: 0 }, { text: '按钮', value: 1 }]"
- :filter-method="filterTag">
- <template slot-scope="scope">
- <el-tag
- :type="scope.row.weight === 0 ? 'primary' : 'success'"
- disable-transitions>{{scope.row.weight === 0 ? '菜单' : '按钮'}}</el-tag>
- </template>
- </el-table-column>
- <el-table-column prop="url" label="菜单路由"></el-table-column>
- <!-- <el-table-column prop="remark" label="备注"></el-table-column>-->
- <el-table-column
- label="操作"
- fixed="right">
- <template slot-scope="scope">
- <el-button size="mini" type="info" v-if="hasPerm('menu:edit')" @click="setEdit(scope.row)" style="margin-right: 10px">编辑</el-button>
- <!-- <el-button size="mini" type="primary" style="margin-right: 10px" @click="addChildren(scope.row, scope.$index)">添加子菜单</el-button>-->
- <el-popconfirm
- :title="scope.row.parentId === 0 ? '这是父菜单,删除后,子菜单将不复存在!确定要删除这个菜单吗' : '确定要删除这个菜单吗?'"
- @confirm="del(scope.row)"
- >
- <el-button size="mini" slot="reference" v-if="hasPerm('menu:del')" type="danger">删除</el-button>
- </el-popconfirm>
- </template>
- </el-table-column>
- </el-table>
- </div>
- </div>
- <a-modal
- :title="showType ? '编辑菜单' : '新增菜单'"
- :width="600"
- :visible="dialogFormVisible"
- @ok="add('ruleForm')"
- @cancel="reset"
- :destroyOnClose="true"
- >
- <el-form :model="form" :rules="rules" ref="ruleForm">
- <el-form-item prop="weight" size="mini" label="菜单层级:" :label-width="formLabelWidth">
- <el-radio-group v-model="form.weight">
- <el-radio :label="0">菜单</el-radio>
- <el-radio :label="1">按钮</el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item size="mini" label="菜单名称" :label-width="formLabelWidth" prop="title">
- <el-input v-model="form.title" autocomplete="off"></el-input>
- </el-form-item>
- <el-form-item size="mini" label="父级菜单" :label-width="formLabelWidth">
- <a-tree-select
- v-model="form.parentId"
- style="width: 100%"
- :dropdownStyle="{ maxHeight: '300px', overflow: 'auto' }"
- :treeData="menuTreeData"
- placeholder="请选择父级菜单"
- treeDefaultExpandAll
- >
- <span slot="title" slot-scope="{ id }">{{ id }}
- </span>
- </a-tree-select>
- </el-form-item>
- <el-form-item size="mini" v-if="form.weight === 0" label="菜单地址" :label-width="formLabelWidth">
- <el-input v-model="form.url" autocomplete="off"></el-input>
- </el-form-item>
- <el-form-item size="mini" v-else label="权限标识" :label-width="formLabelWidth" prop="permission">
- <el-input v-model="form.permission" autocomplete="off"></el-input>
- </el-form-item>
- <el-form-item size="mini" label="排序" :label-width="formLabelWidth">
- <el-input v-model="form.sort" autocomplete="off"></el-input>
- </el-form-item>
- </el-form>
- </a-modal>
- </div>
- </template>
- <script>
- import { TreeSelect } from 'ant-design-vue'
- import { addMenu, editMenu, delMenu, getUserMenu } from '../../utils/api'
- export default {
- name: "MenuAdmin",
- components: {
- // AModal: Modal,
- // AForm: Form,
- ATreeSelect: TreeSelect
- },
- data() {
- return {
- tableData: [],
- showType: false,
- dialogFormVisible: false,
- form: {
- title: '',
- parentId: '',
- url: '',
- id: '',
- sort: '',
- weight: 0,
- permission: '',
- },
- formLabelWidth: '90px',
- rules: {
- title: [
- { required: true, message: '请输入菜单名称', trigger: 'blur' },
- ],
- weight: [
- { required: true, message: '请选择菜单层级', trigger: 'change' }
- ],
- menu: [
- { required: true, message: '请选择父级菜单', trigger: 'change' }
- ],
- permission: [
- { required: true, message: '请输入权限标识', trigger: 'blur' }
- ]
- },
- menuTreeData: [],
- }
- },
- methods: {
- // 拿到parentId
- getParentId(val) {
- this.form.parentId = val;
- },
- // 过滤
- filterTag(value, row) {
- return row.weight === value;
- },
- add(formName) {
- this.$refs[formName].validate((valid) => {
- if(valid) {
- if(this.showType) {
- this.setUpdate();
- } else {
- let params = {
- parentId: this.form.parentId,
- title: this.form.title,
- url: this.form.url,
- sort: this.form.sort,
- weight: this.form.weight,
- permission: this.form.permission,
- }
- addMenu(params)
- .then(res => {
- if(res.code === 10000) {
- this.init();
- this.reset();
- this.$message.success(res.message);
- }
- this.dialogFormVisible = false;
- })
- }
- } else {
- return false;
- }
- })
- this.dialogFormVisible = false;
- },
- setEdit(data) {
- this.showType = true;
- this.dialogFormVisible = true;
- this.form.id = data.id;
- this.form.title = data.title;
- this.form.url = data.url;
- this.form.parentId = data.parentId;
- this.form.sort = data.sort;
- this.form.permission = data.permission;
- this.form.weight = data.weight;
- },
- addMenu() {
- this.dialogFormVisible = true;
- },
- del(data) {
- delMenu({menuId: data.id})
- .then(res => {
- if(res.code === 10000) {
- this.init();
- this.$message.success(res.message);
- }
- })
- },
- setUpdate() {
- let params = {
- id: this.form.id,
- url: this.form.url,
- title: this.form.title,
- parentId: this.form.parentId,
- sort: this.form.sort,
- permission: this.form.permission,
- weight: this.form.weight,
- };
- editMenu(params)
- .then(res => {
- if(res.code === 10000) {
- this.init();
- this.reset();
- this.$message.success(res.message);
- }
- this.dialogFormVisible = false;
- })
- },
- // 重置
- reset() {
- this.form.title = '';
- this.form.parentId = '';
- this.form.url = '';
- this.form.id = '';
- this.form.sort = '';
- this.form.weight = 0;
- this.form.permission = '';
- this.showType = false;
- this.dialogFormVisible = false
- },
- init() {
- // getMenu()
- // .then(res => {
- // if(res.code === 10000) {
- // // this.tableData = res.data;
- // // console.log(res.data)
- // }
- // })
-
- let params = {
- userId: localStorage.getItem('UserId')
- }
- getUserMenu(params).then(res => {
- if(res.code === 10000) {
- this.tableData = res.data;
- this.menuTreeData = [
- {
- id: -1,
- parentId: 0,
- title: '顶级',
- value: 0,
- pid: 0,
- weight: 0,
- children: res.data,
- }
- ]
- }
- })
- // getMenuList().then(res => {
- // if(res.code === 10000) {
- // // this.menuTreeData = [
- // // {
- // // id: -1,
- // // parentId: 0,
- // // title: '顶级',
- // // value: 0,
- // // pid: 0,
- // // weight: 0,
- // // children: res.data,
- // // }
- // // ]
- // // console.log(res)
- // }
- // })
- }
- },
- mounted() {
- this.init();
- }
- }
- </script>
- <style scoped>
- .box {
- width: 100%;
- height: 100%;
- box-sizing: border-box;
- padding: 20px;
- }
- </style>
|