From b04753affc29f1042d0eb75b0af87824a0f4a8aa Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期五, 09 八月 2024 15:41:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java |   83 ++++++++++++++++++++++++++++++++++++-----
 1 files changed, 73 insertions(+), 10 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
index 0491c4f..b9a473e 100644
--- a/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
+++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java
@@ -21,16 +21,15 @@
 import com.ycl.platform.service.WorkOrderService;
 import com.ycl.platform.service.YwPointService;
 import com.ycl.system.Result;
+import com.ycl.system.domain.SysConfig;
+import com.ycl.system.mapper.SysConfigMapper;
 import com.ycl.system.model.LoginUser;
 import com.ycl.system.page.PageUtil;
 import com.ycl.utils.DateUtils;
 import com.ycl.utils.SecurityUtils;
 import com.ycl.utils.redis.RedisCache;
 import com.ycl.utils.uuid.IdUtils;
-import enumeration.general.NotifyTypeEnum;
-import enumeration.general.UrgentLevelEnum;
-import enumeration.general.WorkOrderDistributeWayEnum;
-import enumeration.general.WorkOrderStatusEnum;
+import enumeration.general.*;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.apache.commons.lang3.ObjectUtils;
@@ -39,6 +38,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.Assert;
+import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
 
 import java.time.LocalDateTime;
@@ -65,6 +65,7 @@
     private final NotifyService notifyService;
     private final WorkOrderDistributeRecordMapper workOrderDistributeRecordMapper;
     private final TMonitorMapper monitorMapper;
+    private final SysConfigMapper configMapper;
 
     private final String DISTRIBUTE_LOCK_KEY = "distributeLock";
     private final static String IMPORTANT = "important";
@@ -73,16 +74,78 @@
     private RedisCache redisCache;
 
     @Override
