From 7d0199cc57aecbc88b19ec8bab2db49ca2be31bb Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期四, 13 十一月 2025 16:13:20 +0800
Subject: [PATCH] fix: bug
---
src/views/Permission/RoleManage.vue | 32 ++++++++++++++++++++++++++------
1 files changed, 26 insertions(+), 6 deletions(-)
diff --git a/src/views/Permission/RoleManage.vue b/src/views/Permission/RoleManage.vue
index 887b4f1..dfd95e2 100644
--- a/src/views/Permission/RoleManage.vue
+++ b/src/views/Permission/RoleManage.vue
@@ -52,27 +52,44 @@
import { EnumUserType } from '@/constants';
import DialogAuthorizeV2 from './components/dialogAuthorizeV2.vue';
import * as roleServices from '@/services/api/role';
+import { useQueryClient } from '@tanstack/vue-query';
defineOptions({
name: 'RoleManage',
});
const operationBtnMap: Record<string, OperationBtnType> = {
- editBtn: { emits: { onClick: (role) => openDialog(role) } },
- delBtn: { emits: { onClick: (role) => handleDeleteRole(role) }, props: { type: 'danger' } },
- authorize: { emits: { onClick: (role) => openAuthorizeDialog(role) } },
+ editBtn: {
+ emits: { onClick: (role) => openDialog(role) },
+ extraProps: {
+ hide: (role: API.GetRolesQueryResultItem) => role.isPublic,
+ },
+ },
+ delBtn: {
+ emits: { onClick: (role) => handleDeleteRole(role) },
+ props: { type: 'danger' },
+ extraProps: {
+ hide: (role: API.GetRolesQueryResultItem) => role.isPublic,
+ },
+ },
+ authorize: {
+ emits: { onClick: (role) => openAuthorizeDialog(role) },
+ extraProps: {
+ hide: (role: API.GetRolesQueryResultItem) => role.isPublic,
+ },
+ },
// member: { emits: { onClick: (role) => openMemberDialog(role) } },
disabledBtn: {
emits: { onClick: (role) => roleEnableOrForbid(role) },
props: { type: 'danger' },
extraProps: {
- hide: (row) => row.isDisabled,
+ hide: (row: API.GetRolesQueryResultItem) => !(!row.isPublic && !row.isDisabled),
},
},
enableBtn: {
emits: { onClick: (role) => roleEnableOrForbid(role) },
extraProps: {
- hide: (row) => !row.isDisabled,
+ hide: (row: API.GetRolesQueryResultItem) => !(row.isDisabled && !row.isPublic),
},
},
};
@@ -168,7 +185,7 @@
enterpriseType: AppLocalConfig.enterpriseType,
},
});
-
+const queryClient = useQueryClient();
async function handleAddOrEdit() {
try {
const isEdit = editForm.id;
@@ -193,6 +210,7 @@
if (res) {
Message.successMessage('鎿嶄綔鎴愬姛');
getList(isEdit ? paginationState.pageIndex : 1);
+ queryClient.invalidateQueries(['userServices/getUserInfoRoles']);
}
} catch (error) {}
}
@@ -207,6 +225,7 @@
if (res) {
Message.successMessage('鎿嶄綔鎴愬姛');
getList(paginationState.pageIndex);
+ queryClient.invalidateQueries(['userServices/getUserInfoRoles']);
}
} catch (error) {}
}
@@ -221,6 +240,7 @@
if (res) {
Message.successMessage('鎿嶄綔鎴愬姛');
getList(paginationState.pageIndex);
+ queryClient.invalidateQueries(['userServices/getUserInfoRoles']);
return !!res;
}
} catch (error) {}
--
Gitblit v1.9.1