From 7b09f233bde70508f6db7e08e983e9a2c4bb3e99 Mon Sep 17 00:00:00 2001
From: XiaoRuby <3114200645@qq.com>
Date: 星期五, 11 八月 2023 17:50:23 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 inventory-server/src/main/java/com/yuanchu/mom/service/impl/ConsignmentServiceImpl.java |  167 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 167 insertions(+), 0 deletions(-)

diff --git a/inventory-server/src/main/java/com/yuanchu/mom/service/impl/ConsignmentServiceImpl.java b/inventory-server/src/main/java/com/yuanchu/mom/service/impl/ConsignmentServiceImpl.java
new file mode 100644
index 0000000..adbb905
--- /dev/null
+++ b/inventory-server/src/main/java/com/yuanchu/mom/service/impl/ConsignmentServiceImpl.java
@@ -0,0 +1,167 @@
+package com.yuanchu.mom.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.yuanchu.mom.mapper.ConsignmentMapper;
+import com.yuanchu.mom.mapper.ReceiptMapper;
+import com.yuanchu.mom.mapper.RepertoryMapper;
+import com.yuanchu.mom.pojo.Consignment;
+import com.yuanchu.mom.pojo.Receipt;
+import com.yuanchu.mom.pojo.Repertory;
+import com.yuanchu.mom.pojo.dto.ConsignmentDto;
+import com.yuanchu.mom.pojo.dto.ConsignmentDto2;
+import com.yuanchu.mom.service.ConsignmentService;
+import com.yuanchu.mom.utils.MyUtil;
+import org.springframework.beans.BeanUtils;
+import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.util.Date;
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 鎴愬搧鍙戣揣琛�(Consignment)琛ㄦ湇鍔″疄鐜扮被
+ *
+ * @author zss
+ * @since 2023-08-10 15:08:02
+ */
+@Service
+public class ConsignmentServiceImpl extends ServiceImpl<ConsignmentMapper, Consignment> implements ConsignmentService {
+
+    @Resource
+    ConsignmentMapper consignmentMapper;
+
+    @Resource
+    RepertoryMapper repertoryMapper;
+
+    @Resource
+    ReceiptMapper receiptMapper;
+
+    //鏂板鎴愬搧鍙戣揣
+    @Override
+    public String addCon(String name, ConsignmentDto consignmentDto) {
+        //鐢熸垚涓�涓娂杩愬崟缂栧彿
+        String escortCode = MyUtil.getTimeSixNumberCode("YY");
+        //濡傛灉璇ヨ鍗曞凡缁忓彂杩囪揣浜嗕笉鑳藉啀鍙戣揣
+        List<Consignment> consignments = consignmentMapper.selectAll();
+        //濡傛灉娌℃湁鍙戣揣琛ㄤ腑娌℃湁鏁版嵁涔熷彲浠ュ彂璐�
+        if (consignments.size()==0) {
+            /*鏂板鎴愬搧鍙戣揣*/
+            String mes1 = addConsign(name, consignmentDto, escortCode);
+            return mes1;
+        } else {
+            for (Consignment consignment : consignments) {
+                if (consignment.getCustomerCode().equals(consignmentDto.getCustomerCode())) {
+                    return "璇ュ悎鍚岃鍗曞凡鍙戣繃璐�,鏃犳硶鍐嶆鍙戣揣!";
+                } else {
+                    /*鏂板鎴愬搧鍙戣揣*/
+                    String mes2 = addConsign(name, consignmentDto, escortCode);
+                    return mes2;
+                }
+            }
+        }
+        return null;
+    }
+
+    //鏌ヨ鍙戣揣璁板綍鍒楄〃
+    @Override
+    public IPage<Map<String, Object>> selectAllCon(Page<Object> page, String name, String specifications, String time) {
+        return consignmentMapper.selectAllCon(page, name, specifications, time);
+    }
+
+    //鏍规嵁id鍒犻櫎
+    @Override
+    public void delCon(Integer id) {
+        //鍒犻櫎鍙戣揣璁板綍
+        Consignment consignment = consignmentMapper.selectById(id);
+        consignment.setState(0);
+        consignmentMapper.updateById(consignment);
+        //搴撳瓨涔熻鏂板
+        LambdaQueryWrapper<Repertory> queryWrapper = new LambdaQueryWrapper<>();
+        queryWrapper.eq(Repertory::getCode, consignment.getCode())
+                .eq(Repertory::getName, consignment.getName())
+                .eq(Repertory::getSpecifications, consignment.getSpecifications())
+                .eq(Repertory::getUnit, consignment.getUnit())
+                .eq(Repertory::getType, 0) //鎴愬搧鍙戣揣
+                .eq(Repertory::getCheckState, 1); //鍙湁宸叉楠屾墠鑳藉彂璐�
+        Repertory repertory = repertoryMapper.selectOne(queryWrapper);
+        repertory.setNumber(repertory.getNumber() + consignment.getNumber());
+        repertoryMapper.updateById(repertory);
+    }
+
+    //鎵归噺鍒犻櫎
+    @Override
+    public void delAllCon(List<Integer> ids) {
+        List<Consignment> consignments = consignmentMapper.selectBatchIds(ids);
+        for (Consignment consignment : consignments) {
+            consignment.setState(0);
+            //鍒犻櫎鍙戣揣璁板綍
+            consignmentMapper.updateById(consignment);
+            //搴撳瓨鏂板
+            LambdaQueryWrapper<Repertory> queryWrapper = new LambdaQueryWrapper<>();
+            queryWrapper.eq(Repertory::getCode, consignment.getCode())
+                    .eq(Repertory::getName, consignment.getName())
+                    .eq(Repertory::getSpecifications, consignment.getSpecifications())
+                    .eq(Repertory::getUnit, consignment.getUnit())
+                    .eq(Repertory::getType, 0) //鎴愬搧鍙戣揣
+                    .eq(Repertory::getCheckState, 1); //鍙湁宸叉楠屾墠鑳藉彂璐�
+            Repertory repertory = repertoryMapper.selectOne(queryWrapper);
+            repertory.setNumber(repertory.getNumber() + consignment.getNumber());
+            repertoryMapper.updateById(repertory);
+        }
+    }
+
+
+    //鏂板鍙戣揣涓�绯诲垪鎿嶄綔
+    private String addConsign(String name, ConsignmentDto consignmentDto, String escortCode) {
+        /*鏂板鎴愬搧鍙戣揣*/
+        List<ConsignmentDto2> messages = consignmentDto.getMessages();
+        for (ConsignmentDto2 message : messages) {
+            //鏌ヨ浜у搧缂栫爜(閫氳繃鍦ㄦ垚鍝佸簱瀛樿〃涓殑浜у搧鍚嶇О,瑙勬牸鍨嬪彿浠ュ強鍗曚綅杩涜鏌ユ壘)
+            LambdaQueryWrapper<Repertory> queryWrapper = new LambdaQueryWrapper<>();
+            queryWrapper.eq(Repertory::getName, message.getName())
+                    .eq(Repertory::getSpecifications, message.getSpecifications())
+                    .eq(Repertory::getUnit, message.getUnit())
+                    .eq(Repertory::getType, 0);
+            Repertory repertory = repertoryMapper.selectOne(queryWrapper);
+            //璇ユ垚鍝佺殑妫�楠岀姸鎬佹槸宸叉楠�1鎵嶈兘杩涜鍙戣揣
+            if (repertory.getCheckState() == 1) {
+                //璇ユ垚鍝佸簱瀛樼殑鏁伴噺澶т簬绛変簬鍙戣揣鐨勬暟閲忔墠鑳借繘琛屽彂璐�
+                if (repertory.getNumber() >= message.getNumber()) {
+                    //鏋勯�犳垚鍝佸彂璐у疄浣撶被
+                    Consignment consig = Consignment.builder()
+                            .customerCode(consignmentDto.getCustomerCode())
+                            .escortCode(escortCode)
+                            .orderCode(consignmentDto.getOrderCode())
+                            .userName(name)
+                            .checkName(consignmentDto.getCheckName())
+                            .fitName(consignmentDto.getFitName())
+                            .name(message.getName())
+                            .specifications(message.getSpecifications())
+                            .unit(message.getUnit())
+                            .number(message.getNumber())
+                            .code(repertory.getCode())
+                            .build();
+                    consignmentMapper.insert(consig);
+                    /*鍑忓皯瀵瑰簲鐨勫簱瀛�*/
+                    repertory.setNumber(repertory.getNumber() - consig.getNumber());
+                    repertoryMapper.updateById(repertory);
+                } else return "搴撳瓨涓嶈冻,鏃犳硶鍙戣揣!";
+            } else return "璇ヤ骇鍝佽繕鏈楠�,涓嶈兘鍙戣揣!";
+        }
+        /*鍙戣揣鎴愬姛涔嬪悗闇�瑕佹柊澧炰竴寮犲洖鍗�*/
+        Receipt receipt = new Receipt();
+        BeanUtils.copyProperties(consignmentDto, receipt);
+        receipt.setName(consignmentDto.getUsername());//鏀惰揣鑱旂郴浜�
+        receipt.setUserName(name);//鍙戣揣浜�
+        receipt.setEscortCode(escortCode);//鎶艰繍鍗曠紪鍙�
+        receipt.setDeliverTime(new Date());//鍙戣揣鏃ユ湡
+        receiptMapper.insert(receipt);
+        return "鍙戣揣鎴愬姛!";
+    }
+}
+
+

--
Gitblit v1.9.3