From 6305d0c86c23e9a583e8ca798645885d167f4dc5 Mon Sep 17 00:00:00 2001
From: liding <756868258@qq.com>
Date: 星期三, 10 六月 2026 17:20:58 +0800
Subject: [PATCH] feat:1.销售台账导出按照查询条件 2.导出订单和产品明细

---
 src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java |  233 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 233 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
index 527268f..e209855 100644
--- a/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
+++ b/src/main/java/com/ruoyi/sales/service/impl/SalesLedgerServiceImpl.java
@@ -78,11 +78,13 @@
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.multipart.MultipartFile;
 
+import javax.servlet.http.HttpServletResponse;
 import java.io.IOException;
 import java.io.InputStream;
 import java.lang.reflect.Field;
 import java.math.BigDecimal;
 import java.math.RoundingMode;
+import java.net.URLEncoder;
 import java.nio.file.Files;
 import java.nio.file.Path;
 import java.nio.file.Paths;
@@ -3694,4 +3696,235 @@
             );
         }
     }
+
+    @Override
+    public void exportWithProducts(HttpServletResponse response, SalesLedgerDto salesLedgerDto) {
+        try {
+            // 1. 鏌ヨ閿�鍞彴璐﹀垪琛紙瀵煎嚭浣跨敤鍗囧簭鎺掑簭锛�
+            Page<SalesLedger> page = new Page<>(-1, -1);
+            // 浣跨敤 Wrappers 鏋勫缓鍗囧簭鏌ヨ
+            LambdaQueryWrapper<SalesLedger> queryWrapper = Wrappers.<SalesLedger>lambdaQuery()
+                .orderByAsc(SalesLedger::getEntryDate)
+                .orderByAsc(SalesLedger::getId);
+
+            // 娣诲姞鏌ヨ鏉′欢
+            if (salesLedgerDto.getCustomerName() != null && !salesLedgerDto.getCustomerName().isEmpty()) {
+                queryWrapper.like(SalesLedger::getCustomerName, salesLedgerDto.getCustomerName());
+            }
+            if (salesLedgerDto.getSalesContractNo() != null && !salesLedgerDto.getSalesContractNo().isEmpty()) {
+                queryWrapper.like(SalesLedger::getSalesContractNo, salesLedgerDto.getSalesContractNo());
+            }
+            if (salesLedgerDto.getProjectName() != null && !salesLedgerDto.getProjectName().isEmpty()) {
+                queryWrapper.like(SalesLedger::getProjectName, salesLedgerDto.getProjectName());
+            }
+            if (salesLedgerDto.getEntryDateStart() != null && !salesLedgerDto.getEntryDateStart().isEmpty()) {
+                queryWrapper.ge(SalesLedger::getEntryDate, salesLedgerDto.getEntryDateStart());
+            }
+            if (salesLedgerDto.getEntryDateEnd() != null && !salesLedgerDto.getEntryDateEnd().isEmpty()) {
+                queryWrapper.le(SalesLedger::getEntryDate, salesLedgerDto.getEntryDateEnd());
+            }
+            if (salesLedgerDto.getDeliveryStatus() != null) {
+                queryWrapper.eq(SalesLedger::getDeliveryStatus, salesLedgerDto.getDeliveryStatus());
+            }
+            if (salesLedgerDto.getStockStatus() != null) {
+                queryWrapper.eq(SalesLedger::getStockStatus, salesLedgerDto.getStockStatus());
+            }
+            if (salesLedgerDto.getReviewStatus() != null) {
+                queryWrapper.eq(SalesLedger::getReviewStatus, salesLedgerDto.getReviewStatus());
+            }
+            if (salesLedgerDto.getOrderStatus() != null) {
+                queryWrapper.eq(SalesLedger::getOrderStatus, salesLedgerDto.getOrderStatus());
+            }
+            if (salesLedgerDto.getReviewStatusList() != null && !salesLedgerDto.getReviewStatusList().isEmpty()) {
+                queryWrapper.and(w -> w.in(SalesLedger::getReviewStatus, salesLedgerDto.getReviewStatusList())
+                    .or().isNull(SalesLedger::getReviewStatus));
+            }
+
+            List<SalesLedger> ledgerList = salesLedgerMapper.selectList(page, queryWrapper);
+
+            // 2. 鏀堕泦鏁版嵁
+            List<SalesLedgerExportDto> ledgerExportList = new ArrayList<>();
+            List<SalesLedgerProductExportDto> productExportList = new ArrayList<>();
+
+            for (SalesLedger ledger : ledgerList) {
+                // 杞崲鍙拌处鏁版嵁
+                SalesLedgerExportDto ledgerDto = new SalesLedgerExportDto();
+                ledgerDto.setSalesContractNo(ledger.getSalesContractNo());
+                ledgerDto.setCustomerContractNo(ledger.getCustomerContractNo());
+                ledgerDto.setProjectName(ledger.getProjectName());
+                ledgerDto.setCustomerName(ledger.getCustomerName());
+                ledgerDto.setSalesman(ledger.getSalesman());
+                ledgerDto.setEntryPersonName(ledger.getEntryPersonName());
+                ledgerDto.setEntryDate(ledger.getEntryDate());
+                ledgerDto.setExecutionDate(ledger.getExecutionDate() != null ?
+                    java.sql.Date.valueOf(ledger.getExecutionDate()) : null);
+                ledgerDto.setDeliveryDate(ledger.getDeliveryDate() != null ?
+                    java.sql.Date.valueOf(ledger.getDeliveryDate()) : null);
+                ledgerDto.setContractAmount(ledger.getContractAmount());
+                ledgerDto.setRemarks(ledger.getRemarks());
+                ledgerDto.setCustomerRemarks(ledger.getCustomerRemarks());
+                ledgerDto.setDeliveryStatusText(getDeliveryStatusText(ledger.getDeliveryStatus()));
+                ledgerDto.setStockStatusText(getStockStatusText(ledger.getStockStatus()));
+                ledgerDto.setReviewStatusText(getReviewStatusText(ledger.getReviewStatus()));
+                ledgerDto.setOrderStatusText(getOrderStatusText(ledger.getOrderStatus()));
+                ledgerExportList.add(ledgerDto);
+
+                // 鏌ヨ璇ュ彴璐︾殑浜у搧鍒楄〃
+                List<SalesLedgerProduct> products = salesLedgerProductMapper.selectList(
+                    Wrappers.<SalesLedgerProduct>lambdaQuery()
+                        .eq(SalesLedgerProduct::getSalesLedgerId, ledger.getId())
+                        .eq(SalesLedgerProduct::getType, 1)
+                );
+
+                for (SalesLedgerProduct product : products) {
+                    SalesLedgerProductExportDto productDto = new SalesLedgerProductExportDto();
+                    productDto.setSalesContractNo(ledger.getSalesContractNo());
+                    productDto.setProductCategory(product.getProductCategory());
+                    productDto.setSpecificationModel(product.getSpecificationModel());
+                    productDto.setThickness(product.getThickness());
+                    productDto.setFloorCode(product.getFloorCode());
+                    productDto.setWidth(product.getWidth());
+                    productDto.setHeight(product.getHeight());
+                    productDto.setQuantity(product.getQuantity());
+                    productDto.setSettlePieceArea(product.getSettlePieceArea());
+                    productDto.setSettleTotalArea(product.getSettleTotalArea());
+                    productDto.setTaxInclusiveUnitPrice(product.getTaxInclusiveUnitPrice());
+                    productDto.setTaxRate(product.getTaxRate());
+                    productDto.setTaxInclusiveTotalPrice(product.getTaxInclusiveTotalPrice());
+                    productDto.setTaxExclusiveTotalPrice(product.getTaxExclusiveTotalPrice());
+                    productDto.setInvoiceType(product.getInvoiceType());
+                    productDto.setProcessRequirement(product.getProcessRequirement());
+                    productDto.setRemark(product.getRemark());
+                    productExportList.add(productDto);
+                }
+            }
+
+            // 3. 浣跨敤ExcelUtil瀵煎嚭锛堝唴閮ㄤ細鍒涘缓Workbook骞跺啓鍏ュ搷搴旓級
+            // 鍏堝垱寤轰复鏃舵枃浠讹紝鍐嶅悎骞朵袱涓猻heet
+            response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
+            response.setCharacterEncoding("utf-8");
+            String fileName = URLEncoder.encode("閿�鍞彴璐�.xlsx", "utf-8").replaceAll("\\+", "%20");
+            response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName);
+
+            org.apache.poi.xssf.usermodel.XSSFWorkbook workbook = new org.apache.poi.xssf.usermodel.XSSFWorkbook();
+
+            // Sheet1: 閿�鍞彴璐� - 鎵嬪姩濉厖
+            fillSheetWithData(workbook, "閿�鍞彴璐�", SalesLedgerExportDto.class, ledgerExportList);
+
+            // Sheet2: 浜у搧鏄庣粏 - 鎵嬪姩濉厖
+            fillSheetWithData(workbook, "浜у搧鏄庣粏", SalesLedgerProductExportDto.class, productExportList);
+
+            workbook.write(response.getOutputStream());
+            workbook.close();
+
+        } catch (Exception e) {
+            log.error("瀵煎嚭閿�鍞彴璐﹀け璐�", e);
+            throw new ServiceException("瀵煎嚭澶辫触锛�" + e.getMessage());
+        }
+    }
+
+    /**
+     * 鎵嬪姩濉厖Sheet鏁版嵁
+     */
+    private <T> void fillSheetWithData(org.apache.poi.xssf.usermodel.XSSFWorkbook workbook, String sheetName, Class<T> clazz, List<T> dataList) throws Exception {
+        org.apache.poi.ss.usermodel.Sheet sheet = workbook.createSheet(sheetName);
+
+        // 鑾峰彇瀛楁涓婄殑@Excel娉ㄨВ
+        java.lang.reflect.Field[] fields = clazz.getDeclaredFields();
+        List<java.lang.reflect.Field> excelFields = new ArrayList<>();
+        for (java.lang.reflect.Field field : fields) {
+            com.ruoyi.framework.aspectj.lang.annotation.Excel excel = field.getAnnotation(com.ruoyi.framework.aspectj.lang.annotation.Excel.class);
+            if (excel != null) {
+                excelFields.add(field);
+            }
+        }
+
+        // 鍒涘缓琛ㄥご
+        org.apache.poi.ss.usermodel.Row headerRow = sheet.createRow(0);
+        org.apache.poi.ss.usermodel.CellStyle headerStyle = workbook.createCellStyle();
+        headerStyle.setFillForegroundColor(org.apache.poi.ss.usermodel.IndexedColors.GREY_50_PERCENT.getIndex());
+        headerStyle.setFillPattern(org.apache.poi.ss.usermodel.FillPatternType.SOLID_FOREGROUND);
+        headerStyle.setAlignment(org.apache.poi.ss.usermodel.HorizontalAlignment.CENTER);
+        org.apache.poi.ss.usermodel.Font headerFont = workbook.createFont();
+        headerFont.setBold(true);
+        headerStyle.setFont(headerFont);
+
+        for (int i = 0; i < excelFields.size(); i++) {
+            java.lang.reflect.Field field = excelFields.get(i);
+            field.setAccessible(true);
+            com.ruoyi.framework.aspectj.lang.annotation.Excel excel = field.getAnnotation(com.ruoyi.framework.aspectj.lang.annotation.Excel.class);
+            org.apache.poi.ss.usermodel.Cell cell = headerRow.createCell(i);
+            cell.setCellValue(excel.name());
+            cell.setCellStyle(headerStyle);
+            sheet.setColumnWidth(i, 20 * 256);
+        }
+
+        // 鍒涘缓鏁版嵁琛�
+        org.apache.poi.ss.usermodel.CellStyle dataStyle = workbook.createCellStyle();
+        dataStyle.setAlignment(org.apache.poi.ss.usermodel.HorizontalAlignment.CENTER);
+
+        for (int rowIndex = 0; rowIndex < dataList.size(); rowIndex++) {
+            T data = dataList.get(rowIndex);
+            org.apache.poi.ss.usermodel.Row row = sheet.createRow(rowIndex + 1);
+            for (int colIndex = 0; colIndex < excelFields.size(); colIndex++) {
+                java.lang.reflect.Field field = excelFields.get(colIndex);
+                field.setAccessible(true);
+                Object value = field.get(data);
+                org.apache.poi.ss.usermodel.Cell cell = row.createCell(colIndex);
+                if (value == null) {
+                    cell.setCellValue("");
+                } else if (value instanceof Number) {
+                    cell.setCellValue(((Number) value).doubleValue());
+                } else if (value instanceof Date) {
+                    cell.setCellValue(new java.text.SimpleDateFormat("yyyy-MM-dd").format((Date) value));
+                } else {
+                    cell.setCellValue(value.toString());
+                }
+                cell.setCellStyle(dataStyle);
+            }
+        }
+    }
+
+    private String getDeliveryStatusText(Integer status) {
+        if (status == null) return "鏈煡";
+        switch (status) {
+            case 1: return "鏈彂璐�";
+            case 2: return "瀹℃壒涓�";
+            case 3: return "瀹℃壒涓嶉�氳繃";
+            case 4: return "瀹℃壒閫氳繃";
+            case 5: return "宸插彂璐�";
+            case 6: return "閮ㄥ垎鍙戣揣";
+            default: return "鏈煡";
+        }
+    }
+
+    private String getStockStatusText(Integer status) {
+        if (status == null) return "鏈煡";
+        switch (status) {
+            case 0: return "鏈叆搴�";
+            case 1: return "閮ㄥ垎鍏ュ簱";
+            case 2: return "宸插叆搴�";
+            case 3: return "瀹℃壒涓�";
+            default: return "鏈煡";
+        }
+    }
+
+    private String getReviewStatusText(Integer status) {
+        if (status == null) return "寰呭鏍�";
+        switch (status) {
+            case 0: return "寰呭鏍�";
+            case 1: return "宸插鏍�";
+            case 2: return "宸插弽瀹�";
+            default: return "寰呭鏍�";
+        }
+    }
+
+    private String getOrderStatusText(Integer status) {
+        if (status == null || status == 0) return "杩涜涓�";
+        switch (status) {
+            case 0: return "杩涜涓�";
+            case 1: return "宸插畬鎴�";
+            default: return "杩涜涓�";
+        }
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3