From 47ecac334ac27d99de2a3a69b3f4bc654298ee1f Mon Sep 17 00:00:00 2001
From: dongyukun <1208714201@qq.com>
Date: 星期三, 28 五月 2025 17:30:10 +0800
Subject: [PATCH] 调度建议快照

---
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/controller/admin/StSuggestSnapshotRecordController.java |  117 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 113 insertions(+), 4 deletions(-)

diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/controller/admin/StSuggestSnapshotRecordController.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/controller/admin/StSuggestSnapshotRecordController.java
index be5c2f6..1be57c0 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/controller/admin/StSuggestSnapshotRecordController.java
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mcs/sche/controller/admin/StSuggestSnapshotRecordController.java
@@ -1,19 +1,35 @@
 package com.iailab.module.model.mcs.sche.controller.admin;
 
 import com.iailab.framework.common.pojo.CommonResult;
+import com.iailab.module.data.api.ind.IndItemApi;
+import com.iailab.module.data.api.ind.dto.ApiIndItemQueryDTO;
+import com.iailab.module.data.api.ind.dto.ApiIndItemValueDTO;
+import com.iailab.module.data.api.plan.PlanItemApi;
+import com.iailab.module.data.api.point.DataPointApi;
+import com.iailab.module.data.api.point.dto.ApiPointValueDTO;
+import com.iailab.module.data.api.point.dto.ApiPointValueQueryDTO;
+import com.iailab.module.data.common.ApiDataQueryDTO;
+import com.iailab.module.data.common.ApiDataValueDTO;
+import com.iailab.module.model.api.mcs.McsApi;
+import com.iailab.module.model.api.mcs.dto.PreDataBarLineReqVO;
+import com.iailab.module.model.api.mcs.dto.PreDataBarLineRespVO;
+import com.iailab.module.model.common.enums.DataCategoryEnum;
+import com.iailab.module.model.common.utils.DateUtils;
 import com.iailab.module.model.mcs.sche.service.StSuggestSnapshotRecordService;
 import com.iailab.module.model.mcs.sche.vo.StSuggestSnapshotRecordRespVO;
+import com.mysql.cj.util.TimeUtil;
 import io.swagger.v3.oas.annotations.Parameter;
 import io.swagger.v3.oas.annotations.tags.Tag;
 import org.springframework.beans.factory.annotation.Autowired;
-import org.springframework.web.bind.annotation.GetMapping;
-import org.springframework.web.bind.annotation.RequestMapping;
-import org.springframework.web.bind.annotation.RequestParam;
-import org.springframework.web.bind.annotation.RestController;
+import org.springframework.web.bind.annotation.*;
 
+import java.text.DateFormat;
+import java.util.ArrayList;
+import java.util.Date;
 import java.util.List;
 
 import static com.iailab.framework.common.pojo.CommonResult.success;
