From 1ea84a23004ebcfaf86cb436d84164602ca9091d Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期五, 08 八月 2025 17:03:36 +0800
Subject: [PATCH] Merge branch 'devlop' of http://47.97.1.152:5880/r/wms-master into devlop
---
rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java | 110 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 108 insertions(+), 2 deletions(-)
diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java
index 14cb3b8..cf8c3b1 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java
@@ -1,12 +1,118 @@
package com.vincent.rsf.server.manager.service.impl;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.toolkit.StringUtils;
+import com.vincent.rsf.framework.exception.CoolException;
+import com.vincent.rsf.server.manager.controller.params.ReviseLogItemParams;
+import com.vincent.rsf.server.manager.entity.*;
import com.vincent.rsf.server.manager.mapper.ReviseLogItemMapper;
-import com.vincent.rsf.server.manager.entity.ReviseLogItem;
-import com.vincent.rsf.server.manager.service.ReviseLogItemService;
+import com.vincent.rsf.server.manager.service.*;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import org.springframework.beans.BeanUtils;
+import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+
+import java.util.List;
+import java.util.Objects;
+import java.util.stream.Collectors;
@Service("reviseLogItemService")
public class ReviseLogItemServiceImpl extends ServiceImpl<ReviseLogItemMapper, ReviseLogItem> implements ReviseLogItemService {
+ @Autowired
+ private ReviseLogService reviseLogService;
+ @Autowired
+ private LocItemService locItemService;
+ @Autowired
+ private LocService locService;
+ @Autowired
+ private ReviseLogItemService reviseLogItemService;
+ @Autowired
+ private LocReviseService locReviseService;
+
+
+ /**
+ * 淇濆瓨搴撳瓨璋冩暣鍘嗗彶鍗曟槑缁�
+ *
+ * @param reviseLogItem
+ * @return
+ */
+ @Override
+ @Transactional(rollbackFor = Exception.class)
+ public List<ReviseLogItem> itemSave(ReviseLogItemParams reviseLogItem, Long userId) {
+ ReviseLog reviseLog = reviseLogService.getById(reviseLogItem.getReviseLogId());
+ if (Objects.isNull(reviseLog)) {
+ throw new RuntimeException("搴撳瓨鍘嗗彶鍗曟嵁涓嶅瓨鍦紒锛�");
+ }
+ Loc loc = locService.getOne(new LambdaQueryWrapper<Loc>()
+ .eq(Loc::getCode, reviseLog.getLocCode()));
+ if (Objects.isNull(loc)) {
+ throw new RuntimeException("搴撲綅搴撳瓨涓嶅瓨鍦紒锛�");
+ }
+ List<ReviseLogItem> items = reviseLogItem.getItems();
+
+ this.remove(new LambdaQueryWrapper<ReviseLogItem>()
+ .eq(ReviseLogItem::getLocId, loc.getId()));
+
+ items.forEach(item -> {
+ ReviseLogItem logItem = new ReviseLogItem();
+ BeanUtils.copyProperties(item, logItem);
+ logItem.setReviseLogId(reviseLogItem.getReviseLogId())
+ .setUpdateBy(userId)
+ .setCreateBy(userId)
+ .setLocId(loc.getId())
+ .setLocCode(loc.getCode());
+ if (Objects.isNull(item.getAnfme())) {
+ logItem.setAnfme(0.0);
+ }
+ if (!this.saveOrUpdate(logItem)) {
+ throw new RuntimeException("搴撳瓨鏄庣粏璋冩暣澶辫触");
+ }
+
+ LocItem one = locItemService.getOne(new LambdaQueryWrapper<LocItem>()
+ .eq(LocItem::getMatnrId, logItem.getMatnrId())
+ .eq(StringUtils.isNotBlank(logItem.getBatch()), LocItem::getBatch, logItem.getBatch())
+ .eq(StringUtils.isNotBlank(logItem.getFieldsIndex()), LocItem::getFieldsIndex, logItem.getFieldsIndex())
+ .eq(LocItem::getLocCode, logItem.getLocCode()));
+ if (Objects.isNull(one)) {
+ LocItem locDetl = new LocItem();
+ BeanUtils.copyProperties(logItem, locDetl);
+ locDetl.setLocId(loc.getId())
+ .setLocCode(loc.getCode())
+ .setAnfme(logItem.getReviseQty())
+ .setUpdateBy(userId)
+ .setId(null)
+ .setCreateBy(userId);
+ if (!locItemService.save(locDetl)) {
+ throw new CoolException("搴撳瓨鏄庣粏淇濆瓨澶辫触锛侊紒");
+ }
+ } else {
+ one.setAnfme(logItem.getReviseQty());
+ if (!locItemService.updateById(one)) {
+ throw new RuntimeException("搴撳瓨鏄庣粏淇敼澶辫触锛侊紒");
+ }
+ }
+ });
+
+ List<ReviseLog> list = reviseLogService.list(new LambdaQueryWrapper<ReviseLog>().eq(ReviseLog::getReviseId, reviseLog.getReviseId()));
+ if (Objects.isNull(list)) {
+ throw new RuntimeException("鏁版嵁閿欒锛氬簱瀛樿皟鏁村崟涓嶅瓨鍦紒锛�");
+ }
+ List<Long> reviseIds = list.stream().map(ReviseLog::getId).collect(Collectors.toList());
+ List<ReviseLogItem> logItems = reviseLogItemService.list(new LambdaQueryWrapper<ReviseLogItem>()
+ .in(ReviseLogItem::getReviseLogId, reviseIds));
+
+ Double anfems = logItems.stream().mapToDouble(ReviseLogItem::getAnfme).sum();
+ Double reviseQty = logItems.stream().mapToDouble(ReviseLogItem::getReviseQty).sum();
+
+ if (!locReviseService.update(new LambdaUpdateWrapper<LocRevise>()
+ .eq(LocRevise::getId, reviseLog.getReviseId())
+ .set(LocRevise::getAnfme, anfems)
+ .set(LocRevise::getReviseQty, reviseQty))) {
+ throw new RuntimeException("搴撳瓨璋冩暣鍗曚慨鏀瑰け璐ワ紒锛�");
+ }
+ return items;
+ }
}
--
Gitblit v1.9.1