From 3e0f519c396ac8a72e7bbd426e4f38fa6cc403dc Mon Sep 17 00:00:00 2001 From: zhuguifei <zhuguifei@zhuguifeideiMac.local> Date: 星期五, 14 三月 2025 16:50:34 +0800 Subject: [PATCH] 点检模块 --- eims-ui/apps/web-antd/src/views/eims/insp-st/index.vue | 80 ++++++++++++++++++++++++--------------- 1 files changed, 49 insertions(+), 31 deletions(-) diff --git a/eims-ui/apps/web-antd/src/views/eims/maint-order-st/index.vue b/eims-ui/apps/web-antd/src/views/eims/insp-st/index.vue similarity index 70% copy from eims-ui/apps/web-antd/src/views/eims/maint-order-st/index.vue copy to eims-ui/apps/web-antd/src/views/eims/insp-st/index.vue index 716379d..203ec1a 100644 --- a/eims-ui/apps/web-antd/src/views/eims/maint-order-st/index.vue +++ b/eims-ui/apps/web-antd/src/views/eims/insp-st/index.vue @@ -4,19 +4,18 @@ import { Page, useVbenDrawer, type VbenFormProps } from '@vben/common-ui'; import { addFullName, getPopupContainer, getVxePopupContainer } from '@vben/utils'; -import { Popconfirm, Space } from 'ant-design-vue'; +import { Modal, Popconfirm, Space } from 'ant-design-vue'; -import { useVbenVxeGrid, type VxeGridProps, vxeSortEvent } from '#/adapter/vxe-table'; -import { listMaintOrderGroupDetail } from '#/api/eims/maint-order'; -import { delMaintOrderSt, listMaintOrderSt } from '#/api/eims/maint-order-st'; +import { useVbenVxeGrid, vxeCheckboxChecked, type VxeGridProps, vxeSortEvent } from '#/adapter/vxe-table'; +import { delMaintOrder, listMaintOrderGroupDetail } from '#/api/eims/maint-order'; +import { delInspectSt, listInspectSt } from '#/api/eims/insp-st'; import { getDeptTree, userList } from '#/api/system/user'; import BasisSubTable from '#/views/eims/components/basis-sub-table.vue'; -import { columns as orderCol } from '#/views/eims/maint-order/data'; +import { columns as recordCol } from '#/views/eims/insp-record/data'; import { columns, querySchema } from './data'; -import maintOrderStDrawer from './maint-order-st-drawer.vue'; +import inspStDrawer from './insp-st-drawer.vue'; import type { Recordable } from '@vben/types'; -import { MAINT_ORDER_STATUS } from '#/constants/dict'; import { $t } from '@vben/locales'; defineExpose({ @@ -53,7 +52,7 @@ proxyConfig: { ajax: { query: async ({ page }, formValues = {}) => { - return await listMaintOrderSt({ + return await listInspectSt({ pageNum: page.currentPage, pageSize: page.pageSize, ...formValues @@ -71,9 +70,9 @@ // 鏀寔澶氬瓧娈垫帓搴� 榛樿鍏抽棴 multiple: true }, - id: 'maint-order-group-index' + id: 'insp-st-index' }; -const orderId = ref<string>(); +const recordId = ref<string>(); const [BasicTable, tableApi] = useVbenVxeGrid({ formOptions, gridOptions, @@ -81,7 +80,7 @@ sortChange: (sortParams) => vxeSortEvent(tableApi, sortParams), cellClick: (e: any) => { const { row } = e; - orderId.value = `${row.equId}_${row.planTime}`; + recordId.value = `${row.equId}_${row.planTime}`; } } }); @@ -108,7 +107,7 @@ /** 鏍规嵁閮ㄩ棬ID鍔犺浇鐢ㄦ埛 */ await setupUserOptions(deptId); /** 鍙樺寲鍚庨渶瑕侀噸鏂伴�夋嫨鐢ㄦ埛 */ - formModel.maintUser = undefined; + formModel.inspUser = undefined; }, placeholder: '璇烽�夋嫨', showSearch: true, @@ -120,7 +119,7 @@ // 閫変腑鍚庢樉绀哄湪杈撳叆妗嗙殑鍊� treeNodeLabelProp: 'fullName' }), - fieldName: 'maintDept' + fieldName: 'inspDept' } ]); } @@ -148,28 +147,37 @@ tableApi.formApi.updateSchema([ { componentProps: { options, placeholder, filterOption }, - fieldName: 'maintUser' + fieldName: 'inspUser' } ]); } -const [MaintOrderStDrawer, maintOrderStDrawerApi] = useVbenDrawer({ - connectedComponent: maintOrderStDrawer +const [InspStDrawer, inspStDrawerApi] = useVbenDrawer({ + connectedComponent: inspStDrawer }); -function handleAdd() { - maintOrderStDrawerApi.setData({}); - maintOrderStDrawerApi.open(); -} async function handleEdit(record: Recordable<any>) { - maintOrderStDrawerApi.setData({ id: record.id }); - maintOrderStDrawerApi.open(); + inspStDrawerApi.setData({ id: record.id }); + inspStDrawerApi.open(); } async function handleDelete(row: Recordable<any>) { - await delMaintOrderSt(row.id); + await delInspectSt(row.id); await tableApi.query(); } +function handleMultiDelete() { + const rows = tableApi.grid.getCheckboxRecords(); + const ids = rows.map((row: any) => row.id); + Modal.confirm({ + title: '鎻愮ず', + okType: 'danger', + content: `纭鍒犻櫎閫変腑鐨�${ids.length}鏉¤褰曞悧锛焋, + onOk: async () => { + await delInspectSt(ids); + await tableApi.query(); + } + }); +} onMounted(async () => { await setupDeptSelect(); @@ -184,9 +192,19 @@ <template> <Page :auto-content-height="true"> <div class="flex h-full gap-[8px] flex-col"> - <BasicTable class="h-3/5" table-title="淇濆吇宸ュ崟鍒楄〃"> + <BasicTable class="h-2/3" table-title="鐐规璁板綍鍒楄〃"> <template #toolbar-tools> - <Space /> + <Space > + <a-button + :disabled="!vxeCheckboxChecked(tableApi)" + danger + type="primary" + v-access:code="['eims:inspectSt:remove']" + @click="handleMultiDelete" + > + {{ $t('pages.common.delete') }} + </a-button> + </Space> </template> <template #equName="{ row }"> @@ -196,12 +214,12 @@ </template> <template #action="{ row }"> <Space> - <ghost-button v-access:code="['eims:maintOrderSt:edit']" @click.stop="handleEdit(row)"> + <ghost-button v-access:code="['eims:inspectSt:edit']" @click.stop="handleEdit(row)"> {{ $t('pages.common.edit') }} </ghost-button> <Popconfirm :get-popup-container="getVxePopupContainer" placement="left" title="纭鍒犻櫎锛�" @confirm="handleDelete(row)"> - <ghost-button danger v-access:code="['eims:maintOrderSt:remove']" @click.stop=""> + <ghost-button danger v-access:code="['eims:inspectSt:remove']" @click.stop=""> {{ $t('pages.common.delete') }} </ghost-button> </Popconfirm> @@ -210,14 +228,14 @@ </BasicTable> <BasisSubTable - :columns="orderCol" + :columns="recordCol" :list-api="listMaintOrderGroupDetail" - :req-value="orderId" - class="h-2/5" + :req-value="recordId" + class="h-1/3" req-key="maintCode" title="淇濆吇瀹炴柦椤圭洰" /> </div> - <MaintOrderStDrawer @reload="tableApi.query()" /> + <InspStDrawer @reload="tableApi.query()" /> </Page> </template> -- Gitblit v1.9.3