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