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/maint-st/index.vue |   70 +++++++++++++++++++++-------------
 1 files changed, 43 insertions(+), 27 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/maint-st/index.vue
similarity index 75%
rename from eims-ui/apps/web-antd/src/views/eims/maint-order-st/index.vue
rename to eims-ui/apps/web-antd/src/views/eims/maint-st/index.vue
index 716379d..a90f696 100644
--- a/eims-ui/apps/web-antd/src/views/eims/maint-order-st/index.vue
+++ b/eims-ui/apps/web-antd/src/views/eims/maint-st/index.vue
@@ -1,23 +1,23 @@
 <script setup lang="ts">
+import type { Recordable } from '@vben/types';
+
 import { onMounted, ref } from 'vue';
 
 import { Page, useVbenDrawer, type VbenFormProps } from '@vben/common-ui';
+import { $t } from '@vben/locales';
 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 { useVbenVxeGrid, vxeCheckboxChecked, type VxeGridProps, vxeSortEvent } from '#/adapter/vxe-table';
 import { listMaintOrderGroupDetail } from '#/api/eims/maint-order';
-import { delMaintOrderSt, listMaintOrderSt } from '#/api/eims/maint-order-st';
+import { delMaintSt, listMaintSt } from '#/api/eims/maint-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, querySchema } from './data';
-import maintOrderStDrawer from './maint-order-st-drawer.vue';
-import type { Recordable } from '@vben/types';
-import { MAINT_ORDER_STATUS } from '#/constants/dict';
-import { $t } from '@vben/locales';
+import maintStDrawer from './maint-st-drawer.vue';
 
 defineExpose({
   tableSelect
@@ -53,7 +53,7 @@
   proxyConfig: {
     ajax: {
       query: async ({ page }, formValues = {}) => {
-        return await listMaintOrderSt({
+        return await listMaintSt({
           pageNum: page.currentPage,
           pageSize: page.pageSize,
           ...formValues
@@ -152,24 +152,32 @@
     }
   ]);
 }
-const [MaintOrderStDrawer, maintOrderStDrawerApi] = useVbenDrawer({
-  connectedComponent: maintOrderStDrawer
+const [MaintStDrawer, maintStDrawerApi] = useVbenDrawer({
+  connectedComponent: maintStDrawer
 });
 
-function handleAdd() {
-  maintOrderStDrawerApi.setData({});
-  maintOrderStDrawerApi.open();
-}
-
 async function handleEdit(record: Recordable<any>) {
-  maintOrderStDrawerApi.setData({ id: record.id });
-  maintOrderStDrawerApi.open();
+  maintStDrawerApi.setData({ id: record.id });
+  maintStDrawerApi.open();
 }
 async function handleDelete(row: Recordable<any>) {
-  await delMaintOrderSt(row.id);
+  await delMaintSt(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 delMaintSt(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:maintSt:remove']"
+              @click="handleMultiDelete"
+            >
+              {{ $t('pages.common.delete') }}
+            </a-button>
+          </Space>
         </template>
 
         <template #equName="{ row }">
@@ -196,28 +214,26 @@
         </template>
         <template #action="{ row }">
           <Space>
-            <ghost-button v-access:code="['eims:maintOrderSt:edit']" @click.stop="handleEdit(row)">
+            <ghost-button v-access:code="['eims:maintSt: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="">
+            <Popconfirm :get-popup-container="getVxePopupContainer" placement="left" title="纭鍒犻櫎锛�" @confirm="handleDelete(row)">
+              <ghost-button danger v-access:code="['eims:maintSt:remove']" @click.stop="">
                 {{ $t('pages.common.delete') }}
               </ghost-button>
             </Popconfirm>
           </Space>
         </template>
-
       </BasicTable>
       <BasisSubTable
         :columns="orderCol"
         :list-api="listMaintOrderGroupDetail"
         :req-value="orderId"
-        class="h-2/5"
+        class="h-1/3"
         req-key="maintCode"
         title="淇濆吇瀹炴柦椤圭洰"
       />
     </div>
-    <MaintOrderStDrawer @reload="tableApi.query()" />
+    <MaintStDrawer @reload="tableApi.query()" />
   </Page>
 </template>

--
Gitblit v1.9.3