index.vue 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <template>
  2. <div class="system-user-container">
  3. <el-card shadow="hover">
  4. <div class="system-menu-search">
  5. <el-form inline>
  6. <el-form-item label="菜单名称">
  7. <el-input v-model="state.queryParams.title" placeholder="请输入菜单名称" size="default" clearable class="w-50" />
  8. </el-form-item>
  9. <!-- <el-form-item label="组件路径">
  10. <el-input v-model="queryParams.component" placeholder="请输入组件路径" clearable class="w-50" />
  11. </el-form-item> -->
  12. <el-form-item>
  13. <el-button type="primary" class="ml10" @click="handleQuery">
  14. <el-icon>
  15. <ele-Search />
  16. </el-icon>
  17. 查询
  18. </el-button>
  19. <el-button type="success" class="ml10" @click="onOpenAddMenu(null)">
  20. <el-icon>
  21. <ele-FolderAdd />
  22. </el-icon>
  23. 新增菜单
  24. </el-button>
  25. </el-form-item>
  26. </el-form>
  27. </div>
  28. <el-table
  29. :data="state.menuTableData"
  30. default-expand-all
  31. style="width: 100%"
  32. row-key="path"
  33. :tree-props="{ children: 'children', hasChildren: 'hasChildren' }"
  34. v-loading="state.loading"
  35. >
  36. <el-table-column label="菜单名称" show-overflow-tooltip>
  37. <template #default="scope">
  38. <SvgIcon :name="scope.row.icon" />
  39. <span class="ml10">{{ scope.row.title }}</span>
  40. </template>
  41. </el-table-column>
  42. <el-table-column prop="path" label="路由路径" show-overflow-tooltip></el-table-column>
  43. <el-table-column label="组件路径" prop="component" show-overflow-tooltip></el-table-column>
  44. <el-table-column label="排序" prop="weigh" width="80" align="center"></el-table-column>
  45. <el-table-column label="类型" width="80" align="center">
  46. <template #default="scope">
  47. <el-tag :type="scope.row.menuType === 0 ? 'danger' : scope.row.menuType === 1 ? 'success' : 'warning'" size="small">{{
  48. scope.row.menuType === 0 ? '目录' : scope.row.menuType === 1 ? '菜单' : '按钮'
  49. }}</el-tag>
  50. </template>
  51. </el-table-column>
  52. <el-table-column prop="isHide" label="显示状态" align="center" width="120">
  53. <template #default="{ row }">
  54. {{ row.isHide ? '隐藏' : '显示' }}
  55. </template>
  56. </el-table-column>
  57. <el-table-column label="操作" width="200" align="center" fixed="right">
  58. <template #default="scope">
  59. <el-button v-if="!scope.row.menuType" size="small" type="text" @click="onOpenAddMenu(scope.row)">新增</el-button>
  60. <el-button size="small" text type="warning" @click="onOpenEditMenu(scope.row)">修改</el-button>
  61. <el-button size="small" text type="danger" @click="onTabelRowDel(scope.row)">删除</el-button>
  62. <el-dropdown v-if="scope.row.menuType">
  63. <el-button type="text" size="small" style="margin-top: 1px; margin-left: 10px"
  64. >更多
  65. <el-icon>
  66. <ele-ArrowDown />
  67. </el-icon>
  68. </el-button>
  69. <template #dropdown>
  70. <el-dropdown-menu>
  71. <el-dropdown-item @click.native="authOpen(scope.row, 'buttonAuthorizeList')">按钮权限</el-dropdown-item>
  72. <el-dropdown-item @click.native="authOpen(scope.row, 'listAuthorizeList')">列表权限</el-dropdown-item>
  73. </el-dropdown-menu>
  74. </template>
  75. </el-dropdown>
  76. </template>
  77. </el-table-column>
  78. </el-table>
  79. </el-card>
  80. <EditMenu ref="editMenuRef" @menuList="menuList" :menu="state.menuTableData" :visibleOptions="sys_show_hide" :acType="acType" />
  81. <ButtonAuthorizeListDrawer ref="buttonAuthorizeList" />
  82. <ListAuthorizeListDrawer ref="listAuthorizeList" />
  83. <ApiAuthorizeListDrawer ref="apiAuthorizeList" />
  84. </div>
  85. </template>
  86. <script lang="ts" setup>
  87. import { ref, reactive, onBeforeMount, getCurrentInstance } from 'vue';
  88. import { ElMessageBox, ElMessage } from 'element-plus';
  89. import EditMenu from '/@/views/system/menu/component/editMenu.vue';
  90. import api from '/@/api/system';
  91. import ButtonAuthorizeListDrawer from './component/btn.vue';
  92. import ListAuthorizeListDrawer from './component/list.vue';
  93. const editMenuRef = ref();
  94. const buttonAuthorizeList = ref();
  95. const listAuthorizeList = ref();
  96. const state = reactive({
  97. loading:false,
  98. queryParams: {
  99. title: '',
  100. component: '',
  101. status: -1,
  102. },
  103. menuTableData: [],
  104. });
  105. const { proxy } = getCurrentInstance() as any;
  106. const { sys_show_hide } = proxy.useDict('sys_show_hide');
  107. const acType = ref('add');
  108. // 打开新增菜单弹窗
  109. const onOpenAddMenu = (row: any) => {
  110. acType.value = 'add';
  111. editMenuRef.value.openDialog(row);
  112. };
  113. // 打开编辑菜单弹窗
  114. const onOpenEditMenu = (row: any) => {
  115. acType.value = 'edit';
  116. editMenuRef.value.openDialog(row);
  117. };
  118. // 打开按钮权限抽下
  119. const authOpen = (row: any, key: string) => {
  120. if (key === 'buttonAuthorizeList') {
  121. return buttonAuthorizeList.value.open(row);
  122. }
  123. if (key === 'listAuthorizeList') {
  124. return listAuthorizeList.value.open(row);
  125. }
  126. };
  127. // 删除当前行
  128. const onTabelRowDel = (row: any) => {
  129. ElMessageBox.confirm(`此操作将永久删除菜单:“${row.title}”, 是否继续?`, '提示', {
  130. confirmButtonText: '删除',
  131. cancelButtonText: '取消',
  132. type: 'warning',
  133. })
  134. .then(() => {
  135. api.menu.del(row.id).then(() => {
  136. ElMessage.success('删除成功');
  137. proxy.$refs['editMenuRef'].resetMenuSession();
  138. menuList();
  139. });
  140. })
  141. .catch(() => {});
  142. };
  143. onBeforeMount(() => {
  144. menuList();
  145. });
  146. const handleQuery = () => {
  147. menuList();
  148. };
  149. const menuList = () => {
  150. state.loading = true;
  151. api.menu
  152. .getList(state.queryParams)
  153. .then((res: any) => {
  154. // console.log({...res[0]})
  155. state.menuTableData = res || [];
  156. })
  157. .finally(() => (state.loading = false));
  158. };
  159. </script>