From 34d36a15f339d331d668d4063cfdff50cffa5800 Mon Sep 17 00:00:00 2001
From: zhou zhou <zozhouo3o@gmail.com>
Date: 星期五, 17 四月 2026 15:11:32 +0800
Subject: [PATCH] #导出服务

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WarehouseAreasItemController.java |   66 ++++++++++++++++++++++++++++++++-
 1 files changed, 64 insertions(+), 2 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WarehouseAreasItemController.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WarehouseAreasItemController.java
index 1d29f84..61881f6 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WarehouseAreasItemController.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/controller/WarehouseAreasItemController.java
@@ -10,14 +10,17 @@
 import com.vincent.rsf.server.common.domain.BaseParam;
 import com.vincent.rsf.server.common.domain.KeyValVo;
 import com.vincent.rsf.server.common.domain.PageParam;
+import com.vincent.rsf.server.common.service.AsyncListExportTaskService;
 import com.vincent.rsf.server.common.service.ListExportHandler;
 import com.vincent.rsf.server.common.service.ListExportService;
 import com.vincent.rsf.server.common.utils.ExcelUtil;
+import com.vincent.rsf.server.common.utils.FileServerUtil;
 import com.vincent.rsf.server.common.utils.FieldsUtils;
 import com.vincent.rsf.server.manager.entity.WarehouseAreasItem;
 import com.vincent.rsf.server.manager.service.WarehouseAreasItemService;
 import com.vincent.rsf.server.manager.utils.buildPageRowsUtils;
 import com.vincent.rsf.server.system.controller.BaseController;
+import com.vincent.rsf.server.system.entity.ExportTask;
 import io.swagger.annotations.Api;
 import org.springframework.beans.BeanWrapper;
 import org.springframework.beans.BeanWrapperImpl;
@@ -26,16 +29,24 @@
 import org.springframework.web.bind.annotation.*;
 
 import jakarta.servlet.http.HttpServletResponse;
+import jakarta.servlet.http.HttpServletRequest;
+import java.io.File;
 import java.util.*;
 
 @Api(tags = "搴撳尯搴撳瓨鏄庣粏")
 @RestController
 public class WarehouseAreasItemController extends BaseController {
+    private static final String EXPORT_RESOURCE_KEY = "warehouseAreasItem";
+    private static final String EXPORT_DEFAULT_REPORT_TITLE = "鏀惰揣搴撳瓨鎶ヨ〃";
+
     @Autowired
     private WarehouseAreasItemService warehouseAreasItemService;
 
     @Autowired
     private ListExportService listExportService;
+
+    @Autowired
+    private AsyncListExportTaskService asyncListExportTaskService;
 
     private final ListExportHandler<WarehouseAreasItem, BaseParam> warehouseAreasItemExportHandler = new ListExportHandler<>() {
         @Override
@@ -63,7 +74,7 @@
 
         @Override
         public String defaultReportTitle() {
-            return "鏀惰揣搴撳瓨鎶ヨ〃";
+            return EXPORT_DEFAULT_REPORT_TITLE;
         }
     };
 
@@ -175,7 +186,7 @@
         return R.ok().add(buildPageRowsUtils.rowsMap(vos));
     }
 
-    @PreAuthorize("hasAuthority('manager:warehouseAreasItem:list')")
+    @PreAuthorize("hasAuthority('manager:warehouseAreasItem:export')")
     @PostMapping("/warehouseAreasItem/export")
     public void export(@RequestBody Map<String, Object> map, HttpServletResponse response) throws Exception {
         listExportService.export(
@@ -186,6 +197,57 @@
         );
     }
 
+    @PreAuthorize("hasAuthority('manager:warehouseAreasItem:export')")
+    @PostMapping("/warehouseAreasItem/export/async")
+    public R createAsyncExportTask(@RequestBody Map<String, Object> map) {
+        ExportTask task = asyncListExportTaskService.createTask(
+                EXPORT_RESOURCE_KEY,
+                EXPORT_DEFAULT_REPORT_TITLE,
+                map,
+                getTenantId(),
+                getLoginUserId()
+        );
+        asyncListExportTaskService.executeAsync(
+                task.getId(),
+                EXPORT_RESOURCE_KEY,
+                new HashMap<>(map),
+                exportMap -> buildParam(exportMap, BaseParam.class),
+                warehouseAreasItemExportHandler
+        );
+        return R.ok("瀵煎嚭浠诲姟宸插垱寤�").add(buildPageRowsUtils.rowsMap(task));
+    }
+
+    @PreAuthorize("hasAuthority('manager:warehouseAreasItem:export')")
+    @GetMapping("/warehouseAreasItem/export/task/{taskId}")
+    public R getExportTask(@PathVariable("taskId") Long taskId) {
+        ExportTask task = asyncListExportTaskService.getTask(
+                taskId,
+                EXPORT_RESOURCE_KEY,
+                getTenantId(),
+                getLoginUserId()
+        );
+        if (task == null) {
+            return R.error("瀵煎嚭浠诲姟涓嶅瓨鍦�");
+        }
+        return R.ok().add(buildPageRowsUtils.rowsMap(task));
+    }
+
+    @PreAuthorize("hasAuthority('manager:warehouseAreasItem:export')")
+    @GetMapping("/warehouseAreasItem/export/task/{taskId}/download")
+    public void downloadExportTask(
+            @PathVariable("taskId") Long taskId,
+            HttpServletResponse response,
+            HttpServletRequest request
+    ) {
+        File file = asyncListExportTaskService.getDownloadFile(
+                taskId,
+                EXPORT_RESOURCE_KEY,
+                getTenantId(),
+                getLoginUserId()
+        );
+        FileServerUtil.preview(file, true, file.getName(), null, null, response, request);
+    }
+
     private void fillExtendFields(List<WarehouseAreasItem> records) {
         for (WarehouseAreasItem record : records) {
             if (!Objects.isNull(record.getFieldsIndex())) {

--
Gitblit v1.9.1