Merge branch 'dev' into dev-new
# Conflicts: # apps/web-antd/src/views/infra/codegen/index.vue # apps/web-antd/src/views/infra/job/index.vuepull/144/head
						commit
						34f41790c2
					
				|  | @ -148,3 +148,10 @@ export function deleteCodegenTable(tableId: number) { | ||||||
|     params: { tableId }, |     params: { tableId }, | ||||||
|   }); |   }); | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除代码生成表定义 */ | ||||||
|  | export function deleteCodegenTableList(tableIds: number[]) { | ||||||
|  |   return requestClient.delete( | ||||||
|  |     `/infra/codegen/delete-list?tableIds=${tableIds.join(',')}`, | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | @ -54,6 +54,11 @@ export function deleteConfig(id: number) { | ||||||
|   return requestClient.delete(`/infra/config/delete?id=${id}`); |   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) { | export function exportConfig(params: any) { | ||||||
|   return requestClient.download('/infra/config/export', { |   return requestClient.download('/infra/config/export', { | ||||||
|  |  | ||||||
|  | @ -69,6 +69,13 @@ export function deleteFileConfig(id: number) { | ||||||
|   return requestClient.delete(`/infra/file-config/delete?id=${id}`); |   return requestClient.delete(`/infra/file-config/delete?id=${id}`); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /** 批量删除文件配置 */ | ||||||
|  | export function deleteFileConfigList(ids: number[]) { | ||||||
|  |   return requestClient.delete( | ||||||
|  |     `/infra/file-config/delete-list?ids=${ids.join(',')}`, | ||||||
|  |   ); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** 测试文件配置 */ | /** 测试文件配置 */ | ||||||
| export function testFileConfig(id: number) { | export function testFileConfig(id: number) { | ||||||
|   return requestClient.get(`/infra/file-config/test?id=${id}`); |   return requestClient.get(`/infra/file-config/test?id=${id}`); | ||||||
|  |  | ||||||
|  | @ -45,6 +45,11 @@ export function deleteFile(id: number) { | ||||||
|   return requestClient.delete(`/infra/file/delete?id=${id}`); |   return requestClient.delete(`/infra/file/delete?id=${id}`); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /** 批量删除文件 */ | ||||||
|  | export function deleteFileList(ids: number[]) { | ||||||
|  |   return requestClient.delete(`/infra/file/delete-list?ids=${ids.join(',')}`); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** 获取文件预签名地址 */ | /** 获取文件预签名地址 */ | ||||||
| export function getFilePresignedUrl(name: string, directory?: string) { | export function getFilePresignedUrl(name: string, directory?: string) { | ||||||
|   return requestClient.get<InfraFileApi.FilePresignedUrlRespVO>( |   return requestClient.get<InfraFileApi.FilePresignedUrlRespVO>( | ||||||
|  |  | ||||||
|  | @ -46,6 +46,11 @@ export function deleteJob(id: number) { | ||||||
|   return requestClient.delete(`/infra/job/delete?id=${id}`); |   return requestClient.delete(`/infra/job/delete?id=${id}`); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | /** 批量删除定时任务调度 */ | ||||||
|  | export function deleteJobList(ids: number[]) { | ||||||
|  |   return requestClient.delete(`/infra/job/delete-list?ids=${ids.join(',')}`); | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** 导出定时任务调度 */ | /** 导出定时任务调度 */ | ||||||
| export function exportJob(params: any) { | export function exportJob(params: any) { | ||||||
|   return requestClient.download('/infra/job/export-excel', { params }); |   return requestClient.download('/infra/job/export-excel', { params }); | ||||||
|  |  | ||||||
|  | @ -394,6 +394,7 @@ export function useGridColumns( | ||||||
|   getDataSourceConfigName?: (dataSourceConfigId: number) => string | undefined, |   getDataSourceConfigName?: (dataSourceConfigId: number) => string | undefined, | ||||||
| ): VxeTableGridOptions['columns'] { | ): VxeTableGridOptions['columns'] { | ||||||
|   return [ |   return [ | ||||||
|  |     { type: 'checkbox', width: 40 }, | ||||||
|     { |     { | ||||||
|       field: 'dataSourceConfigId', |       field: 'dataSourceConfigId', | ||||||
|       title: '数据源', |       title: '数据源', | ||||||
|  |  | ||||||
|  | @ -7,12 +7,14 @@ import { ref } from 'vue'; | ||||||
| import { useRouter } from 'vue-router'; | import { useRouter } from 'vue-router'; | ||||||
| 
 | 
 | ||||||
| import { DocAlert, Page, useVbenModal } from '@vben/common-ui'; | import { DocAlert, Page, useVbenModal } from '@vben/common-ui'; | ||||||
|  | import { isEmpty } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { message } from 'ant-design-vue'; | import { message } from 'ant-design-vue'; | ||||||
| 
 | 
 | ||||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||||
| import { | import { | ||||||
|   deleteCodegenTable, |   deleteCodegenTable, | ||||||
|  |   deleteCodegenTableList, | ||||||
|   downloadCodegen, |   downloadCodegen, | ||||||
|   getCodegenTablePage, |   getCodegenTablePage, | ||||||
|   syncCodegenFromDB, |   syncCodegenFromDB, | ||||||
|  | @ -82,6 +84,31 @@ async function handleDelete(row: InfraCodegenApi.CodegenTable) { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const checkedIds = ref<number[]>([]); | ||||||
|  | function handleRowCheckboxChange({ | ||||||
|  |   records, | ||||||
|  | }: { | ||||||
|  |   records: InfraCodegenApi.CodegenTable[]; | ||||||
|  | }) { | ||||||
|  |   checkedIds.value = records.map((item) => item.id); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除代码生成配置 */ | ||||||
|  | async function handleDeleteBatch() { | ||||||
|  |   const hideLoading = message.loading({ | ||||||
|  |     content: $t('ui.actionMessage.deleting'), | ||||||
|  |     duration: 0, | ||||||
|  |     key: 'action_process_msg', | ||||||
|  |   }); | ||||||
|  |   try { | ||||||
|  |     await deleteCodegenTableList(checkedIds.value); | ||||||
|  |     message.success($t('ui.actionMessage.deleteSuccess')); | ||||||
|  |     onRefresh(); | ||||||
|  |   } finally { | ||||||
|  |     hideLoading(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| /** 同步数据库 */ | /** 同步数据库 */ | ||||||
| async function handleSync(row: InfraCodegenApi.CodegenTable) { | async function handleSync(row: InfraCodegenApi.CodegenTable) { | ||||||
|   const hideLoading = message.loading({ |   const hideLoading = message.loading({ | ||||||
|  | @ -145,12 +172,17 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|     }, |     }, | ||||||
|     rowConfig: { |     rowConfig: { | ||||||
|       keyField: 'id', |       keyField: 'id', | ||||||
|  |       isHover: true, | ||||||
|     }, |     }, | ||||||
|     toolbarConfig: { |     toolbarConfig: { | ||||||
|       refresh: { code: 'query' }, |       refresh: { code: 'query' }, | ||||||
|       search: true, |       search: true, | ||||||
|     }, |     }, | ||||||
|   } as VxeTableGridOptions<InfraCodegenApi.CodegenTable>, |   } as VxeTableGridOptions<InfraCodegenApi.CodegenTable>, | ||||||
|  |   gridEvents: { | ||||||
|  |     checkboxAll: handleRowCheckboxChange, | ||||||
|  |     checkboxChange: handleRowCheckboxChange, | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
| /** 获取数据源配置列表 */ | /** 获取数据源配置列表 */ | ||||||
|  | @ -196,6 +228,15 @@ initDataSourceConfig(); | ||||||
|               auth: ['infra:codegen:create'], |               auth: ['infra:codegen:create'], | ||||||
|               onClick: handleImport, |               onClick: handleImport, | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |               label: '批量删除', | ||||||
|  |               type: 'primary', | ||||||
|  |               danger: true, | ||||||
|  |               disabled: isEmpty(checkedIds), | ||||||
|  |               icon: ACTION_ICON.DELETE, | ||||||
|  |               auth: ['infra:codegen:delete'], | ||||||
|  |               onClick: handleDeleteBatch, | ||||||
|  |             }, | ||||||
|           ]" |           ]" | ||||||
|         /> |         /> | ||||||
|       </template> |       </template> | ||||||
|  |  | ||||||
|  | @ -119,6 +119,7 @@ export function useGridFormSchema(): VbenFormSchema[] { | ||||||
| /** 列表的字段 */ | /** 列表的字段 */ | ||||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||||
|   return [ |   return [ | ||||||
|  |     { type: 'checkbox', width: 40 }, | ||||||
|     { |     { | ||||||
|       field: 'id', |       field: 'id', | ||||||
|       title: '参数主键', |       title: '参数主键', | ||||||
|  |  | ||||||
|  | @ -2,13 +2,20 @@ | ||||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||||
| import type { InfraConfigApi } from '#/api/infra/config'; | import type { InfraConfigApi } from '#/api/infra/config'; | ||||||
| 
 | 
 | ||||||
|  | import { ref } from 'vue'; | ||||||
|  | 
 | ||||||
| import { Page, useVbenModal } from '@vben/common-ui'; | import { Page, useVbenModal } from '@vben/common-ui'; | ||||||
| import { downloadFileFromBlobPart } from '@vben/utils'; | import { downloadFileFromBlobPart, isEmpty } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { message } from 'ant-design-vue'; | import { message } from 'ant-design-vue'; | ||||||
| 
 | 
 | ||||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||||
| import { deleteConfig, exportConfig, getConfigPage } from '#/api/infra/config'; | import { | ||||||
|  |   deleteConfig, | ||||||
|  |   deleteConfigList, | ||||||
|  |   exportConfig, | ||||||
|  |   getConfigPage, | ||||||
|  | } from '#/api/infra/config'; | ||||||
| import { $t } from '#/locales'; | import { $t } from '#/locales'; | ||||||
| 
 | 
 | ||||||
| import { useGridColumns, useGridFormSchema } from './data'; | import { useGridColumns, useGridFormSchema } from './data'; | ||||||
|  | @ -59,6 +66,31 @@ async function handleDelete(row: InfraConfigApi.Config) { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const checkedIds = ref<number[]>([]); | ||||||
|  | function handleRowCheckboxChange({ | ||||||
|  |   records, | ||||||
|  | }: { | ||||||
|  |   records: InfraConfigApi.Config[]; | ||||||
|  | }) { | ||||||
|  |   checkedIds.value = records.map((item) => item.id as number); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除参数 */ | ||||||
|  | async function handleDeleteBatch() { | ||||||
|  |   const hideLoading = message.loading({ | ||||||
|  |     content: $t('ui.actionMessage.deleting'), | ||||||
|  |     duration: 0, | ||||||
|  |     key: 'action_process_msg', | ||||||
|  |   }); | ||||||
|  |   try { | ||||||
|  |     await deleteConfigList(checkedIds.value); | ||||||
|  |     message.success($t('ui.actionMessage.deleteSuccess')); | ||||||
|  |     onRefresh(); | ||||||
|  |   } finally { | ||||||
|  |     hideLoading(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const [Grid, gridApi] = useVbenVxeGrid({ | const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|   formOptions: { |   formOptions: { | ||||||
|     schema: useGridFormSchema(), |     schema: useGridFormSchema(), | ||||||
|  | @ -80,12 +112,17 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|     }, |     }, | ||||||
|     rowConfig: { |     rowConfig: { | ||||||
|       keyField: 'id', |       keyField: 'id', | ||||||
|  |       isHover: true, | ||||||
|     }, |     }, | ||||||
|     toolbarConfig: { |     toolbarConfig: { | ||||||
|       refresh: { code: 'query' }, |       refresh: { code: 'query' }, | ||||||
|       search: true, |       search: true, | ||||||
|     }, |     }, | ||||||
|   } as VxeTableGridOptions<InfraConfigApi.Config>, |   } as VxeTableGridOptions<InfraConfigApi.Config>, | ||||||
|  |   gridEvents: { | ||||||
|  |     checkboxAll: handleRowCheckboxChange, | ||||||
|  |     checkboxChange: handleRowCheckboxChange, | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | @ -110,6 +147,15 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|               auth: ['infra:config:export'], |               auth: ['infra:config:export'], | ||||||
|               onClick: handleExport, |               onClick: handleExport, | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |               label: '批量删除', | ||||||
|  |               type: 'primary', | ||||||
|  |               danger: true, | ||||||
|  |               disabled: isEmpty(checkedIds), | ||||||
|  |               icon: ACTION_ICON.DELETE, | ||||||
|  |               auth: ['infra:config:delete'], | ||||||
|  |               onClick: handleDeleteBatch, | ||||||
|  |             }, | ||||||
|           ]" |           ]" | ||||||
|         /> |         /> | ||||||
|       </template> |       </template> | ||||||
|  |  | ||||||
|  | @ -54,6 +54,7 @@ export function useGridFormSchema(): VbenFormSchema[] { | ||||||
| /** 列表的字段 */ | /** 列表的字段 */ | ||||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||||
|   return [ |   return [ | ||||||
|  |     { type: 'checkbox', width: 40 }, | ||||||
|     { |     { | ||||||
|       field: 'name', |       field: 'name', | ||||||
|       title: '文件名', |       title: '文件名', | ||||||
|  |  | ||||||
|  | @ -2,14 +2,16 @@ | ||||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||||
| import type { InfraFileApi } from '#/api/infra/file'; | import type { InfraFileApi } from '#/api/infra/file'; | ||||||
| 
 | 
 | ||||||
|  | import { ref } from 'vue'; | ||||||
|  | 
 | ||||||
| import { Page, useVbenModal } from '@vben/common-ui'; | import { Page, useVbenModal } from '@vben/common-ui'; | ||||||
| import { openWindow } from '@vben/utils'; | import { isEmpty, openWindow } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { useClipboard } from '@vueuse/core'; | import { useClipboard } from '@vueuse/core'; | ||||||
| import { Button, Image, message } from 'ant-design-vue'; | import { Button, Image, message } from 'ant-design-vue'; | ||||||
| 
 | 
 | ||||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||||
| import { deleteFile, getFilePage } from '#/api/infra/file'; | import { deleteFile, deleteFileList, getFilePage } from '#/api/infra/file'; | ||||||
| import { $t } from '#/locales'; | import { $t } from '#/locales'; | ||||||
| 
 | 
 | ||||||
| import { useGridColumns, useGridFormSchema } from './data'; | import { useGridColumns, useGridFormSchema } from './data'; | ||||||
|  | @ -64,6 +66,31 @@ async function handleDelete(row: InfraFileApi.File) { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const checkedIds = ref<number[]>([]); | ||||||
|  | function handleRowCheckboxChange({ | ||||||
|  |   records, | ||||||
|  | }: { | ||||||
|  |   records: InfraFileApi.File[]; | ||||||
|  | }) { | ||||||
|  |   checkedIds.value = records.map((item) => item.id as number); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除文件 */ | ||||||
|  | async function handleDeleteBatch() { | ||||||
|  |   const hideLoading = message.loading({ | ||||||
|  |     content: $t('ui.actionMessage.deleting'), | ||||||
|  |     duration: 0, | ||||||
|  |     key: 'action_process_msg', | ||||||
|  |   }); | ||||||
|  |   try { | ||||||
|  |     await deleteFileList(checkedIds.value); | ||||||
|  |     message.success($t('ui.actionMessage.deleteSuccess')); | ||||||
|  |     onRefresh(); | ||||||
|  |   } finally { | ||||||
|  |     hideLoading(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const [Grid, gridApi] = useVbenVxeGrid({ | const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|   formOptions: { |   formOptions: { | ||||||
|     schema: useGridFormSchema(), |     schema: useGridFormSchema(), | ||||||
|  | @ -85,12 +112,17 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|     }, |     }, | ||||||
|     rowConfig: { |     rowConfig: { | ||||||
|       keyField: 'id', |       keyField: 'id', | ||||||
|  |       isHover: true, | ||||||
|     }, |     }, | ||||||
|     toolbarConfig: { |     toolbarConfig: { | ||||||
|       refresh: { code: 'query' }, |       refresh: { code: 'query' }, | ||||||
|       search: true, |       search: true, | ||||||
|     }, |     }, | ||||||
|   } as VxeTableGridOptions<InfraFileApi.File>, |   } as VxeTableGridOptions<InfraFileApi.File>, | ||||||
|  |   gridEvents: { | ||||||
|  |     checkboxAll: handleRowCheckboxChange, | ||||||
|  |     checkboxChange: handleRowCheckboxChange, | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | @ -108,6 +140,15 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|               auth: ['infra:file:create'], |               auth: ['infra:file:create'], | ||||||
|               onClick: handleUpload, |               onClick: handleUpload, | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |               label: '批量删除', | ||||||
|  |               type: 'primary', | ||||||
|  |               danger: true, | ||||||
|  |               disabled: isEmpty(checkedIds), | ||||||
|  |               icon: ACTION_ICON.DELETE, | ||||||
|  |               auth: ['infra:file:delete'], | ||||||
|  |               onClick: handleDeleteBatch, | ||||||
|  |             }, | ||||||
|           ]" |           ]" | ||||||
|         /> |         /> | ||||||
|       </template> |       </template> | ||||||
|  |  | ||||||
|  | @ -262,6 +262,7 @@ export function useGridFormSchema(): VbenFormSchema[] { | ||||||
| /** 列表的字段 */ | /** 列表的字段 */ | ||||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||||
|   return [ |   return [ | ||||||
|  |     { type: 'checkbox', width: 40 }, | ||||||
|     { |     { | ||||||
|       field: 'id', |       field: 'id', | ||||||
|       title: '编号', |       title: '编号', | ||||||
|  |  | ||||||
|  | @ -2,14 +2,17 @@ | ||||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||||
| import type { InfraFileConfigApi } from '#/api/infra/file-config'; | import type { InfraFileConfigApi } from '#/api/infra/file-config'; | ||||||
| 
 | 
 | ||||||
|  | import { ref } from 'vue'; | ||||||
|  | 
 | ||||||
| import { confirm, Page, useVbenModal } from '@vben/common-ui'; | import { confirm, Page, useVbenModal } from '@vben/common-ui'; | ||||||
| import { openWindow } from '@vben/utils'; | import { isEmpty, openWindow } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { message } from 'ant-design-vue'; | import { message } from 'ant-design-vue'; | ||||||
| 
 | 
 | ||||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||||
| import { | import { | ||||||
|   deleteFileConfig, |   deleteFileConfig, | ||||||
|  |   deleteFileConfigList, | ||||||
|   getFileConfigPage, |   getFileConfigPage, | ||||||
|   testFileConfig, |   testFileConfig, | ||||||
|   updateFileConfigMaster, |   updateFileConfigMaster, | ||||||
|  | @ -97,6 +100,31 @@ async function handleDelete(row: InfraFileConfigApi.FileConfig) { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const checkedIds = ref<number[]>([]); | ||||||
|  | function handleRowCheckboxChange({ | ||||||
|  |   records, | ||||||
|  | }: { | ||||||
|  |   records: InfraFileConfigApi.FileConfig[]; | ||||||
|  | }) { | ||||||
|  |   checkedIds.value = records.map((item) => item.id as number); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除文件配置 */ | ||||||
|  | async function handleDeleteBatch() { | ||||||
|  |   const hideLoading = message.loading({ | ||||||
|  |     content: $t('ui.actionMessage.deleting'), | ||||||
|  |     duration: 0, | ||||||
|  |     key: 'action_process_msg', | ||||||
|  |   }); | ||||||
|  |   try { | ||||||
|  |     await deleteFileConfigList(checkedIds.value); | ||||||
|  |     message.success($t('ui.actionMessage.deleteSuccess')); | ||||||
|  |     onRefresh(); | ||||||
|  |   } finally { | ||||||
|  |     hideLoading(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const [Grid, gridApi] = useVbenVxeGrid({ | const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|   formOptions: { |   formOptions: { | ||||||
|     schema: useGridFormSchema(), |     schema: useGridFormSchema(), | ||||||
|  | @ -118,12 +146,17 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|     }, |     }, | ||||||
|     rowConfig: { |     rowConfig: { | ||||||
|       keyField: 'id', |       keyField: 'id', | ||||||
|  |       isHover: true, | ||||||
|     }, |     }, | ||||||
|     toolbarConfig: { |     toolbarConfig: { | ||||||
|       refresh: { code: 'query' }, |       refresh: { code: 'query' }, | ||||||
|       search: true, |       search: true, | ||||||
|     }, |     }, | ||||||
|   } as VxeTableGridOptions<InfraFileConfigApi.FileConfig>, |   } as VxeTableGridOptions<InfraFileConfigApi.FileConfig>, | ||||||
|  |   gridEvents: { | ||||||
|  |     checkboxAll: handleRowCheckboxChange, | ||||||
|  |     checkboxChange: handleRowCheckboxChange, | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | @ -141,6 +174,15 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|               auth: ['infra:file-config:create'], |               auth: ['infra:file-config:create'], | ||||||
|               onClick: handleCreate, |               onClick: handleCreate, | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |               label: '批量删除', | ||||||
|  |               type: 'primary', | ||||||
|  |               danger: true, | ||||||
|  |               disabled: isEmpty(checkedIds), | ||||||
|  |               icon: ACTION_ICON.DELETE, | ||||||
|  |               auth: ['infra:file-config:delete'], | ||||||
|  |               onClick: handleDeleteBatch, | ||||||
|  |             }, | ||||||
|           ]" |           ]" | ||||||
|         /> |         /> | ||||||
|       </template> |       </template> | ||||||
|  |  | ||||||
|  | @ -129,6 +129,7 @@ export function useGridFormSchema(): VbenFormSchema[] { | ||||||
| /** 表格列配置 */ | /** 表格列配置 */ | ||||||
| export function useGridColumns(): VxeTableGridOptions['columns'] { | export function useGridColumns(): VxeTableGridOptions['columns'] { | ||||||
|   return [ |   return [ | ||||||
|  |     { type: 'checkbox', width: 40 }, | ||||||
|     { |     { | ||||||
|       field: 'id', |       field: 'id', | ||||||
|       title: '任务编号', |       title: '任务编号', | ||||||
|  |  | ||||||
|  | @ -2,16 +2,18 @@ | ||||||
| import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | import type { VxeTableGridOptions } from '#/adapter/vxe-table'; | ||||||
| import type { InfraJobApi } from '#/api/infra/job'; | import type { InfraJobApi } from '#/api/infra/job'; | ||||||
| 
 | 
 | ||||||
|  | import { ref } from 'vue'; | ||||||
| import { useRouter } from 'vue-router'; | import { useRouter } from 'vue-router'; | ||||||
| 
 | 
 | ||||||
| import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui'; | import { confirm, DocAlert, Page, useVbenModal } from '@vben/common-ui'; | ||||||
| import { downloadFileFromBlobPart } from '@vben/utils'; | import { downloadFileFromBlobPart, isEmpty } from '@vben/utils'; | ||||||
| 
 | 
 | ||||||
| import { message } from 'ant-design-vue'; | import { message } from 'ant-design-vue'; | ||||||
| 
 | 
 | ||||||
| import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | import { ACTION_ICON, TableAction, useVbenVxeGrid } from '#/adapter/vxe-table'; | ||||||
| import { | import { | ||||||
|   deleteJob, |   deleteJob, | ||||||
|  |   deleteJobList, | ||||||
|   exportJob, |   exportJob, | ||||||
|   getJobPage, |   getJobPage, | ||||||
|   runJob, |   runJob, | ||||||
|  | @ -114,6 +116,27 @@ async function handleDelete(row: InfraJobApi.Job) { | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | const checkedIds = ref<number[]>([]); | ||||||
|  | function handleRowCheckboxChange({ records }: { records: InfraJobApi.Job[] }) { | ||||||
|  |   checkedIds.value = records.map((item) => item.id as number); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | /** 批量删除任务 */ | ||||||
|  | async function handleDeleteBatch() { | ||||||
|  |   const hideLoading = message.loading({ | ||||||
|  |     content: $t('ui.actionMessage.deleting'), | ||||||
|  |     duration: 0, | ||||||
|  |     key: 'action_process_msg', | ||||||
|  |   }); | ||||||
|  |   try { | ||||||
|  |     await deleteJobList(checkedIds.value); | ||||||
|  |     message.success($t('ui.actionMessage.deleteSuccess')); | ||||||
|  |     onRefresh(); | ||||||
|  |   } finally { | ||||||
|  |     hideLoading(); | ||||||
|  |   } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| const [Grid, gridApi] = useVbenVxeGrid({ | const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|   formOptions: { |   formOptions: { | ||||||
|     schema: useGridFormSchema(), |     schema: useGridFormSchema(), | ||||||
|  | @ -135,12 +158,17 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|     }, |     }, | ||||||
|     rowConfig: { |     rowConfig: { | ||||||
|       keyField: 'id', |       keyField: 'id', | ||||||
|  |       isHover: true, | ||||||
|     }, |     }, | ||||||
|     toolbarConfig: { |     toolbarConfig: { | ||||||
|       refresh: { code: 'query' }, |       refresh: { code: 'query' }, | ||||||
|       search: true, |       search: true, | ||||||
|     }, |     }, | ||||||
|   } as VxeTableGridOptions<InfraJobApi.Job>, |   } as VxeTableGridOptions<InfraJobApi.Job>, | ||||||
|  |   gridEvents: { | ||||||
|  |     checkboxAll: handleRowCheckboxChange, | ||||||
|  |     checkboxChange: handleRowCheckboxChange, | ||||||
|  |   }, | ||||||
| }); | }); | ||||||
| </script> | </script> | ||||||
| 
 | 
 | ||||||
|  | @ -177,7 +205,16 @@ const [Grid, gridApi] = useVbenVxeGrid({ | ||||||
|               type: 'primary', |               type: 'primary', | ||||||
|               icon: 'lucide:history', |               icon: 'lucide:history', | ||||||
|               auth: ['infra:job:export'], |               auth: ['infra:job:export'], | ||||||
|               onClick: handleExport, |               onClick: handleLog, | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |               label: '批量删除', | ||||||
|  |               type: 'primary', | ||||||
|  |               danger: true, | ||||||
|  |               disabled: isEmpty(checkedIds), | ||||||
|  |               icon: ACTION_ICON.DELETE, | ||||||
|  |               auth: ['infra:job:delete'], | ||||||
|  |               onClick: handleDeleteBatch, | ||||||
|             }, |             }, | ||||||
|           ]" |           ]" | ||||||
|         /> |         /> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 puhui999
						puhui999