From 24a1aa1d7470998522aa28b4abc728fff5bcbaf7 Mon Sep 17 00:00:00 2001
From: zss <zss@example.com>
Date: 星期五, 11 八月 2023 16:00:20 +0800
Subject: [PATCH] WMS--回单管理
---
inventory-server/src/main/java/com/yuanchu/mom/service/impl/ConsignmentServiceImpl.java | 161 +++++++++++++++++++++++++++++++++++++++++------------
1 files changed, 123 insertions(+), 38 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
index 0191276..adbb905 100644
--- 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
@@ -1,19 +1,26 @@
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)琛ㄦ湇鍔″疄鐜扮被
@@ -30,53 +37,131 @@
@Resource
RepertoryMapper repertoryMapper;
+ @Resource
+ ReceiptMapper receiptMapper;
+
//鏂板鎴愬搧鍙戣揣
@Override
public String addCon(String name, ConsignmentDto consignmentDto) {
+ //鐢熸垚涓�涓娂杩愬崟缂栧彿
+ String escortCode = MyUtil.getTimeSixNumberCode("YY");
//濡傛灉璇ヨ鍗曞凡缁忓彂杩囪揣浜嗕笉鑳藉啀鍙戣揣
List<Consignment> consignments = consignmentMapper.selectAll();
- for (Consignment consignment : consignments) {
- if (consignment.getCustomerCode().equals(consignmentDto.getCustomerCode())) {
- return "璇ュ悎鍚岃鍗曞凡鍙戣繃璐�,鏃犳硶鍐嶆鍙戣揣!";
- } else {
- /*鏂板鎴愬搧鍙戣揣*/
- 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(MyUtil.getTimeSixNumberCode("YY"))
- .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 "璇ヤ骇鍝佽繕鏈楠�,涓嶈兘鍙戣揣!";
+ //濡傛灉娌℃湁鍙戣揣琛ㄤ腑娌℃湁鏁版嵁涔熷彲浠ュ彂璐�
+ 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