update: 权限管理
This commit is contained in:
		
							parent
							
								
									1efe058322
								
							
						
					
					
						commit
						dc6ad3b081
					
				|  | @ -2,5 +2,11 @@ import server from '@/utils/request'; | ||||||
| 
 | 
 | ||||||
| // 获取权限列表
 | // 获取权限列表
 | ||||||
| export const getPermission_api = (data:object) => server.post(`/permission/_query/`,data); | export const getPermission_api = (data:object) => server.post(`/permission/_query/`,data); | ||||||
| // 修改权限信息
 | // 新增时校验标识id是否可用
 | ||||||
| export const editPermission_api = (data:object) => server.patch(`/permission`,data); | export const checkId_api = (data:object) => server.get(`/permission/id/_validate`,data); | ||||||
|  | // 修改权限
 | ||||||
|  | export const editPermission_api = (data:object) => server.patch(`/permission`,data); | ||||||
|  | // 添加权限
 | ||||||
|  | export const addPermission_api = (data:object) => server.post(`/permission`,data); | ||||||
|  | // 删除权限
 | ||||||
|  | export const delPermission_api = (id:string) => server.remove(`/permission/${id}`); | ||||||
|  | @ -9,7 +9,10 @@ | ||||||
|         <a-form ref="formRef" :model="form.data" layout="vertical"> |         <a-form ref="formRef" :model="form.data" layout="vertical"> | ||||||
|             <a-form-item |             <a-form-item | ||||||
|                 name="id" |                 name="id" | ||||||
|                 :rules="[{ required: true, message: '请输入标识' }]" |                 :rules="[ | ||||||
|  |                     { required: true, message: '请输入标识(ID)' }, | ||||||
|  |                     { validator: form.rules.idCheck, trigger: 'blur' }, | ||||||
|  |                 ]" | ||||||
|                 class="question-item" |                 class="question-item" | ||||||
|             > |             > | ||||||
|                 <template #label> |                 <template #label> | ||||||
|  | @ -62,6 +65,7 @@ | ||||||
|                 </template> |                 </template> | ||||||
|                 <template v-else-if="column.key === 'act'"> |                 <template v-else-if="column.key === 'act'"> | ||||||
|                     <a-button |                     <a-button | ||||||
|  |                         class="delete-btn" | ||||||
|                         style="padding: 0" |                         style="padding: 0" | ||||||
|                         type="link" |                         type="link" | ||||||
|                         @click="table.clickRemove(index)" |                         @click="table.clickRemove(index)" | ||||||
|  | @ -71,17 +75,17 @@ | ||||||
|                 </template> |                 </template> | ||||||
|             </template> |             </template> | ||||||
|         </a-table> |         </a-table> | ||||||
|         <div class="pager"> |         <div class="pager" v-show="pager.total > pager.pageSize"> | ||||||
|  |             <a-select v-model:value="pager.current" style="width: 60px"> | ||||||
|  |                 <a-select-option v-for="(val, i) in pageArr" :value="i + 1">{{ | ||||||
|  |                     i + 1 | ||||||
|  |                 }}</a-select-option> | ||||||
|  |             </a-select> | ||||||
|             <a-pagination |             <a-pagination | ||||||
|                 v-model:current="pager.current" |                 v-model:current="pager.current" | ||||||
|                 :page-size="pager.pageSize" |                 :page-size="pager.pageSize" | ||||||
|                 :total="pager.total" |                 :total="pager.total" | ||||||
|             /> |             /> | ||||||
|             <a-select v-model:value="pager.current" style="width: 60px"> |  | ||||||
|                 <a-select-option v-for="(val,i) in pageArr" :value="i + 1">{{ |  | ||||||
|                     i + 1 |  | ||||||
|                 }}</a-select-option> |  | ||||||
|             </a-select> |  | ||||||
|         </div> |         </div> | ||||||
| 
 | 
 | ||||||
|         <a-button type="dashed" style="width: 100%" @click="table.clickAdd"> |         <a-button type="dashed" style="width: 100%" @click="table.clickAdd"> | ||||||
|  | @ -105,27 +109,40 @@ | ||||||
| import { FormInstance, message } from 'ant-design-vue'; | import { FormInstance, message } from 'ant-design-vue'; | ||||||
| import { DeleteOutlined, PlusOutlined } from '@ant-design/icons-vue'; | import { DeleteOutlined, PlusOutlined } from '@ant-design/icons-vue'; | ||||||
| import { QuestionCircleOutlined } from '@ant-design/icons-vue'; | import { QuestionCircleOutlined } from '@ant-design/icons-vue'; | ||||||
|  | import { Rule } from 'ant-design-vue/es/form'; | ||||||
|  | 
 | ||||||
