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