From cffbaec750882dd7f4d112d7c735d247e2a961a7 Mon Sep 17 00:00:00 2001
From: zjj <3272660260@qq.com>
Date: 星期五, 10 十一月 2023 13:32:50 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/asrs/controller/OrderController.java |  128 +++++++++++++++++++++++++++++-------------
 1 files changed, 89 insertions(+), 39 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OrderController.java b/src/main/java/com/zy/asrs/controller/OrderController.java
index de90edd..d6666bf 100644
--- a/src/main/java/com/zy/asrs/controller/OrderController.java
+++ b/src/main/java/com/zy/asrs/controller/OrderController.java
@@ -37,6 +37,7 @@
 import java.io.OutputStream;
 import java.math.BigDecimal;
 import java.net.URLEncoder;
+import java.text.SimpleDateFormat;
 import java.util.*;
 
 @RestController
@@ -58,6 +59,8 @@
     private LocOwnerService locOwnerService;
     @Autowired
     private OrderLogService orderLogService;
+    @Autowired
+    private OrderDetlLogService orderDetlLogService;
 
     @RequestMapping(value = "/order/all")
     @ManagerAuth
@@ -71,62 +74,109 @@
 
         return R.ok().add(stockStatis);
     }
-//    @RequestMapping(value = "/order/export")
-//    @ManagerAuth
-//    public void orderExport(HttpServletResponse response,OrderExport orderExport) throws IOException {
-//        List<OrderDetl> orderNo = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", orderExport.getOrderNo()));
-//
-//        response.setContentType("application/vnd.ms-excel");
-//        response.setCharacterEncoding("utf-8");
-//        String templateFileName =
-//                this.getClass().getClassLoader().getResource("ru.xlsx").getPath();;
-//
-//        String fileName =  "complexFill" + System.currentTimeMillis() + ".xlsx";
-//
-//        response.setHeader("Content-disposition", "attachment;filename=" + fileName);
-//        ExcelWriter excelWriter = EasyExcel.write(fileName).withTemplate(templateFileName).build();
-//        WriteSheet writeSheet = EasyExcel.writerSheet().build();
-//        // 杩欓噷娉ㄦ剰 鍏ュ弬鐢ㄤ簡forceNewRow 浠h〃鍦ㄥ啓鍏ist鐨勬椂鍊欎笉绠ist涓嬮潰鏈夋病鏈夌┖琛� 閮戒細鍒涘缓涓�琛岋紝鐒跺悗涓嬮潰鐨勬暟鎹線鍚庣Щ鍔ㄣ�傞粯璁� 鏄痜alse锛屼細鐩存帴浣跨敤涓嬩竴琛岋紝濡傛灉娌℃湁鍒欏垱寤恒��
-//        // forceNewRow 濡傛灉璁剧疆浜唗rue,鏈変釜缂虹偣 灏辨槸浠栦細鎶婃墍鏈夌殑鏁版嵁閮芥斁鍒板唴瀛樹簡锛屾墍浠ユ厧鐢�
-//        // 绠�鍗曠殑璇� 濡傛灉浣犵殑妯℃澘鏈塴ist,涓攍ist涓嶆槸鏈�鍚庝竴琛岋紝涓嬮潰杩樻湁鏁版嵁闇�瑕佸~鍏� 灏卞繀椤昏缃� forceNewRow=true 浣嗘槸杩欎釜灏变細鎶婃墍鏈夋暟鎹斁鍒板唴瀛� 浼氬緢鑰楀唴瀛�
-//        // 濡傛灉鏁版嵁閲忓ぇ list涓嶆槸鏈�鍚庝竴琛� 鍙傜収涓嬩竴涓�
-//        FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
-//        excelWriter.fill(orderNo, fillConfig, writeSheet);
-////        excelWriter.fill(orderNo, fillConfig, writeSheet);
-//        Map<String, Object> map = new HashMap<String, Object>();
-//        map.put("date", "2019骞�10鏈�9鏃�13:28:28");
-//        map.put("total", 1000);
-//        excelWriter.fill(map, writeSheet);
-//        excelWriter.finish();
-//
-//
-//    }
 
     @RequestMapping("/download_excel")