|  | import { | ||||||
|  |     checkId_api, | ||||||
|  |     editPermission_api, | ||||||
|  |     addPermission_api, | ||||||
|  | } from '@/api/system/permission'; | ||||||
| 
 | 
 | ||||||
| const defaultAction = [ | const defaultAction = [ | ||||||
|     { action: 'query', name: '查询', describe: '查询' }, |     { action: 'query', name: '查询', describe: '查询' }, | ||||||
|     { action: 'save', name: '保存', describe: '保存' }, |     { action: 'save', name: '保存', describe: '保存' }, | ||||||
|     { action: 'delete', name: '删除', describe: '删除' }, |     { action: 'delete', name: '删除', describe: '删除' }, | ||||||
| ]; | ]; | ||||||
|  | const emits = defineEmits(['refresh']); | ||||||
| // 弹窗相关 | // 弹窗相关 | ||||||
| const dialog = reactive({ | const dialog = reactive({ | ||||||
|     title: '', |     title: '', | ||||||
|     visible: false, |     visible: false, | ||||||
|     handleOk: () => { |     handleOk: () => { | ||||||
|         formRef.value?.validate().then(() => console.log('success')); |         formRef.value?.validate().then(() => { | ||||||
|  |             form.submit(); | ||||||
|  |         }); | ||||||
|     }, |     }, | ||||||
|     // 控制弹窗的打开与关闭 |     // 控制弹窗的打开与关闭 | ||||||
|     changeVisible: (status: boolean, defaultForm: any = {}) => { |     changeVisible: (status: boolean, defaultForm: any = {}) => { | ||||||
|         form.data = { name: '', description: '', ...defaultForm }; |  | ||||||
|         dialog.title = defaultForm.id ? '编辑' : '新增'; |         dialog.title = defaultForm.id ? '编辑' : '新增'; | ||||||
|  |         form.data = { name: '', ...defaultForm }; | ||||||
|         table.data = defaultForm.id ? defaultForm.actions : [...defaultAction]; |         table.data = defaultForm.id ? defaultForm.actions : [...defaultAction]; | ||||||
|         pager.total = table.data.length; |         pager.total = table.data.length; | ||||||
|         pager.current = 1; |         pager.current = 1; | ||||||
|         dialog.visible = status; |         dialog.visible = status; | ||||||
|  |         nextTick(() => { | ||||||
|  |             formRef.value?.clearValidate(); | ||||||
|  |         }); | ||||||
|     }, |     }, | ||||||
| }); | }); | ||||||
| // 表单相关 | // 表单相关 | ||||||
|  | @ -136,6 +153,46 @@ const form = reactive({ | ||||||
|         name: '', |         name: '', | ||||||
|         id: '', |         id: '', | ||||||
|     }, |     }, | ||||||
|  |     rules: { | ||||||
|  |         // 校验标识是否可用 | ||||||
|  |         idCheck: (_rule: Rule, id: string, cb: Function) => { | ||||||
|  |             if (!id) return cb('请输入标识(ID)'); | ||||||
|  |             if (dialog.title === '编辑') return cb(); | ||||||
|  |             checkId_api({ id }) | ||||||
|  |                 .then((resp: any) => { | ||||||
|  |                     if (resp.status === 200 && !resp.result.passed) | ||||||
|  |                         cb(resp.result.reason); | ||||||
|  |                     else cb(); | ||||||
|  |                 }) | ||||||
|  |                 .catch(() => cb('验证失败')); | ||||||
|  | 
 | ||||||
|  |             // return new Promise((resolve) => { | ||||||
|  |             //     checkId_api({ id }) | ||||||
|  |             //         .then((resp: any) => { | ||||||
|  |             //             if (resp.status === 200 && !resp.result.passed) | ||||||
|  |             //                 resolve(resp.result.reason); | ||||||
|  |             //             else resolve(''); | ||||||
|  |             //         }) | ||||||
|  |             //         .catch(() => resolve('验证失败')); | ||||||
|  |             // }); | ||||||
|  |         }, | ||||||
|  |     }, | ||||||
|  |     submit: () => { | ||||||
|  |         const params = { | ||||||
|  |             ...form.data, | ||||||
|  |             actions: table.data.filter((item: any) => item.action && item.name), | ||||||
|  |         }; | ||||||
|  |         const api = | ||||||
|  |             dialog.title === '编辑' ? editPermission_api : addPermission_api; | ||||||
|  | 
 | ||||||
|  |         api(params).then((resp) => { | ||||||
|  |             if (resp.status === 200) { | ||||||
|  |                 message.error('操作成功'); | ||||||
|  |                 emits('refresh'); | ||||||
|  |                 dialog.visible = false; | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  |     }, | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| const table = reactive({ | const table = reactive({ | ||||||
|  | @ -144,21 +201,26 @@ const table = reactive({ | ||||||
|             title: '-', |             title: '-', | ||||||
|             dataIndex: 'index', |             dataIndex: 'index', | ||||||
|             key: 'index', |             key: 'index', | ||||||
|  |             width:80, | ||||||
|  |             align:'center' | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             title: '操作类型', |             title: '操作类型', | ||||||
|             dataIndex: 'action', |             dataIndex: 'action', | ||||||
|             key: 'action', |             key: 'action', | ||||||
|  |             width: 220 | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             title: '名称', |             title: '名称', | ||||||
|             dataIndex: 'name', |             dataIndex: 'name', | ||||||
|             key: 'name', |             key: 'name', | ||||||
|  |             width: 220 | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             title: '说明', |             title: '说明', | ||||||
|             dataIndex: 'describe', |             dataIndex: 'describe', | ||||||
|             key: 'describe', |             key: 'describe', | ||||||
|  |             width: 220 | ||||||
|         }, |         }, | ||||||
|         { |         { | ||||||
|             title: '操作', |             title: '操作', | ||||||
|  | @ -230,5 +292,30 @@ defineExpose({ | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |     .ant-table { | ||||||
|  |         color: #ff4d4f; | ||||||
|  | 
 | ||||||
|  |         .ant-table-tbody { | ||||||
|  |             color: #ff4d4f; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     .delete-btn { | ||||||
|  |         color: #000000d9; | ||||||
|  |         &:hover{ | ||||||
|  |             color: #415ed1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     .pager { | ||||||
|  |         display: flex; | ||||||
|  |         justify-content: center; | ||||||
|  |         margin-bottom: 12px; | ||||||
|  |         .ant-pagination { | ||||||
|  |             margin-left: 8px; | ||||||
|  |             :deep(.ant-pagination-item) { | ||||||
|  |                 display: none; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
| } | } | ||||||
| </style> | </style> | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| <template> | <template> | ||||||
|     <div class="permission-container"> |     <div class="permission-container"> | ||||||
|         <Search :columns="query.columns" /> |         <Search :columns="query.columns" @search="query.search" /> | ||||||
| 
 | 
 | ||||||
|         <JTable |         <JTable | ||||||
|             ref="tableRef" |             ref="tableRef" | ||||||
|  | @ -73,7 +73,7 @@ | ||||||
|         </JTable> |         </JTable> | ||||||
| 
 | 
 | ||||||
|         <div class="dialogs"> |         <div class="dialogs"> | ||||||
|             <EditDialog ref="editDialogRef" /> |             <EditDialog ref="editDialogRef" @refresh="table.refresh" /> | ||||||
|         </div> |         </div> | ||||||
|     </div> |     </div> | ||||||
| </template> | </template> | ||||||
|  | @ -89,7 +89,7 @@ import { | ||||||
|     StopOutlined, |     StopOutlined, | ||||||
|     PlayCircleOutlined, |     PlayCircleOutlined, | ||||||
| } from '@ant-design/icons-vue'; | } from '@ant-design/icons-vue'; | ||||||
| import { getPermission_api, editPermission_api } from '@/api/system/permission'; | import { getPermission_api, editPermission_api, delPermission_api } from '@/api/system/permission'; | ||||||
| 
 | 
 | ||||||
| const editDialogRef = ref(); // 新增弹窗实例 | const editDialogRef = ref(); // 新增弹窗实例 | ||||||
| const tableRef = ref<Record<string, any>>({}); // 表格实例 | const tableRef = ref<Record<string, any>>({}); // 表格实例 | ||||||
|  | @ -138,6 +138,9 @@ const query = reactive({ | ||||||
|         }, |         }, | ||||||
|     ], |     ], | ||||||
|     params: {}, |     params: {}, | ||||||
|  |     search: (params:object)=>{ | ||||||
|  |         query.params = params | ||||||
|  |     } | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| // 表格 | // 表格 | ||||||
|  | @ -181,12 +184,12 @@ const table = reactive({ | ||||||
|         }); |         }); | ||||||
|     }, |     }, | ||||||
|     clickDel: (row: any) => { |     clickDel: (row: any) => { | ||||||
|         // delRole_api(row.id).then((resp: any) => { |         delPermission_api(row.id).then((resp: any) => { | ||||||
|         //     if (resp.status === 200) { |             if (resp.status === 200) { | ||||||
|         //         tableRef.value?.reload(); |                 tableRef.value?.reload(); | ||||||
|         //         message.success('操作成功!'); |                 message.success('操作成功!'); | ||||||
|         //     } |             } | ||||||
|         // }); |         }); | ||||||
|     }, |     }, | ||||||
|     refresh: () => { |     refresh: () => { | ||||||
|         tableRef.value.reload(); |         tableRef.value.reload(); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue