华西海圻ELN前端工程
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 

496 lines
18 KiB

<template>
<div class="app-container">
<el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch">
<el-form-item :label="$t('page.system.menu.name')+':'" prop="menuName">
<el-input
v-model="queryParams.menuName"
:placeholder="$t('form.placeholderInput')"
clearable
@keyup.enter.native="handleQuery"
/>
</el-form-item>
<el-form-item :label="$t('page.system.menu.status')+':'" prop="visible">
<el-select v-model="queryParams.visible" :placeholder="$t('form.placeholderSelect')">
<el-option :label="$t('page.system.menu.statusVisible')" :value="0" />
<el-option :label="$t('page.system.menu.statusHide')" :value="1" />
</el-select>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="handleQuery">{{$t('form.search')}}</el-button>
<el-button icon="el-icon-refresh" @click="resetQuery">{{$t('form.reset')}}</el-button>
</el-form-item>
</el-form>
<el-row :gutter="10" class="mb8">
<el-col :span="1.5">
<el-button
type="primary"
plain
icon="el-icon-plus"
@click="handleAdd"
v-hasPermi="['system:menu:add']"
>{{$t('form.add')}}</el-button>
</el-col>
<!-- <el-col :span="1.5">
<el-button
type="info"
plain
icon="el-icon-sort"
@click="toggleExpandAll"
>展开/折叠</el-button>
</el-col> -->
<!-- <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar> -->
</el-row>
<el-table
v-if="refreshTable"
v-loading="loading"
:data="menuList"
row-key="menuId"
:default-expand-all="isExpandAll"
:tree-props="{children: 'children', hasChildren: 'hasChildren'}"
>
<el-table-column prop="menuName" :label="$t('page.system.menu.name')" :show-overflow-tooltip="true"></el-table-column>
<el-table-column prop="orderNum" :label="$t('page.system.menu.sort')" width="100"></el-table-column>
<el-table-column prop="path" :label="$t('page.system.menu.router')" :show-overflow-tooltip="true"></el-table-column>
<el-table-column prop="menuType" :label="$t('page.system.menu.type')" width="100">
<template slot-scope="scope">
<span v-if="scope.row.menuType==='M'">{{$t('page.system.menu.typeDir')}}</span>
<span v-if="scope.row.menuType==='C'">{{$t('page.system.menu.typeMenu')}}</span>
<span v-if="scope.row.menuType==='F'">{{$t('page.system.menu.typeBtn')}}</span>
</template>
</el-table-column>
<el-table-column prop="visible" :label="$t('page.system.menu.status')" width="100">
<template slot-scope="scope">
<span v-if="scope.row.visible==='0'">{{$t('page.system.menu.statusVisible')}}</span>
<span v-if="scope.row.visible==='1'">{{$t('page.system.menu.statusHide')}}</span>
</template>
</el-table-column>
<!-- <el-table-column prop="perms" label="权限标识" :show-overflow-tooltip="true"></el-table-column>
<el-table-column prop="component" label="组件路径" :show-overflow-tooltip="true"></el-table-column>
<el-table-column prop="status" label="状态" width="80">
<template slot-scope="scope">
<dict-tag :options="dict.type.sys_normal_disable" :value="scope.row.status"/>
</template>
</el-table-column>
<el-table-column label="创建时间" align="center" prop="createTime">
<template slot-scope="scope">
<span>{{ parseTime(scope.row.createTime) }}</span>
</template>
</el-table-column> -->
<el-table-column :label="$t('form.operate')" align="center" class-name="small-padding fixed-width" width="200">
<template slot-scope="scope">
<el-button
type="text"
@click="handleAdd(scope.row)"
v-hasPermi="['system:menu:add']"
>{{$t('page.system.menu.add')}}</el-button>
<el-button
type="text"
@click="handleUpdate(scope.row)"
v-hasPermi="['system:menu:edit']"
>{{$t('page.system.menu.edit')}}</el-button>
<el-button
type="text"
@click="handleDelete(scope.row)"
v-hasPermi="['system:menu:remove']"
>{{$t('page.system.menu.delete')}}</el-button>
</template>
</el-table-column>
</el-table>
<!-- 添加或修改菜单对话框 -->
<el-dialog :close-on-click-modal="false" :close-on-press-escape="false" :title="title" :visible.sync="open" width="680px" append-to-body>
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
<el-row>
<el-col :span="24">
<el-form-item :label="$t('page.system.menu.parent')+':'" prop="parentId">
<treeselect
v-model="form.parentId"
:options="menuOptions"
:normalizer="normalizer"
:show-count="true"
/>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item :label="$t('page.system.menu.type')+':'" prop="menuType">
<el-radio-group v-model="form.menuType">
<el-radio label="M">{{$t('page.system.menu.typeDir')}}</el-radio>
<el-radio label="C">{{$t('page.system.menu.typeMenu')}}</el-radio>
<el-radio label="F">{{$t('page.system.menu.typeBtn')}}</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
<el-row>
<!-- <el-col :span="12" v-if="form.menuType != 'F'">
<el-form-item prop="isFrame">
<span slot="label">
<el-tooltip content="选择是外链则路由地址需要以`http(s)://`开头" placement="top">
<i class="el-icon-question"></i>
</el-tooltip>
是否外链
</span>
<el-radio-group v-model="form.isFrame">
<el-radio label="0">是</el-radio>
<el-radio label="1">否</el-radio>
</el-radio-group>
</el-form-item>
</el-col> -->
<el-col :span="24" v-if="form.menuType != 'F'">
<el-form-item prop="path">
<span slot="label">
<!-- <el-tooltip content="访问的路由地址,如:`user`,如外网地址需内链访问则以`http(s)://`开头" placement="top">
<i class="el-icon-question"></i>
</el-tooltip> -->
{{$t('page.system.menu.router')+':'}}
</span>
<el-input v-model="form.path" :placeholder="$t('form.placeholderInput')" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24">
<el-form-item :label="$t('page.system.menu.name')+':'" prop="menuName">
<el-input v-model="form.menuName" :placeholder="$t('form.placeholderInput')" />
</el-form-item>
</el-col>
<!-- <el-col :span="12" v-if="form.menuType == 'C'">
<el-form-item prop="routeName">
<el-input v-model="form.routeName" placeholder="请输入路由名称" />
<span slot="label">
<el-tooltip content="默认不填则和路由地址相同:如地址为:`user`,则名称为`User`(注意:为避免名字的冲突,特殊情况下请自定义,保证唯一性)" placement="top">
<i class="el-icon-question"></i>
</el-tooltip>
路由名称
</span>
</el-form-item>
</el-col> -->
<el-col :span="24">
<el-form-item :label="$t('page.system.menu.sort')+':'" prop="orderNum">
<el-input-number style="width:100%" v-model="form.orderNum" controls-position="right" :min="0" :placeholder="$t('form.placeholderInput')" />
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24" v-if="form.menuType != 'F'">
<el-form-item prop="visible">
<span slot="label">
<!-- <el-tooltip content="选择隐藏则路由将不会出现在侧边栏,但仍然可以访问" placement="top">
<i class="el-icon-question"></i>
</el-tooltip> -->
{{$t('page.system.menu.status')+':'}}
</span>
<el-radio-group v-model="form.visible">
<el-radio key="0" label="0" >{{$t('page.system.menu.statusVisible')}}</el-radio>
<el-radio key="1" label="1" >{{$t('page.system.menu.statusHide')}}</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
<!-- <el-col :span="12">
<el-form-item prop="status">
<span slot="label">
<el-tooltip content="选择停用则路由将不会出现在侧边栏,也不能被访问" placement="top">
<i class="el-icon-question"></i>
</el-tooltip>
菜单状态
</span>
<el-radio-group v-model="form.status">
<el-radio
v-for="dict in dict.type.sys_normal_disable"
:key="dict.value"
:label="dict.value"
>{{dict.label}}</el-radio>
</el-radio-group>
</el-form-item>
</el-col> -->
</el-row>
<el-row>
<el-col :span="24" v-if="form.menuType == 'C'">
<el-form-item prop="component">
<span slot="label">
<!-- <el-tooltip content="访问的组件路径,如:`system/user/index`,默认在`views`目录下" placement="top">
<i class="el-icon-question"></i>
</el-tooltip> -->
{{$t('page.system.menu.comp')+':'}}
</span>
<el-input v-model="form.component" :placeholder="$t('form.placeholderInput')" />
</el-form-item>
</el-col>
<el-col :span="24" v-if="form.menuType != 'M'">
<el-form-item prop="perms">
<el-input v-model="form.perms" :placeholder="$t('form.placeholderInput')" maxlength="100" />
<span slot="label">
<!-- <el-tooltip content="控制器中定义的权限字符,如:@PreAuthorize(`@ss.hasPermi('system:user:list')`)" placement="top">
<i class="el-icon-question"></i>
</el-tooltip> -->
{{$t('page.system.menu.permit')+':'}}
</span>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="24" v-if="form.menuType != 'F'">
<el-form-item :label="$t('page.system.menu.icon')+':'" prop="icon">
<el-popover
placement="bottom-start"
width="460"
trigger="click"
@show="$refs['iconSelect'].reset()"
>
<IconSelect ref="iconSelect" @selected="selected" :active-icon="form.icon" />
<el-input slot="reference" v-model="form.icon" :placeholder="$t('form.placeholderSelect')" readonly>
<svg-icon
v-if="form.icon"
slot="prefix"
:icon-class="form.icon"
style="width: 25px;"
/>
<i v-else slot="prefix" class="el-icon-search el-input__icon" />
</el-input>
</el-popover>
</el-form-item>
</el-col>
</el-row>
<el-row>
<!-- <el-col :span="12" v-if="form.menuType == 'C'">
<el-form-item prop="query">
<el-input v-model="form.query" placeholder="请输入路由参数" maxlength="255" />
<span slot="label">
<el-tooltip content='访问路由的默认传递参数,如:`{"id": 1, "name": "ry"}`' placement="top">
<i class="el-icon-question"></i>
</el-tooltip>
路由参数
</span>
</el-form-item>
</el-col> -->
<el-col :span="24" v-if="form.menuType == 'C'">
<el-form-item prop="isCache">
<span slot="label">
<el-tooltip content="选择是则会被`keep-alive`缓存,需要匹配组件的`name`和地址保持一致" placement="top">
<i class="el-icon-question"></i>
</el-tooltip>
是否缓存
</span>
<el-radio-group v-model="form.isCache">
<el-radio label="0">缓存</el-radio>
<el-radio label="1">不缓存</el-radio>
</el-radio-group>
</el-form-item>
</el-col>
</el-row>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button type="primary" @click="submitForm">{{$t('form.saveConfirm')}}</el-button>
<el-button @click="cancel">{{$t('form.cancel')}}</el-button>
</div>
</el-dialog>
</div>
</template>
<script>
import { listMenu, getMenu, delMenu, addMenu, updateMenu } from "@/api/system/menu"
import Treeselect from "@riophae/vue-treeselect"
import "@riophae/vue-treeselect/dist/vue-treeselect.css"
import IconSelect from "@/components/IconSelect"
export default {
name: "Menu",
dicts: ['sys_show_hide', 'sys_normal_disable'],
components: { Treeselect, IconSelect },
data() {
return {
// 遮罩层
loading: true,
// 显示搜索条件
showSearch: true,
// 菜单表格树数据
menuList: [],
// 菜单树选项
menuOptions: [],
// 弹出层标题
title: "",
// 是否显示弹出层
open: false,
// 是否展开,默认全部折叠
isExpandAll: false,
// 重新渲染表格状态
refreshTable: true,
// 查询参数
queryParams: {
menuName: undefined,
visible: ''
},
// 表单参数
form: {},
// 表单校验
rules: {
menuType: [
{ required: true, message: this.$t('form.placeholderSelect'), trigger: "change" }
],
menuName: [
{ required: true, message: this.$t('form.placeholderInput'), trigger: "blur" }
],
orderNum: [
{ required: true, message: this.$t('form.placeholderInput'), trigger: "blur" }
],
path: [
{ required: true, message: this.$t('form.placeholderInput'), trigger: "blur" }
],
component: [
{ required: true, message: this.$t('form.placeholderInput'), trigger: "blur" }
],
visible: [
{ required: true, message: this.$t('form.placeholderSelect'), trigger: "change" }
],
}
}
},
created() {
this.getList()
},
methods: {
// 选择图标
selected(name) {
this.form.icon = name
},
/** 查询菜单列表 */
getList() {
this.loading = true
listMenu(this.queryParams).then(response => {
this.menuList = this.handleTree(response.data, "menuId")
this.loading = false
})
},
/** 转换菜单数据结构 */
normalizer(node) {
if (node.children && !node.children.length) {
delete node.children
}
return {
id: node.menuId,
label: node.menuName,
children: node.children
}
},
/** 查询菜单下拉树结构 */
getTreeselect() {
listMenu().then(response => {
this.menuOptions = []
const menu = { menuId: 0, menuName: this.$t('page.system.menu.root'), children: [] }
menu.children = this.handleTree(response.data, "menuId")
this.menuOptions.push(menu)
})
},
// 取消按钮
cancel() {
this.open = false
this.reset()
},
// 表单重置
reset() {
this.form = {
menuId: undefined,
parentId: 0,
menuName: undefined,
icon: undefined,
menuType: "M",
orderNum: undefined,
isFrame: "1",
isCache: "0",
visible: "0",
status: "0"
}
this.resetForm("form")
},
/** 搜索按钮操作 */
handleQuery() {
this.getList()
},
/** 重置按钮操作 */
resetQuery() {
this.resetForm("queryForm")
this.handleQuery()
},
/** 新增按钮操作 */
handleAdd(row) {
this.reset()
this.getTreeselect()
if (row != null && row.menuId) {
this.form.parentId = row.menuId
} else {
this.form.parentId = 0
}
this.open = true
this.title = this.$t('page.system.menu.addMenu')
},
/** 展开/折叠操作 */
toggleExpandAll() {
this.refreshTable = false
this.isExpandAll = !this.isExpandAll
this.$nextTick(() => {
this.refreshTable = true
})
},
/** 修改按钮操作 */
handleUpdate(row) {
this.reset()
this.getTreeselect()
getMenu(row.menuId).then(response => {
this.form = response.data
this.open = true
this.title = this.$t('page.system.menu.modifyMenu')
})
},
/** 提交按钮 */
submitForm: function() {
this.$refs["form"].validate(valid => {
if (valid) {
if (this.form.menuId != undefined) {
updateMenu(this.form).then(response => {
// this.$modal.msgSuccess("修改成功")
this.open = false
this.getList()
})
} else {
addMenu(this.form).then(response => {
// this.$modal.msgSuccess("新增成功")
this.open = false
this.getList()
})
}
}
})
},
/** 删除按钮操作 */
handleDelete(row) {
this.$modal.confirm(this.$t('form.confirmDelete')).then(function() {
return delMenu(row.menuId)
}).then(() => {
this.getList()
}).catch(() => {})
}
}
}
</script>