From dbe3ed318dfe013663271fd64c8b8b152005e0b6 Mon Sep 17 00:00:00 2001
From: liurunyu <lry9898@163.com>
Date: 星期二, 08 十月 2024 09:31:32 +0800
Subject: [PATCH] Merge branch 'master' of http://8.140.179.55:20000/r/pms-SV

---
 pms-parent/pms-web-product/src/main/java/com/dy/pmsProduct/order/OrderSv.java |  203 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 203 insertions(+), 0 deletions(-)

diff --git a/pms-parent/pms-web-product/src/main/java/com/dy/pmsProduct/order/OrderSv.java b/pms-parent/pms-web-product/src/main/java/com/dy/pmsProduct/order/OrderSv.java
new file mode 100644
index 0000000..4c909c6
--- /dev/null
+++ b/pms-parent/pms-web-product/src/main/java/com/dy/pmsProduct/order/OrderSv.java
@@ -0,0 +1,203 @@
+package com.dy.pmsProduct.order;
+
+import com.dy.common.webFilter.UserTokenContext;
+import com.dy.common.webUtil.QueryResultVo;
+import com.dy.pmsGlobal.daoPr.*;
+import com.dy.pmsGlobal.pojoBa.BaUser;
+import com.dy.pmsGlobal.pojoPr.*;
+import com.dy.pmsGlobal.util.UserUtil;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.dubbo.common.utils.PojoUtils;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.time.LocalDate;
+import java.time.format.DateTimeFormatter;
+import java.util.List;
+import java.util.Map;
+
+@Slf4j
+@Service
+public class OrderSv {
+    private PrOrderMapper orderDao;
+    private PrOrderItemMapper orderItemDao;
+    private UserUtil userUtil;
+
+    @Autowired
+    public void setOrderDao(PrOrderMapper orderDao) {
+        this.orderDao = orderDao;
+    }
+
+    @Autowired
+    public void setOrderItemDao(PrOrderItemMapper orderItemDao) {
+        this.orderItemDao = orderItemDao;
+    }
+
+    @Autowired
+    public void setUserUtil(UserUtil userUtil) {
+        this.userUtil = userUtil;
+    }
+
+    @Transactional
+    public int save(PrOrder p) {
+        p.id = null;
+        //鍒ゆ柇浜у搧涓嶈兘閲嶅悕
+        if (orderDao.exists(p.name, p.id)) {
+            throw new RuntimeException("璁㈠崟鍚嶇О涓嶈兘閲嶅");
+        }
+        extractedCheck(p);
+        p.deleted = false;
+        BaUser loginUser = userUtil.getUser(UserTokenContext.get());
+        if (loginUser != null) {
+            p.creator = loginUser.id;
+        }
+        int count = orderDao.insertSelective(p);
+        saveOrderItems(p);
+        return count;
+    }
+
+    @Transactional
+    public int update(PrOrder p) {
+        if (orderDao.exists(p.name, p.id)) {
+            throw new RuntimeException("璁㈠崟鍚嶇О涓嶈兘閲嶅");
+        }
+        extractedCheck(p);
+        int count = orderDao.updateByPrimaryKeySelective(p);
+        if (count > 0) {
+            saveOrderItems(p);
+        }
+        return count;
+    }
+
+    private void saveOrderItems(PrOrder p) {
+        p.items.forEach(param -> {
+            param.orderId = p.id;
+            if (param.id != null) {
+                orderItemDao.updateByPrimaryKeySelective(param);
+            } else {
+                param.deleted = false;
+                orderItemDao.insert(param);
+            }
+        });
+    }
+
+    /**
+     * 閫昏緫鍒犻櫎瀹炰綋
+     *
+     * @param id 瀹炰綋ID
+     * @return 褰卞搷璁板綍鏁伴噺
+     */
+    @Transactional
+    public int delete(Long id) {
+        return orderDao.deleteLogicById(id);
+    }
+
+    public PrOrder selectById(String proId) {
+        PrOrder pro = orderDao.selectByPrimaryKey(Long.valueOf(proId));
+        changeRate(pro);
+        return pro;
+    }
+
+    /**
+     * 鑾峰彇璁㈠崟鍒楄〃
+     */
+    public QueryResultVo<List<PrOrder>> selectSome(QueryVo queryVo) {
+        Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo);
+
+        //鏌ヨ绗﹀悎鏉′欢鐨勮褰曟�绘暟
+        Long itemTotal = orderDao.selectSomeCount(params);
+
+        QueryResultVo<List<PrOrder>> rsVo = new QueryResultVo<>(queryVo.pageSize, queryVo.pageCurr);
+        //璁$畻鍒嗛〉绛変俊鎭�
+        rsVo.calculateAndSet(itemTotal, params);
+
+        List<PrOrder> orderList = orderDao.selectSome(params);
+        for (PrOrder prOrder : orderList) {
+            changeRate(prOrder);
+        }
+        //鏌ヨ绗﹀悎鏉′欢鐨勮褰�
+        rsVo.obj = orderList;
+        return rsVo;
+    }
+
+    private void changeRate(PrOrder prOrder) {
+        if (prOrder != null && prOrder.items != null) {
+            List<PrOrderItem> items = prOrder.items;
+            for (int i = 1; i < items.size(); i++) {
+                for (int j = i - 1; j >= 0; j--) {
+                    //鎷跨潃i渚濇璺熶笂涓�涓瘮杈�,濡傛灉浜у搧鐩稿悓,鍒欎笂涓�涓褰昪omplete_number - number 濡傛灉 > 0 鍒嗙粰i ,濡傛灉 < 0 鍒欏皢 complete_number 缃负0
+                    if (items.get(j).getProId().intValue() == items.get(i).getProId().intValue()) {
+                        int remainNumber = items.get(j).getCompleteNumber() - items.get(j).getNumber();
+                        if (remainNumber > 0) {
+                            items.get(j).setCompleteNumber(items.get(j).getNumber());
+                            items.get(j).setCompleteRate("100.00%");
+                            items.get(i).setCompleteNumber(remainNumber);
+                            BigDecimal remainBig = new BigDecimal(remainNumber * 100);
+                            BigDecimal iNumberBig = new BigDecimal(items.get(i).getNumber());
+                            BigDecimal result = remainBig.divide(iNumberBig, 2, RoundingMode.HALF_UP);
+                            items.get(i).setCompleteRate(result.toString() + "%");
+                        } else {
+                            items.get(i).setCompleteNumber(0);
+                            items.get(i).setCompleteRate("0.00%");
+                        }
+                        break;
+                    }
+                }
+            }
+        }
+    }
+
+    public List<PrOrder> selectAll(QueryVo queryVo) {
+        Map<String, Object> params = (Map<String, Object>) PojoUtils.generalize(queryVo);
+        List<PrOrder> orderList = orderDao.selectAll(params);
+        for (PrOrder prOrder : orderList) {
+            changeRate(prOrder);
+        }
+        return orderList;
+    }
+
+    /**
+     * 鍙洿鏂扮姸鎬�,涓嶆洿鏂板叾浠栧瓧娈�
+     *
+     * @param order 鏇存柊鐘舵��  濡傛灉鏈夊湪鎵ц涓殑浠诲姟,涓嶈鏆傚仠
+     * @return
+     */
+    @Transactional
+    public int updateStatus(PrOrder order) {
+        if (order.status == OrderStatusEnum.NORMAL.getCode()) {
+            PrOrder prOrder = orderDao.selectByPrimaryKey(order.id);
+            prOrder.status = order.status;
+            extractedCheck(prOrder);
+        }
+        PrOrder param = new PrOrder();
+        param.id = order.id;
+        param.status = order.status;
+        return orderDao.updateByPrimaryKeySelective(param);
+    }
+
+    //濡傛灉浜ゆ湡灏忎簬褰撳墠鏃堕棿,涓嶅厑璁歌缃负姝e父
+    private void extractedCheck(PrOrder order) {
+        if (order.status == OrderStatusEnum.NORMAL.getCode()) {
+            String deliveryDateStr = order.getDeliveryDate();
+            LocalDate endDate = LocalDate.parse(deliveryDateStr, DateTimeFormatter.ISO_LOCAL_DATE);
+            LocalDate nextDay = endDate.plusDays(1);
+            LocalDate today = LocalDate.now(); // 鑾峰彇褰撳墠鏃ユ湡
+            if (nextDay.isBefore(today)) {
+                throw new RuntimeException("浜や粯鏃ユ湡蹇呴』澶т簬绛変簬褰撳墠鏃ユ湡,璇蜂慨鏀逛氦浠樻棩鏈�");
+            }
+        }
+        //濡傛灉鏈夊湪鐢熶骇鐨勪换鍔′笉鑳借缃负鏆傚仠 鎴� 缁撴潫
+ /*
+        PrProductionProcess process = processDao.selectByPrimaryKey(order.processId);
+        if(process == null || !process.proId.equals(order.proId)){
+            throw new RuntimeException("浜у搧涓庣敓浜ф祦绋嬩笉鍖归厤");
+        }
+        //寮�濮嬫棩鏈熻灏忎簬缁撴潫鏃ユ湡
+        if(order.startDate.compareTo(order.endDate) > 0){
+            throw new RuntimeException("寮�濮嬫棩鏈熶笉鑳藉ぇ浜庣粨鏉熸棩鏈�");
+        }*/
+    }
+}
\ No newline at end of file

--
Gitblit v1.8.0