From 3170c2aca0583f801a5527c124103cfbff2bb306 Mon Sep 17 00:00:00 2001
From: skyouc
Date: 星期一, 14 七月 2025 15:01:13 +0800
Subject: [PATCH] 盘点单功能优化

---
 rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java |  100 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 100 insertions(+), 0 deletions(-)

diff --git a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
index 2c31210..a481d1f 100644
--- a/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
+++ b/rsf-server/src/main/java/com/vincent/rsf/server/manager/service/impl/CheckOrderServiceImpl.java
@@ -1,12 +1,112 @@
 package com.vincent.rsf.server.manager.service.impl;
 
+import cn.afterturn.easypoi.excel.ExcelImportUtil;
+import cn.afterturn.easypoi.excel.entity.result.ExcelImportResult;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.vincent.rsf.framework.common.R;
+import com.vincent.rsf.framework.exception.CoolException;
+import com.vincent.rsf.server.common.utils.ExcelUtil;
 import com.vincent.rsf.server.manager.entity.AsnOrder;
+import com.vincent.rsf.server.manager.entity.AsnOrderItem;
+import com.vincent.rsf.server.manager.entity.Matnr;
+import com.vincent.rsf.server.manager.entity.excel.CheckOrderTemplate;
+import com.vincent.rsf.server.manager.enums.AsnExceStatus;
+import com.vincent.rsf.server.manager.enums.OrderType;
+import com.vincent.rsf.server.manager.enums.OrderWorkType;
 import com.vincent.rsf.server.manager.mapper.CheckOrderMapper;
+import com.vincent.rsf.server.manager.service.CheckOrderItemService;
 import com.vincent.rsf.server.manager.service.CheckOrderService;
+import com.vincent.rsf.server.manager.service.MatnrService;
+import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import org.springframework.web.multipart.MultipartFile;
+
+import java.util.*;
+import java.util.stream.Collectors;
 
 @Service("checkOrderService")
 public class CheckOrderServiceImpl extends ServiceImpl<CheckOrderMapper, AsnOrder> implements CheckOrderService {
 
+    @Autowired
+    private MatnrService matnrService;
+
+    @Autowired
+    private CheckOrderItemService checkOrderItemService;
+
+    /**
+     * @author Ryan
+     * @date 2025/7/14
+     * @description: 鐩樼偣鍗曞鍏�
+     * @version 1.0
+     */
+    @Override
+    @Transactional(rollbackFor = Exception.class)
+    public R excelImport(MultipartFile file, HashMap<String, Object> hashMap, Long loginUserId) {
+        ExcelImportResult result = null;
+        try {
+            result = ExcelImportUtil.importExcelMore(file.getInputStream(), CheckOrderTemplate.class, ExcelUtil.getDefaultImportParams());
+        } catch (Exception e) {
+            throw new RuntimeException(e);
+        }
+        if (result.getList().isEmpty()) {
+            throw new CoolException("琛ㄦ牸鍐呭涓嶈兘涓虹┖锛侊紒");
+        }
+        List<CheckOrderTemplate> resultList = result.getList();
+        Map<String, List<CheckOrderTemplate>> listMap = resultList.stream().collect(Collectors.groupingBy(CheckOrderTemplate::getCode));
+        for (String key : listMap.keySet()) {
+            CheckOrderTemplate template = listMap.get(key).stream().findFirst().get();
+            AsnOrder asnOrder = this.getOne(new LambdaQueryWrapper<AsnOrder>().eq(AsnOrder::getCode, template.getCode()));
+            if (!Objects.isNull(asnOrder)) {
+                continue;
+            }
+            AsnOrder order = new AsnOrder();
+            order.setCode(template.getCode())
+                    .setMemo(template.getMemo())
+                    .setUpdateBy(loginUserId)
+                    .setCreateBy(loginUserId)
+                    .setType(OrderType.getTypeVal(template.getType()))
+                    .setWkType(OrderWorkType.getWorkType(template.getWkType()));
+            if (!this.save(order)) {
+                throw new CoolException("鍗曟嵁淇濆瓨澶辫触锛侊紒");
+            }
+            List<AsnOrderItem> items = new ArrayList<>();
+            for (CheckOrderTemplate orderTemplate : listMap.get(key)) {
+                AsnOrderItem orderItem = new AsnOrderItem();
+                Matnr matnr = null;
+                if (StringUtils.isNotBlank(orderTemplate.getMatnrCode())) {
+                    matnr = matnrService.getOne(new LambdaQueryWrapper<Matnr>()
+                            .eq(Matnr::getCode, orderTemplate.getMatnrCode()));
+                }
+                orderItem.setAsnId(order.getId())
+                        .setAsnCode(order.getCode())
+                        .setSplrBatch(orderTemplate.getSplrBatch())
+                        .setAnfme(Double.parseDouble(orderTemplate.getAnfme()))
+                        .setSplrName(orderTemplate.getSplrName())
+                        .setSplrCode(orderTemplate.getSplrCode())
+                        .setMaktx(orderTemplate.getMaktx())
+                        .setMatnrCode(orderTemplate.getMatnrCode());
+                if (!Objects.isNull(matnr)) {
+                    orderItem.setMaktx(matnr.getName()).setMatnrCode(matnr.getCode()).setMatnrId(matnr.getId());
+                }
+                items.add(orderItem);
+                if (!checkOrderItemService.saveBatch(items)) {
+                    throw new CoolException("鍗曟嵁鏄庣粏淇濆瓨澶辫触锛侊紒");
+                }
+            }
+            if (!items.isEmpty()) {
+                double purQty = items.stream().mapToDouble(AsnOrderItem::getAnfme).sum();
+                if (!this.update(new LambdaUpdateWrapper<AsnOrder>()
+                        .set(AsnOrder::getExceStatus, AsnExceStatus.OUT_STOCK_STATUS_TASK_INIT.val)
+                        .set(AsnOrder::getAnfme, purQty).eq(AsnOrder::getId, order.getId()))) {
+                    throw new CoolException("鍗曟嵁鏁伴噺淇敼澶辫触锛侊紒");
+                }
+            }
+        }
+
+        return R.ok("鎿嶄綔鎴愬姛锛侊紒");
+    }
 }

--
Gitblit v1.9.1