From 27bf1aad170bc78af274a596ce5c89caaa903ce3 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期三, 04 九月 2024 03:34:45 +0800
Subject: [PATCH] 合同积分回显

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/WorkOrderServiceImpl.java |   46 ++++++++++++++++++++++++++++++----------------
 1 files changed, 30 insertions(+), 16 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 a8f2c12..8b4cfe0 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
@@ -104,18 +104,28 @@
     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());
+            return StringUtils.hasText(item.getSerialNumber()) && Objects.nonNull(item.getStatus()) && !CollectionUtils.isEmpty(item.getErrorTypeList());
         });
         if (CollectionUtils.isEmpty(workOrderList)) {
             return Boolean.TRUE;
         }
+        // 鏍规嵁鍥芥爣鐮佸幓閲�
+        workOrderList = workOrderList.stream()
+                .collect(Collectors.toMap(
+                        WorkOrder::getSerialNumber,
+                        p -> p,
+                        (existing, replacement) -> existing // 鍐茬獊鏃朵繚鐣欑涓�涓�
+                )).values().stream().collect(Collectors.toList());
         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::getWorkOrderNo)
-                .in(WorkOrder::getSerialNumber, serialNumberList)
-                .ne(WorkOrder::getStatus, WorkOrderStatusEnum.AUDITING_SUCCESS)
-                .list();
+        List<WorkOrder> inDatabaseWorkOrderList = baseMapper.getNotFinishedWorkOrders(serialNumberList);
+        inDatabaseWorkOrderList.stream().forEach(item -> {
+            if (StringUtils.hasText(item.getErrorType())) {
+                item.setErrorTypeList(List.of(item.getErrorType().split(",")));
+            } else {
+                item.setErrorTypeList(new ArrayList<>(1));
+            }
+        });
         Map<String, WorkOrder> mapping = inDatabaseWorkOrderList.stream().collect((Collectors.toMap(WorkOrder::getSerialNumber, workOrder -> workOrder)));
         List<WorkOrder> waitAddList = new ArrayList<>(48);
         List<WorkOrderErrorType> waitAddErrorTypeList = new ArrayList<>(48);
@@ -130,7 +140,7 @@
         for (WorkOrder workOrder : workOrderList) {
             WorkOrder databaseWorkOrder = mapping.get(workOrder.getSerialNumber());
             if (Objects.nonNull(databaseWorkOrder)) {
-                List<String> errorNameList = workOrderErrorTypeService.getBaseMapper().getNotFinishWorkOrderErrors(databaseWorkOrder.getWorkOrderNo());
+                List<String> errorNameList = databaseWorkOrder.getErrorTypeList();
                 List<String> errorTypes = workOrder.getErrorTypeList();
                 if (errorNameList.containsAll(errorTypes)) {
                     // 濡傛灉锛屽浗鏍囩爜銆佹晠闅滅被鍨嬮兘涓�鏍凤紝鍒欒烦杩囦笉澶勭悊
@@ -201,7 +211,7 @@
                 notAddList.add(workOrder);
                 continue;
             }
-            workOrder.setWorkOrderNo(IdUtils.randomNO());
+            workOrder.setWorkOrderNo(IdUtils.randomNO(now));
             if (Objects.nonNull(point.getUnitId())) {
                 workOrder.setUnitId(Math.toIntExact(point.getUnitId()));
             }
@@ -258,12 +268,12 @@
     @Override
     public Result add(WorkOrderForm form) {
         WorkOrder entity = WorkOrderForm.getEntityByForm(form, null);
-        entity.setWorkOrderNo(IdUtils.randomNO());
         entity.setCreateTime(DateUtils.getNowDate());
         entity.setStatus(WorkOrderStatusEnum.WAIT_DISTRIBUTE);
         Date now = new Date();
         entity.setCreateTime(now);
         entity.setUpdateTime(now);
+        entity.setWorkOrderNo(IdUtils.randomNO(now));
         entity.setErrorType(String.join(",", form.getErrorType()));
         List<WorkOrderErrorType> workOrderErrorTypes = form.getErrorType().stream().map(errorType -> new WorkOrderErrorType(entity.getWorkOrderNo(), errorType)).toList();
         workOrderErrorTypeService.getBaseMapper().insertWorkOrderErrorTypeList(workOrderErrorTypes);
@@ -460,6 +470,9 @@
                 if (StringUtils.hasText(item.getErrorType())) {
                     item.setErrorTypeList(List.of(item.getErrorType().split(",")));
                 }
+                if (StringUtils.hasText(item.getImgListStr())) {
+                    item.setImgList(List.of(item.getImgListStr().split(",")));
+                }
             });
         }
         return Result.ok().data(page.getRecords()).total(page.getTotal());
@@ -479,9 +492,6 @@
         LocalDateTime now = LocalDateTime.now(ZoneId.systemDefault());
         data.setEnd(now);
         switch (data.getFastWay()) {
-            case LAST_HALF_HOUR:
-                data.setStart(now.minusMinutes(30));
-                break;
             case LAST_HOUR:
                 data.setStart(now.minusHours(1));
                 break;
@@ -491,8 +501,12 @@
             case LAST_DAY:
                 data.setStart(now.minusDays(1));
                 break;
+            default:
+                break;
            }
-
+        if (Objects.isNull(data.getStart())) {
+            throw new RuntimeException("鏃犳硶鐢熸垚蹇�熶笅鍙戠殑鏃堕棿鑼冨洿锛岃閫夋嫨姝g‘鐨勫揩閫熶笅鍙戞柟寮�");
+        }
         // 鏌ヨ绗﹀悎鏉′欢鐨勫伐鍗�
         List<WorkOrder> list = new LambdaQueryChainWrapper<>(baseMapper)
                 .select(WorkOrder::getSerialNumber, WorkOrder::getWorkOrderNo)
@@ -684,7 +698,7 @@
 
                         imgUrl = workOrderNo + "_" + IdUtils.fastSimpleUUID() + ".png";
                         // 鐢熸垚鍥剧墖璺緞
-                        String imgPath = PlatformConfig.getUploadPath() + "/" + imgUrl;
+                        String imgPath = PlatformConfig.getProfile() + "/" + imgUrl;
                         System.out.println("鍥剧墖淇濆瓨鍦板潃锛�" + imgPath);
                         imgUrl = Constants.RESOURCE_PREFIX + "/" + imgUrl;
                         // 淇濆瓨鍥剧墖
@@ -714,8 +728,8 @@
     }
 
     @Override
-    public List<DeviceInfoVO> hasErrorWorkOrderList() {
-        List<DeviceInfoVO> list = baseMapper.hasErrorWorkOrderList();
+    public List<DeviceInfoVO> hasErrorWorkOrderList(Date start, Date end) {
+        List<DeviceInfoVO> list = baseMapper.hasErrorWorkOrderList(start, end);
         return list;
     }
 

--
Gitblit v1.8.0