|
|
- <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) {
- debugger
- // this.saveSimpleLog({name:'',nameEn:'',jcmc:'新增菜单',jcmcEn:'Add Menu'})
- 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.saveSimpleLog({name:row.menuName,nameEn:row.menuName,jcmc:'编辑菜单',jcmcEn:'Edit Menu'})
- 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.saveSimpleLog({name:row.menuName,nameEn:row.menuName,jcmc:'删除菜单',jcmcEn:'Remove Menu'})
- this.$modal.confirm(this.$t('form.confirmDelete')).then(function() {
- return delMenu(row.menuId)
- }).then(() => {
- this.getList()
- }).catch(() => {})
- }
- }
- }
- </script>
|