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 |  245 ++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 240 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/OrderController.java b/src/main/java/com/zy/asrs/controller/OrderController.java
index 4be0ae7..d6666bf 100644
--- a/src/main/java/com/zy/asrs/controller/OrderController.java
+++ b/src/main/java/com/zy/asrs/controller/OrderController.java
@@ -1,6 +1,10 @@
 package com.zy.asrs.controller;
 
 import com.alibaba.excel.EasyExcel;
+import com.alibaba.excel.ExcelWriter;
+
+import com.alibaba.excel.write.metadata.WriteSheet;
+import com.alibaba.excel.write.metadata.fill.FillConfig;
 import com.alibaba.excel.write.style.column.LongestMatchColumnWidthStyleStrategy;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.mapper.EntityWrapper;
@@ -12,18 +16,28 @@
 import com.sun.org.apache.xpath.internal.operations.Or;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.entity.param.OrderDomainParam;
+import com.zy.asrs.entity.result.LocDetlAll;
 import com.zy.asrs.entity.result.OrderDetlVo;
 import com.zy.asrs.service.*;
 import com.zy.common.CodeRes;
+import com.zy.common.config.AdminInterceptor;
 import com.zy.common.model.DetlDto;
+import com.zy.common.utils.BarcodeUtils;
+import com.zy.common.utils.QrCode;
 import com.zy.common.web.BaseController;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.web.bind.annotation.*;
 
+import javax.imageio.ImageIO;
 import javax.servlet.http.HttpServletResponse;
+import java.awt.image.BufferedImage;
+import java.io.File;
 import java.io.IOException;
+import java.io.OutputStream;
+import java.math.BigDecimal;
 import java.net.URLEncoder;
+import java.text.SimpleDateFormat;
 import java.util.*;
 
 @RestController
@@ -45,6 +59,127 @@
     private LocOwnerService locOwnerService;
     @Autowired
     private OrderLogService orderLogService;
+    @Autowired
+    private OrderDetlLogService orderDetlLogService;
+
+    @RequestMapping(value = "/order/all")
+    @ManagerAuth
+    public R statis2(@RequestParam(defaultValue = "1")Integer curr,
+                     @RequestParam(defaultValue = "10")Integer limit,
+                     @RequestParam Map<String, Object> param) {
+
+
+
+        Page<Order> stockStatis = orderService.getOrderAll(toPage(curr, limit, param, Order.class));
+
+        return R.ok().add(stockStatis);
+    }
+
+    @RequestMapping("/download_excel")
+    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,type,map);
+        outputStream.flush();
+        outputStream.close();
+    }
+
+    public void orderExport(OutputStream outputStream,Integer type,Map<String, Object> map) throws IOException {
+
+        //鑾峰彇璁㈠崟鏄庣粏鏁版嵁
+        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();
+
+        //鎬昏鏁伴噺锛岄噸閲�
+        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();
+    }
 
     @RequestMapping(value = "/order/nav/list/auth")
     @ManagerAuth
