From 9fe1ec3afe8696c628d076d1f76686c4efc3012e Mon Sep 17 00:00:00 2001
From: zc <zyzc>
Date: 星期二, 21 十月 2025 10:49:55 +0800
Subject: [PATCH] 容器初始化功能优化
---
rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/ReviseLogItemServiceImpl.java | 112 +++++++++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 110 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..96e8de7 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,120 @@
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.enums.CommonExceStatus;
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(timeout = 60, 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::getExceStatus, CommonExceStatus.COMMON_EXCE_STATUS_EXCE_ING.val)
+ .set(LocRevise::getReviseQty, reviseQty))) {
+ throw new RuntimeException("搴撳瓨璋冩暣鍗曚慨鏀瑰け璐ワ紒锛�");
+ }
+ return items;
+ }
}
--
Gitblit v1.9.1