+import static com.iailab.module.model.common.utils.DateUtils.DATE_TIME_PATTERN;
 
 /**
  * @author Jay
@@ -26,9 +42,102 @@
     @Autowired
     private StSuggestSnapshotRecordService stSuggestSnapshotRecordService;
 
+    @Autowired
+    private DataPointApi dataPointApi;
+
+    @Autowired
+    private IndItemApi indItemApi;
+
+    @Autowired
+    private PlanItemApi planItemApi;
+
+    @Autowired
+    private McsApi mcsApi;
+
+
     @GetMapping("/list")
     @Parameter(name = "operationId", description = "操作id", required = true, example = "1024")
     public CommonResult<List<StSuggestSnapshotRecordRespVO>> getListByOperationId(@RequestParam("operationId") String operationId) {
         return success(stSuggestSnapshotRecordService.getListByOperationId(operationId));
     }
+
+    @PostMapping("/getChartData")
+    public CommonResult<List<StSuggestSnapshotRecordRespVO>> getChartData(@RequestBody List<StSuggestSnapshotRecordRespVO> reqList){
+        reqList.forEach(item -> {
+            List<Object[]> dataList = new ArrayList<>();
+            if(DataCategoryEnum.DATAPOINT.getCode().equals(item.getDataType())){
+                ApiPointValueQueryDTO queryDTO = new ApiPointValueQueryDTO();
+                queryDTO.setPointNo(item.getDataNo());
+                queryDTO.setStart(item.getStartTime());
+                queryDTO.setEnd(item.getEndTime());
+                List<ApiPointValueDTO> valueList = dataPointApi.queryPointHistoryValue(queryDTO);
+                if (valueList != null && !valueList.isEmpty()){
+                    for (ApiPointValueDTO apiPointValueDTO : valueList) {
+                        Object[] data = new Object[2];
+                        data[0] = DateUtils.format(new Date(String.valueOf(apiPointValueDTO.getT())), DATE_TIME_PATTERN);
+                        data[1] = apiPointValueDTO.getV();
+                        dataList.add(data);
+                    }
+                }
+            } else if (DataCategoryEnum.IND.getCode().equals(item.getDataType())) {
+                ApiIndItemQueryDTO queryDTO = new ApiIndItemQueryDTO();
+                queryDTO.setItemNo(item.getDataNo());
+                queryDTO.setStart(item.getStartTime());
+                queryDTO.setEnd(item.getEndTime());
+                List<ApiIndItemValueDTO> valueList = indItemApi.queryIndItemHistoryValue(queryDTO);
+                if (valueList != null && !valueList.isEmpty()){
+                    for (ApiIndItemValueDTO apiIndItemValueDTO : valueList) {
+                        Object[] data = new Object[2];
+                        data[0] = DateUtils.format(new Date(apiIndItemValueDTO.getDataTime()), DATE_TIME_PATTERN);
+                        data[1] = apiIndItemValueDTO.getDataValue();
+                        dataList.add(data);
+                    }
+                }
+            } else if (DataCategoryEnum.PLAN.getCode().equals(item.getDataType())) {
+                ApiDataQueryDTO queryDTO = new ApiDataQueryDTO();
+                queryDTO.setItemNo(item.getDataNo());
+                queryDTO.setStart(item.getStartTime());
+                queryDTO.setEnd(item.getEndTime());
+                List<ApiDataValueDTO> valueList = planItemApi.queryPlanItemHistoryValue(queryDTO);
+                if (valueList != null && !valueList.isEmpty()){
+                    for (ApiDataValueDTO apiDataValueDTO : valueList) {
+                        Object[] data = new Object[2];
+                        data[0] = DateUtils.format(apiDataValueDTO.getDataTime(), DATE_TIME_PATTERN);
+                        data[1] = apiDataValueDTO.getDataValue();
+                        dataList.add(data);
+                    }
+                }
+            } else if (DataCategoryEnum.PREDICT_ITEM_N.getCode().equals(item.getDataType())) {
+                dataList = getPreDataList(item, "N");
+            }else if (DataCategoryEnum.PREDICT_ITEM_L.getCode().equals(item.getDataType())) {
+                dataList = getPreDataList(item, "L");
+            }else if (DataCategoryEnum.PREDICT_ITEM_C.getCode().equals(item.getDataType())) {
+                dataList = getPreDataList(item, "C");
+            }
+            item.setDataList(dataList);
+
+        });
+        return success(reqList);
+    }
+    private List<Object[]> getPreDataList(StSuggestSnapshotRecordRespVO resVo, String type){
+        List<Object[]> dataList = new ArrayList<>();
+        PreDataBarLineReqVO reqVO  = new PreDataBarLineReqVO();
+        List<String> outIds = new ArrayList<>();
+        outIds.add(resVo.getDataNo());
+        reqVO.setOutIds(outIds);
+        reqVO.setStartTime(resVo.getStartTime());
+        reqVO.setEndTime(resVo.getEndTime());
+        PreDataBarLineRespVO result = mcsApi.getPreDataCharts(reqVO);
+        if (result == null || result.getDataViewList() == null || result.getDataViewList().isEmpty()){
+            return dataList;
+        }
+        if ("N".equals(type) && result.getDataViewList().get(0).getPreDataN()!=null){
+            dataList = result.getDataViewList().get(0).getPreDataN();
+        }else if ("L".equals(type) && result.getDataViewList().get(0).getPreDataL()!=null){
+            dataList = result.getDataViewList().get(0).getPreDataL();
+        }else if ("C".equals(type) && result.getDataViewList().get(0).getCurData()!=null){
+            dataList = result.getDataViewList().get(0).getCurData();
+        }
+        return dataList;
+    }
 }

--
Gitblit v1.9.3