-    public void downloadExcel(HttpServletResponse response,@RequestParam String orderNo) throws IOException {
+    public void downloadExcel(HttpServletResponse response,
+                              @RequestParam String orderNo,
+                              @RequestParam Integer type,
+                              @RequestParam String name,
+                              @RequestParam String threeCode) throws IOException {
+
+        //鑾峰彇鍗曟嵁绫诲瀷
+        DocType docType = docTypeService.selectOne(new EntityWrapper<DocType>().eq("doc_id", type));
+        if (docType.getPakin()==1 && docType.getPakout()==0){
+            type = 1;
+        } else if (docType.getPakin()==0 && docType.getPakout()==1) {
+            type = 2;
+        }else {
+            throw new CoolException("鍗曟嵁绫诲瀷鏈夎");
+        }
+        //璁剧疆http杩斿洖澶村拰鏂囦欢鍚�
         response.setContentType("application/vnd.ms-excel");
         response.setCharacterEncoding("utf-8");
         String fileName = "Order " + orderNo + ".xlsx";
         response.setHeader("Content-disposition", "attachment;filename=" + fileName);
 
+        //excel鍐欏叆鐨勬暟鎹�
+        Map<String, Object> map = new HashMap<String, Object>();
+        map.put("orderNo", orderNo);
+        map.put("name",name);
+        map.put("threeCode",threeCode);
+
         OutputStream outputStream = response.getOutputStream();
-        orderExport(outputStream, orderNo);
+        orderExport(outputStream,type,map);
         outputStream.flush();
         outputStream.close();
     }
 
-    public void orderExport(OutputStream outputStream, String orderNo) throws IOException {
-        List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", orderNo));
+    public void orderExport(OutputStream outputStream,Integer type,Map<String, Object> map) throws IOException {
 
-        String templateFileName = this.getClass().getClassLoader().getResource("ru.xlsx").getPath();
+        //鑾峰彇璁㈠崟鏄庣粏鏁版嵁
+        List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", map.get("orderNo")));
+        List<OrderDetlLog> orderDetlLogs = new ArrayList<>();
+        if (Cools.isEmpty(orderDetls)){
+            orderDetlLogs = orderDetlLogService.selectList(new EntityWrapper<OrderDetlLog>().eq("order_no", map.get("orderNo")));
+        }
+        //鑾峰彇妯$増璺緞
+        String templateFileName = null ;
+        if (type == 1){
+            templateFileName = this.getClass().getClassLoader().getResource("ru.xlsx").getPath();
+        } else if (type ==2 ) {
+            templateFileName = this.getClass().getClassLoader().getResource("cu.xlsx").getPath();
+        }
 
+
+        //鎶婃枃浠跺啓鍏ュ埌outputStream涓�
         ExcelWriter excelWriter = EasyExcel.write(outputStream).withTemplate(templateFileName).build();
         WriteSheet writeSheet = EasyExcel.writerSheet().build();
         FillConfig fillConfig = FillConfig.builder().forceNewRow(Boolean.TRUE).build();
-        excelWriter.fill(orderDetls, fillConfig, writeSheet);
-        Map<String, Object> map = new HashMap<String, Object>();
-        map.put("date", "2019骞�10鏈�9鏃�13:28:28");
-        map.put("orderNo", orderNo);
+
+        //鎬昏鏁伴噺锛岄噸閲�
+        BigDecimal sumWeight = new BigDecimal(0);
+        BigDecimal sumAnfme = new BigDecimal(0);
+
+        if (Cools.isEmpty(orderDetls)){
+            //搴忓彿
+            int i = 1;
+            for (OrderDetlLog orderDetlLog:orderDetlLogs){
+                orderDetlLog.setThreeCode(map.get("threeCode").toString());
+                orderDetlLog.setDanger(i);
+                i++;
+                if (Cools.isEmpty(orderDetlLog.getWeight())){
+                    orderDetlLog.setWeight(0.0);
+                }
+                sumWeight = sumWeight.add(BigDecimal.valueOf(orderDetlLog.getWeight()));
+                sumAnfme = sumAnfme.add(BigDecimal.valueOf(orderDetlLog.getAnfme()));
+            }
+            //鍐欏叆orderDetlLogs涓殑鏁版嵁
+            excelWriter.fill(orderDetlLogs, fillConfig, writeSheet);
+            map.put("comp",orderDetlLogs.get(0).getOwner$());
+            map.put("sumVol",sumWeight);
+            map.put("sumAnfme",sumAnfme);
+        }else {
+            int i = 1;
+            for (OrderDetl orderDetl:orderDetls){
+                orderDetl.setThreeCode(map.get("threeCode").toString());
+                orderDetl.setDanger(i);
+                i++;
+                if (Cools.isEmpty(orderDetl.getWeight())){
+                    orderDetl.setWeight(0.0);
+                }
+                sumWeight = sumWeight.add(BigDecimal.valueOf(orderDetl.getWeight()));
+                sumAnfme = sumAnfme.add(BigDecimal.valueOf(orderDetl.getAnfme()));
+
+            }
+            excelWriter.fill(orderDetls, fillConfig, writeSheet);
+            map.put("comp",orderDetls.get(0).getOwner$());
+            map.put("sumVol",sumWeight);
+            map.put("sumAnfme",sumAnfme);
+        }
+        Date date = new Date();
+        SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy/MM/dd");
+
+        map.put("time",dateFormat.format(date));
+
+        //鍐欏叆map涓殑鏁版嵁
         excelWriter.fill(map, writeSheet);
         excelWriter.finish();
     }

--
Gitblit v1.9.1