-    public Boolean innerAdd(List<WorkOrder> workOrderList) {
+    @Transactional(rollbackFor = Exception.class)
+    public Boolean innerAddWorkOrder(List<WorkOrder> workOrderList) {
         int total = workOrderList.size();
         workOrderList.stream().filter(item -> {
             return StringUtils.hasText(item.getSerialNumber()) && Objects.nonNull(item.getStatus()) && StringUtils.hasText(item.getErrorType());
         });
-        // TODO 鑷姩涓嬪彂宸ュ崟
-        int real = workOrderList.size();
-        boolean result = this.saveBatch(workOrderList);
-        log.info("浼犲叆宸ュ崟鎬绘暟: {}锛屽疄闄呮坊鍔犲伐鍗曟暟锛歿}", total, real);
-        return result;
+        List<String> serialNumberList = workOrderList.stream().map(WorkOrder::getSerialNumber).collect(Collectors.toList());
+        // 鏌ュ嚭鏁版嵁搴撲腑鍥芥爣鐮佸搴旂殑鏈畬鎴愮殑宸ュ崟
+        List<WorkOrder> inDatabaseWorkOrderList = new LambdaQueryChainWrapper<>(baseMapper)
+                .select(WorkOrder::getId, WorkOrder::getSerialNumber, WorkOrder::getStatus, WorkOrder::getErrorType)
+                .in(WorkOrder::getSerialNumber, serialNumberList)
+                .ne(WorkOrder::getStatus, WorkOrderStatusEnum.AUDITING_SUCCESS)
+                .list();
+        Map<String, WorkOrder> mapping = inDatabaseWorkOrderList.stream().collect((Collectors.toMap(WorkOrder::getSerialNumber, workOrder -> workOrder)));
+        List<WorkOrder> waitAddList = new ArrayList<>(48);
+        Integer updateNum = 0;
+        for (WorkOrder workOrder : workOrderList) {
+            WorkOrder databaseWorkOrder = mapping.get(workOrder.getSerialNumber());
+            if (Objects.nonNull(databaseWorkOrder)) {
+                String errorType = databaseWorkOrder.getErrorType();
+                if (workOrder.getErrorType().equals(errorType)) {
+                    // 濡傛灉锛屽浗鏍囩爜銆佹晠闅滅被鍨嬮兘涓�鏍凤紝鍒欒烦杩囦笉澶勭悊
+                    continue;
+                } else {
+                    // 閿欒绫诲瀷涓嶄竴鏍凤紝灏辨洿鏂伴敊璇被鍨嬶紝骞朵笖閲嶇疆宸ュ崟鐘舵�佷负寰呭鐞�
+                    errorType = errorType + "," + workOrder.getErrorType();
+                    databaseWorkOrder.setErrorType(errorType);
+                    databaseWorkOrder.setStatus(WorkOrderStatusEnum.DISTRIBUTED);
+                    baseMapper.updateById(databaseWorkOrder);
+                    updateNum++;
+                    // 鍚屾椂鏂板涓�涓繍缁村鐞嗕俊鎭紝琛ㄦ槑姝ゅ伐鍗曡璋冩暣 TODO
+                }
+            } else {
+                waitAddList.add(workOrder);
+            }
+        }
+        if (CollectionUtils.isEmpty(waitAddList)) {
+            return Boolean.TRUE;
+        }
+        List<String> willAddSerialNumber = waitAddList.stream().map(WorkOrder::getSerialNumber).collect(Collectors.toList());
+        List<YwPoint> pointList = new LambdaQueryChainWrapper<>(ywPointService.getBaseMapper())
+                .select(YwPoint::getUnitId, YwPoint::getSerialNumber, YwPoint::getImportantTag, YwPoint::getImportantTag, YwPoint::getProvinceTag, YwPoint::getImportantCommandImageTag)
+                .in(YwPoint::getSerialNumber, willAddSerialNumber)
+                .list();
+        Map<String, YwPoint> pointMapping = pointList.stream().collect(Collectors.toMap(YwPoint::getSerialNumber, point -> point));
+        // 鏌ュ嚭閲嶇偣鐐逛綅銆佹櫘閫氱偣浣嶇殑澶勭悊鏃堕棿
+        SysConfig important = configMapper.checkConfigKeyUnique("important.wordkorder.time");
+        SysConfig normal = configMapper.checkConfigKeyUnique("normal.wordkorder.alarm.time");
+        for (WorkOrder workOrder : waitAddList) {
+            YwPoint point = pointMapping.get(workOrder.getSerialNumber());
+            workOrder.setWorkOrderNo(IdUtils.timeAddRandomNO(5));
+            workOrder.setUnitId(Math.toIntExact(point.getUnitId()));
+            if (point.getImportantTag() || point.getImportantCommandImageTag()) {
+                workOrder.setProcessingPeriod(Integer.valueOf(important.getConfigValue()));
+            } else {
+                workOrder.setProcessingPeriod(Integer.valueOf(normal.getConfigValue()));
+            }
+        }
+        this.saveBatch(waitAddList);
+        // 濡傛灉鏄洿鎺ヤ笅鍙戯紝娣诲姞涓嬪彂璁板綍
+        if (WorkOrderStatusEnum.DISTRIBUTED.equals(waitAddList.get(0).getStatus())) {
+            List<WorkOrderDistributeRecord> distributedRecordList = waitAddList.stream().map(item -> {
+                WorkOrderDistributeRecord workOrderDistributeRecord = new WorkOrderDistributeRecord();
+                workOrderDistributeRecord.setWorkOrderId(item.getId());
+                workOrderDistributeRecord.setDistributeWay(WorkOrderDistributeWayEnum.DIRECT_DISTRIBUTE);
+                workOrderDistributeRecord.setUserId(1L);
+                return workOrderDistributeRecord;
+            }).collect(Collectors.toList());
+            workOrderDistributeRecordMapper.insertBatch(distributedRecordList);
+        }
+        log.info("浼犲叆宸ュ崟鎬绘暟: {}锛屽疄闄呮坊鍔犲伐鍗曟暟锛歿}, 瀹為檯淇敼宸ュ崟鏁帮細{}", total, waitAddList.size(), updateNum);
+        return Boolean.TRUE;
     }
 
     /**

--
Gitblit v1.8.0