@@ -94,7 +229,16 @@
     @RequestMapping(value = "/order/detl/all/auth")
     @ManagerAuth
     public R head(@RequestParam Long orderId){
-        return R.ok().add(orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_id", orderId)));
+        List<OrderDetl> orderDetls = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_id", orderId));
+        List<OrderDetl> orderDetls1 = new ArrayList<>();
+        for (OrderDetl orderDetl : orderDetls){
+            double v = orderDetl.getAnfme() - orderDetl.getWorkQty();
+            double v1 = new BigDecimal(v).setScale(2, BigDecimal.ROUND_HALF_UP).doubleValue();
+            if (v1!=0.0){
+                orderDetls1.add(orderDetl);
+            }
+        }
+        return R.ok().add(orderDetls1);
     }
 
     @RequestMapping(value = "/order/form/add/auth")
@@ -116,6 +260,15 @@
         }
         if (orderLog != null) {
             return R.error("鍗曟嵁缂栧彿鍦ㄥ巻鍙叉。涓凡瀛樺湪");
+        }
+        OrderDetl orderDetl1 = new OrderDetl();
+        for (OrderDetl orderDetl : param.getOrderDetlList()) {
+            if (orderDetl1.getId() == null){
+                orderDetl1.sync(orderDetl);
+            }
+            if (orderDetl1.getOwner() != orderDetl.getOwner()){
+                return R.error("鍚屼釜鍗曟嵁涓彧鑳藉瓨鍦ㄤ竴涓揣涓讳唬鐮�");
+            }
         }
         Date now = new Date();
         order = new Order(
@@ -207,6 +360,17 @@
         if (order == null || order.getStatus() == 0) {
             return R.error("璁㈠崟涓嶅瓨鍦�");
         }
+
+        OrderDetl orderDetl1 = new OrderDetl();
+        for (OrderDetl orderDetl : param.getOrderDetlList()) {
+            if (orderDetl1.getId() == null){
+                orderDetl1.sync(orderDetl);
+            }
+            if (orderDetl1.getOwner() != orderDetl.getOwner()){
+                return R.error("鍚屼釜鍗曟嵁涓彧鑳藉瓨鍦ㄤ竴涓揣涓讳唬鐮�");
+            }
+        }
+
         Date now = new Date();
         Long userId = getUserId();
         // 淇敼涓绘。
@@ -391,9 +555,8 @@
         locCheckEntityWrapper.eq("order_no",orderNo);
         List<OrderDetl> list = orderDetlService.selectList(locCheckEntityWrapper);
         List<OrderDetlVo> orderDetlVos=new ArrayList<>();
-        OrderDetlVo orderDetlVo=new OrderDetlVo();
-        for (OrderDetl o:
-             list) {
+        for (OrderDetl o:list) {
+            OrderDetlVo orderDetlVo=new OrderDetlVo();
             orderDetlVo.setOrderNo(o.getOrderNo());
             orderDetlVo.setMatnr(o.getMatnr());
             orderDetlVo.setMaktx(o.getMaktx());
@@ -434,10 +597,82 @@
         return R.ok(orderService.selectAllorderNo());
     }
 
+    @RequestMapping(value = "/order/list/AllCu")
+    @ManagerAuth
+    public R orderCuList(@RequestParam(required = false) String orderNo){
+        EntityWrapper<Order> wrapper = new EntityWrapper<>();
+        if (!Cools.isEmpty(orderNo)) {
+            wrapper.like("order_no", orderNo);
+        }
+        wrapper.le("settle", 2).eq("status", 1);
+        wrapper.orderBy("create_time", false);
+        List<Order> orders = orderService.selectList(wrapper);
+        // 淇濈暀鍑哄簱鍗�
+        if (!Cools.isEmpty(orders)) {
+            Iterator<Order> iterator = orders.iterator();
+            while (iterator.hasNext()) {
+                Order order = iterator.next();
+                if (order.getDocType() != null) {
+                    DocType docType = docTypeService.selectById(order.getDocType());
+                    if (docType != null) {
+                        if (docType.getPakout() == 1) {
+                            iterator.remove();
+                        }
+                    }
+                }
+            }
+        }
+        return R.ok().add(orders);
+    }
+
+    //璁㈠崟缁勬墭2
     @RequestMapping(value = "/order/list/orderNo")
     public R orderListorderNo(@RequestParam String orderNo) {
+        //鏁伴噺淇敼鎴愪负瀹屾垚鏁伴噺
+        List<OrderDetl> orderDetl1=orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",orderNo));
+        List<OrderDetl> orderDetls= new ArrayList<OrderDetl>();
+        for (OrderDetl o: orderDetl1) {
+            o.setAnfme(o.getAnfme()-o.getWorkQty());
+            BigDecimal c1 = new BigDecimal(o.getAnfme()).setScale(2,BigDecimal.ROUND_HALF_UP);
+            o.setAnfme(c1.doubleValue());
+            orderDetls.add(o);
+        }
+        return R.ok(orderDetls);
+    }
 
-        return R.ok(orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no",orderNo)));
+    @RequestMapping(value = "/order/print2/auth")
+    @ManagerAuth(memo = "璁㈠崟缂栫爜鎵撳嵃")
+    public R manPakOutPrint(@RequestParam(value = "param[]") String[] param) {
+        if(Cools.isEmpty(param)) {
+            return R.parse(CodeRes.EMPTY);
+        }
+        List<OrderDetl> res = new ArrayList<>();
+        for (String orderNo : param){
+            res = orderDetlService.selectList(new EntityWrapper<OrderDetl>().eq("order_no", orderNo));
+        }
+        return R.ok().add(res);
+    }
+    @RequestMapping(value = "/order/code/auth")
+//    @ManagerAuth(memo = "鐗╂枡缂栫爜鏉″舰鐮佽幏鍙�(type:1(鏉″舰鐮�);2(浜岀淮鐮�)")
+    public R manPakOutCodeBarcode(@RequestParam(defaultValue = "2") Integer type
+            , @RequestParam String param
+            , HttpServletResponse response) throws Exception {
+        AdminInterceptor.cors(response);
+        if (Cools.isEmpty(param)){
+            return R.parse(BaseRes.EMPTY);
+        }
+        BufferedImage img;
+        if (type == 1) {
+            img = BarcodeUtils.encode(param);
+        } else {
+            img = QrCode.createImg(param);
+        }
+        if (!ImageIO.write(img, "jpg", response.getOutputStream())) {
+            throw new IOException("Could not write an image of format jpg");
+        }
+        response.getOutputStream().flush();
+        response.getOutputStream().close();
+        return R.ok();
     }
 
 

--
Gitblit v1.9.1