feat: 【ele】配置管理新增批量删除
							parent
							
								
									c874f754b8
								
							
						
					
					
						commit
						79011799dc
					
				|  | @ -54,6 +54,11 @@ export function deleteConfig(id: number) { | |||
|   return requestClient.delete(`/infra/config/delete?id=${id}`); | ||||
| } | ||||
| 
 | ||||
| /** 批量删除参数 */ | ||||
| export function deleteConfigList(ids: number[]) { | ||||
|   return requestClient.delete(`/infra/config/delete-list?ids=${ids.join(',')}`); | ||||
| } | ||||
| 
 | ||||
| /** 导出参数 */ | ||||
| export function exportConfig(params: any) { | ||||
|   return requestClient.download('/infra/config/export', { | ||||
|  |  | |||
|  | @ -126,6 +126,7 @@ export function useGridColumns<T = InfraConfigApi.Config>( | |||
|   onActionClick: OnActionClickFn<T>, | ||||
| ): VxeTableGridOptions['columns'] { | ||||
|   return [ | ||||
|     { type: 'checkbox', width: 40 }, | ||||
|     { | ||||
|       field: 'id', | ||||
|       title: '参数主键', | ||||
|  |  | |||
|  | @ -5,14 +5,20 @@ import type { | |||
| } from '#/adapter/vxe-table'; | ||||
| import type { InfraConfigApi } from '#/api/infra/config'; | ||||
| 
 | ||||
| import { ref } from 'vue'; | ||||
| 
 | ||||
| import { Page, useVbenModal } from '@vben/common-ui'; | ||||
| import { Download, Plus } from '@vben/icons'; | ||||
| import { downloadFileFromBlobPart } from '@vben/utils'; | ||||
| import { downloadFileFromBlobPart, isEmpty } from '@vben/utils'; | ||||
| 
 | ||||
| import { ElButton, ElLoading, ElMessage } from 'element-plus'; | ||||
| import { ElLoading, ElMessage } from 'element-plus'; | ||||
| 
 | ||||
| import { useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||
| import { deleteConfig, exportConfig, getConfigPage } from '#/api/infra/config'; | ||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||
| import { | ||||
|   deleteConfig, | ||||
|   deleteConfigList, | ||||
|   exportConfig, | ||||
|   getConfigPage, | ||||
| } from '#/api/infra/config'; | ||||
| import { $t } from '#/locales'; | ||||
| 
 | ||||
| import { useGridColumns, useGridFormSchema } from './data'; | ||||
|  | @ -52,15 +58,39 @@ async function onDelete(row: InfraConfigApi.Config) { | |||
|   }); | ||||
|   try { | ||||
|     await deleteConfig(row.id as number); | ||||
|     // TODO @puhui999:close 是不是放在 finally 里面更好? | ||||
|     loadingInstance.close(); | ||||
|     ElMessage.success($t('ui.actionMessage.deleteSuccess', [row.name])); | ||||
|     onRefresh(); | ||||
|   } catch { | ||||
|   } finally { | ||||
|     loadingInstance.close(); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /** 批量删除参数 */ | ||||
| async function onDeleteBatch() { | ||||
|   const loadingInstance = ElLoading.service({ | ||||
|     text: $t('ui.actionMessage.deleting'), | ||||
|     fullscreen: true, | ||||
|   }); | ||||
|   try { | ||||
|     await deleteConfigList(checkedIds.value); | ||||
|     loadingInstance.close(); | ||||
|     ElMessage.success($t('ui.actionMessage.deleteSuccess')); | ||||
|     onRefresh(); | ||||
|   } finally { | ||||
|     loadingInstance.close(); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| const checkedIds = ref<number[]>([]); | ||||
| function handleRowCheckboxChange({ | ||||
|   records, | ||||
| }: { | ||||
|   records: InfraConfigApi.Config[]; | ||||
| }) { | ||||
|   checkedIds.value = records.map((item) => item.id as number); | ||||
| } | ||||
| 
 | ||||
| /** 表格操作按钮的回调函数 */ | ||||
| function onActionClick({ | ||||
|   code, | ||||
|  | @ -105,6 +135,10 @@ const [Grid, gridApi] = useVbenVxeGrid({ | |||
|       search: true, | ||||
|     }, | ||||
|   } as VxeTableGridOptions<InfraConfigApi.Config>, | ||||
|   gridEvents: { | ||||
|     checkboxAll: handleRowCheckboxChange, | ||||
|     checkboxChange: handleRowCheckboxChange, | ||||
|   }, | ||||
| }); | ||||
| </script> | ||||
| 
 | ||||
|  | @ -113,23 +147,32 @@ const [Grid, gridApi] = useVbenVxeGrid({ | |||
|     <FormModal @success="onRefresh" /> | ||||
|     <Grid table-title="参数列表"> | ||||
|       <template #toolbar-tools> | ||||
|         <ElButton | ||||
|           type="primary" | ||||
|           @click="onCreate" | ||||
|           v-access:code="['infra:config:create']" | ||||
|         > | ||||
|           <Plus class="size-5" /> | ||||
|           {{ $t('ui.actionTitle.create', ['参数']) }} | ||||
|         </ElButton> | ||||
|         <ElButton | ||||
|           type="primary" | ||||
|           class="ml-2" | ||||
|           @click="onExport" | ||||
|           v-access:code="['infra:config:export']" | ||||
|         > | ||||
|           <Download class="size-5" /> | ||||
|           {{ $t('ui.actionTitle.export') }} | ||||
|         </ElButton> | ||||
|         <TableAction | ||||
|           :actions="[ | ||||
|             { | ||||
|               label: $t('ui.actionTitle.create', ['参数']), | ||||
|               type: 'primary', | ||||
|               icon: ACTION_ICON.ADD, | ||||
|               auth: ['infra:config:create'], | ||||
|               onClick: onCreate, | ||||
|             }, | ||||
|             { | ||||
|               label: $t('ui.actionTitle.export'), | ||||
|               type: 'primary', | ||||
|               icon: ACTION_ICON.DOWNLOAD, | ||||
|               auth: ['infra:config:export'], | ||||
|               onClick: onExport, | ||||
|             }, | ||||
|             { | ||||
|               label: $t('ui.actionTitle.deleteBatch'), | ||||
|               type: 'danger', | ||||
|               icon: ACTION_ICON.DELETE, | ||||
|               disabled: isEmpty(checkedIds), | ||||
|               auth: ['infra:config:delete'], | ||||
|               onClick: onDeleteBatch, | ||||
|             }, | ||||
|           ]" | ||||
|         /> | ||||
|       </template> | ||||
|     </Grid> | ||||
|   </Page> | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	 puhui999
						puhui999