优化角色菜单选择

This commit is contained in:
gyq
2025-11-20 11:38:56 +08:00
parent 09a6f8b067
commit f51d0d44e4

View File

@@ -3,12 +3,7 @@
<div class="search-bar"> <div class="search-bar">
<el-form ref="queryFormRef" :model="queryParams" :inline="true"> <el-form ref="queryFormRef" :model="queryParams" :inline="true">
<el-form-item prop="keywords" label="关键字"> <el-form-item prop="keywords" label="关键字">
<el-input <el-input v-model="queryParams.key" placeholder="角色名称" clearable @keyup.enter="handleQuery" />
v-model="queryParams.key"
placeholder="角色名称"
clearable
@keyup.enter="handleQuery"
/>
</el-form-item> </el-form-item>
<el-form-item> <el-form-item>
@@ -26,14 +21,8 @@
</el-button> --> </el-button> -->
</div> </div>
<el-table <el-table ref="dataTableRef" v-loading="loading" :data="roleList" highlight-current-row :border="true"
ref="dataTableRef" @selection-change="handleSelectionChange">
v-loading="loading"
:data="roleList"
highlight-current-row
:border="true"
@selection-change="handleSelectionChange"
>
<!-- <el-table-column type="selection" width="55" align="center" /> --> <!-- <el-table-column type="selection" width="55" align="center" /> -->
<el-table-column label="角色名称" prop="name" /> <el-table-column label="角色名称" prop="name" />
<el-table-column label="角色级别" prop="level" /> <el-table-column label="角色级别" prop="level" />
@@ -41,53 +30,25 @@
<el-table-column label="创建日期" prop="createTime" /> <el-table-column label="创建日期" prop="createTime" />
<el-table-column fixed="right" label="操作" width="220"> <el-table-column fixed="right" label="操作" width="220">
<template #default="scope"> <template #default="scope">
<el-button <el-button type="primary" size="small" link icon="position" @click="handleOpenAssignPermDialog(scope.row)">
type="primary"
size="small"
link
icon="position"
@click="handleOpenAssignPermDialog(scope.row)"
>
分配菜单 分配菜单
</el-button> </el-button>
<el-button <el-button type="primary" size="small" link icon="edit" @click="handleOpenDialog(scope.row)">
type="primary"
size="small"
link
icon="edit"
@click="handleOpenDialog(scope.row)"
>
编辑 编辑
</el-button> </el-button>
<el-button <el-button type="danger" size="small" link icon="delete" @click="handleDelete(scope.row.id)">
type="danger"
size="small"
link
icon="delete"
@click="handleDelete(scope.row.id)"
>
删除 删除
</el-button> </el-button>
</template> </template>
</el-table-column> </el-table-column>
</el-table> </el-table>
<pagination <pagination v-if="total > 0" v-model:total="total" v-model:page="queryParams.page"
v-if="total > 0" v-model:limit="queryParams.size" @pagination="handleQuery" />
v-model:total="total"
v-model:page="queryParams.page"
v-model:limit="queryParams.size"
@pagination="handleQuery"
/>
</el-card> </el-card>
<!-- 角色表单弹窗 --> <!-- 角色表单弹窗 -->
<el-dialog <el-dialog v-model="dialog.visible" :title="dialog.title" width="500px" @close="handleCloseDialog">
v-model="dialog.visible"
:title="dialog.title"
width="500px"
@close="handleCloseDialog"
>
<el-form ref="addRequestRef" :model="formData" :rules="rules" label-width="100px"> <el-form ref="addRequestRef" :model="formData" :rules="rules" label-width="100px">
<el-form-item label="角色名称" prop="name"> <el-form-item label="角色名称" prop="name">
<el-input v-model="formData.name" placeholder="请输入角色名称" /> <el-input v-model="formData.name" placeholder="请输入角色名称" />
@@ -153,11 +114,7 @@
</template> </template>
{{ isExpanded ? "收缩" : "展开" }} {{ isExpanded ? "收缩" : "展开" }}
</el-button> </el-button>
<el-checkbox <el-checkbox v-model="parentChildLinked" class="ml-5" @change="handleparentChildLinkedChange">
v-model="parentChildLinked"
class="ml-5"
@change="handleparentChildLinkedChange"
>
父子联动 父子联动
</el-checkbox> </el-checkbox>
@@ -174,33 +131,18 @@
</div> </div>
</template> </template>
<div class="u-relative" style="overflow-x: hidden"> <div class="u-relative" style="overflow-x: hidden">
<el-tree <el-tree ref="permTreeRef" node-key="value" show-checkbox :data="menuPermOptions"
ref="permTreeRef" :default-checked-keys="adminMenuIdList" :filter-node-method="handlePermFilter" :default-expand-all="true"
node-key="value" :check-strictly="!parentChildLinked" class="mt-5">
show-checkbox
:data="menuPermOptions"
:default-checked-keys="adminMenuIdList"
:filter-node-method="handlePermFilter"
:default-expand-all="true"
:check-strictly="!parentChildLinked"
class="mt-5"
>
<template #default="{ data }"> <template #default="{ data }">
{{ data.label }} {{ data.label }}
</template> </template>
</el-tree> </el-tree>
<div <div class="cashMenuIdList" :style="{
class="cashMenuIdList" transform: `translateX(${(platformType == 1 ? 0 : 1) * 100}%)`,
:style="{ }">
transform: `translateX(${(platformType == 1 ? 0 : 1) * 100}%)`,
}"
>
<el-checkbox-group v-model="cashMenuIdList"> <el-checkbox-group v-model="cashMenuIdList">
<el-checkbox <el-checkbox v-for="(item, index) in casher_windows_menus" :key="index" :value="item.menuId">
v-for="(item, index) in casher_windows_menus"
:key="index"
:value="item.menuId"
>
{{ item.name }} {{ item.name }}
</el-checkbox> </el-checkbox>
</el-checkbox-group> </el-checkbox-group>
@@ -327,6 +269,7 @@ async function handleOpenDialog(row: SysRole) {
dialog.title = "修改角色"; dialog.title = "修改角色";
//获取角色菜单列表 //获取角色菜单列表
const data = await RoleApi.getMenu(row.id, platformType.value); const data = await RoleApi.getMenu(row.id, platformType.value);
// const data = await RoleApi.getList(row.id, platformType.value);
console.log(data); console.log(data);
Object.assign(formData, row); Object.assign(formData, row);
formData.menuIdList = data; formData.menuIdList = data;
@@ -435,8 +378,8 @@ async function getCashMenus() {
} }
// 获取所有的菜单 // 获取所有的菜单
async function getMenuPermOptions() { async function getMenuPermOptions() {
let arr = // let arr = shopUser.userInfo.account === "admin" ? await MenuAPI.getList() : await MenuAPI.getRoutes();
shopUser.userInfo.account === "admin" ? await MenuAPI.getList() : await MenuAPI.getRoutes(); let arr = await MenuAPI.getList();
menuPermOptions.value = returnMenu(arr); menuPermOptions.value = returnMenu(arr);
} }
getMenuPermOptions(); getMenuPermOptions();
@@ -455,8 +398,8 @@ async function handleOpenAssignPermDialog(row: SysRole) {
getMenuIds(roleId); getMenuIds(roleId);
} }
} }
// 回显角色已拥有的菜单
// 回显角色已拥有的菜单
function getMenuIds(roleId: number) { function getMenuIds(roleId: number) {
roleId = roleId ? roleId : dialog.row.id; roleId = roleId ? roleId : dialog.row.id;
if (!roleId) { if (!roleId) {