From ef5a518c3e2c1fe41aa60f56ca31ddafa0cb1561 Mon Sep 17 00:00:00 2001 From: guoyuji <guoyujie@ng.com> Date: 星期四, 23 五月 2024 08:32:36 +0800 Subject: [PATCH] 添加产品汇总报表 --- north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java | 100 +++++++++++++++++++++++++++++++++++++------------ 1 files changed, 75 insertions(+), 25 deletions(-) diff --git a/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java b/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java index 1473de8..f774212 100644 --- a/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java +++ b/north-glass-erp/src/main/java/com/example/erp/service/sd/DeliveryService.java @@ -1,19 +1,15 @@ package com.example.erp.service.sd; import com.alibaba.excel.util.StringUtils; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; +import com.alibaba.fastjson.TypeReference; import com.baomidou.dynamic.datasource.annotation.DS; -import com.example.erp.entity.sd.Delivery; -import com.example.erp.entity.sd.DeliveryDetail; -import com.example.erp.entity.sd.Order; -import com.example.erp.entity.sd.OrderDetail; +import com.example.erp.entity.sd.*; import com.example.erp.entity.userInfo.SysError; import com.example.erp.mapper.mm.FinishedGoodsInventoryMapper; -import com.example.erp.mapper.sd.DeliveryDetailMapper; -import com.example.erp.mapper.sd.DeliveryMapper; -import com.example.erp.mapper.sd.OrderDetailMapper; -import com.example.erp.mapper.sd.OrderMapper; +import com.example.erp.mapper.sd.*; import com.example.erp.service.userInfo.SysErrorService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @@ -23,7 +19,7 @@ import java.text.SimpleDateFormat; import java.time.LocalDate; import java.util.*; -import java.math.BigDecimal; +import java.util.concurrent.atomic.AtomicReference; @Service @DS("sd") @@ -39,6 +35,8 @@ OrderDetailMapper orderDetailMapper; @Autowired FinishedGoodsInventoryMapper finishedGoodsInventoryMapper; + @Autowired + DeliveryOtherMoneyMapper deliveryOtherMoneyMapper; @Autowired SysErrorService sysErrorService; @@ -87,6 +85,28 @@ return map; } + public Map<String, Object> getSelectDeliveryDetailProductReport(Integer pageNum, Integer pageSize,List<String> selectDate, DeliveryDetail deliveryDetail) { + Integer offset = (pageNum - 1) * pageSize; + String endDate = LocalDate.now().toString(); + String startDate = LocalDate.now().minusDays(15).toString(); + if(selectDate !=null && selectDate.size()==2){ + if(!selectDate.get(0).isEmpty()){ + startDate = selectDate.get(0); + } + if(!selectDate.get(1).isEmpty()){ + endDate = selectDate.get(1); + } + } + Map<String, Object> map = new HashMap<>(); + map.put("data", deliveryDetailMapper.getSelectDeliveryDetailProductReport(offset, pageSize,startDate,endDate, deliveryDetail)); + map.put("total", deliveryDetailMapper.getSelectDeliveryDetailProductReportPageTotal(offset, pageSize,startDate,endDate, deliveryDetail)); + List<String> list = new ArrayList<>(); + list.add(startDate); + list.add(endDate); + map.put("selectDate",list); + return map; + } + public Map<String, Object> getSelectShippingOrderDetail(Integer pageNum, Integer pageSize, OrderDetail orderDetail) { Integer offset = (pageNum - 1) * pageSize; @@ -94,6 +114,7 @@ map.put("data", deliveryDetailMapper.getSelectShippingOrderDetail(offset, pageSize, orderDetail)); map.put("delivery", deliveryMapper.getSelectShippingOrderDetailDelivery(offset, pageSize, orderDetail)); map.put("total", deliveryDetailMapper.getSelectShippingOrderDetailPageTotal(offset, pageSize, orderDetail)); + map.put("orderOtherMoneyList",deliveryOtherMoneyMapper.findById(orderDetail.getDeliveryDetail().getDeliveryId())); return map; } @@ -134,15 +155,18 @@ boolean saveState = true; //璁剧疆鍥炴粴鐐� Object savePoint = TransactionAspectSupport.currentTransactionStatus().createSavepoint(); - try { - String deliveryId = ""; + + String deliveryId=""; String oddNumber; if (object.get("deliveryId") != null) { deliveryId = object.get("deliveryId").toString(); + } else { + deliveryId = ""; } Delivery delivery = JSONObject.parseObject(JSONObject.toJSONString(object.get("title")), Delivery.class); List<OrderDetail> orderDetaillist = JSONArray.parseArray(JSONObject.toJSONString(object.get("delivery")), OrderDetail.class); + List<DeliveryOtherMoney> deliveryOtherMoneyList = JSONArray.parseArray(JSONObject.toJSONString(object.get("otherMoney")), DeliveryOtherMoney.class); //鏌ヨ鍙戣揣鍗曟槸鍚﹀瓨鍦� Integer deliveryConut = deliveryMapper.getDeliveryConut(deliveryId); @@ -159,6 +183,7 @@ } } + List<DeliveryDetail> deliveryDetaillist = deliveryDetailMapper.getIsNotDeliveryDetail(deliveryDetailNumber, deliveryId); if (!deliveryDetaillist.isEmpty()) { for (DeliveryDetail deliveryDetail : deliveryDetaillist) { @@ -168,9 +193,11 @@ } } //杩樺師鍙戣揣琛ㄧ殑闈㈢Н鏁伴噺閲戦 - deliveryMapper.updatedelivery(0.0, 0, 0.0, deliveryId); + deliveryMapper.updatedelivery(0.0, 0, 0.0,0.0, deliveryId); //鍒犻櫎鍙戣揣鏄庣粏鐨勬暟鎹� deliveryDetailMapper.deleteDeliveryDetail(deliveryId); + //鍒犻櫎璁㈠崟棰濆閲戦鐨勬暟鎹� + deliveryOtherMoneyMapper.deleteDeliveryOtherMoney(deliveryId); oddNumber = deliveryId; } else { //鑾峰彇鍗曞彿 @@ -178,11 +205,17 @@ //鏂板鍙戣揣琛ㄦ暟鎹� deliveryMapper.insertDelivery(delivery, oddNumber, orderDetaillist.get(0).getOrderId()); } - Double area = 0.0; + double area = 0.0; Integer quantity = 0; - Double money = 0.0; - //鑾峰彇瀵硅薄闆嗗悎寰幆杩涜鏂板淇敼 + double money = 0.0; + AtomicReference<Double> otherMoney = new AtomicReference<>(0.0); + //鍏堟妸鍏朵粬閲戦鍓〃鐨勯噾棰濅笌鏁伴噺缃�0 + deliveryOtherMoneyList.forEach(deliveryOtherMoney -> { + deliveryOtherMoney.setQuantity(0.0); + }); + + //鑾峰彇瀵硅薄闆嗗悎寰幆杩涜鏂板淇敼 if (!orderDetaillist.isEmpty()) { for (OrderDetail orderDetail : orderDetaillist) { @@ -190,6 +223,21 @@ area += orderDetail.getFinishedGoodsInventory().getActualSignalArea() * orderDetail.getDeliveryDetail().getQuantity(); money += orderDetail.getPrice() * orderDetail.getDeliveryDetail().getQuantity(); Integer deliveryDetailmaximum = deliveryDetailMapper.getdeliveryDetailmaximum(oddNumber); + + Map<String,Double> otherColumns = JSON.parseObject(orderDetail.getOtherColumns(), new TypeReference<Map<String, Double>>(){}); + if(otherColumns!=null){ + otherColumns.forEach((key, value) ->{ + if(value!=null) { + deliveryOtherMoneyList.forEach(deliveryOtherMoney ->{ + if(deliveryOtherMoney.getColumn().equals(key)){ + deliveryOtherMoney.setQuantity(deliveryOtherMoney.getQuantity()+(value * orderDetail.getDeliveryDetail().getQuantity())); + } + }); + + } + }); + } + //鏂板鍙戣揣鏄庣粏鏁版嵁 deliveryDetailMapper.insertDeliveryDetail(orderDetail, oddNumber, deliveryDetailmaximum + 1); //淇敼璁㈠崟鏄庣粏 @@ -198,22 +246,24 @@ finishedGoodsInventoryMapper.updateInventoryquantityOut(orderDetail.getOrderId(), orderDetail.getOrderNumber(), orderDetail.getDeliveryDetail().getQuantity()); } + //寰�璁㈠崟鍏朵粬閲戦鍓〃浼犲叆鏁版嵁 + deliveryOtherMoneyList.forEach(deliveryOtherMoney ->{ + deliveryOtherMoney.setId(null); + deliveryOtherMoney.setDeliveryId(oddNumber); + if(deliveryOtherMoney.getQuantity()!=null && deliveryOtherMoney.getPrice()!=null){ + deliveryOtherMoney.setMoney((deliveryOtherMoney.getQuantity()*deliveryOtherMoney.getPrice())); + otherMoney.updateAndGet(v -> new Double((double) (v + deliveryOtherMoney.getMoney()))); + deliveryOtherMoneyMapper.insertDeliveryOtherMoney(deliveryOtherMoney); + } + }); //淇敼鍙戣揣鏄庣粏绱姞闈㈢Н鏁伴噺閲戦 - deliveryMapper.updatedelivery(Double.valueOf(String.format("%.2f", area)), quantity, Double.valueOf(String.format("%.2f", money)), oddNumber); + deliveryMapper.updatedelivery(Double.valueOf(String.format("%.2f", area)), quantity, Double.valueOf(String.format("%.2f", money)), otherMoney.get(), oddNumber); } else { return false; } - } catch (Exception e) { - TransactionAspectSupport.currentTransactionStatus().rollbackToSavepoint(savePoint); - //灏嗗紓甯镐紶鍏ユ暟鎹簱 - SysError sysError = new SysError(); - sysError.setError(e.toString()); - sysError.setFunc("saveOrder"); - sysErrorService.insert(sysError); - saveState = false; - } + return saveState; } -- Gitblit v1.8.0