From e6805fc62484ccd5580a6f7eefaf096acc84d5da Mon Sep 17 00:00:00 2001
From: dongyukun <1208714201@qq.com>
Date: 星期三, 07 五月 2025 15:26:37 +0800
Subject: [PATCH] 根据outId查询预测数据

---
 ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java |  105 +++++++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 99 insertions(+), 6 deletions(-)

diff --git a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java
index 01b38a5..7b41ea8 100644
--- a/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java
+++ b/ansteel-biz/src/main/java/com/iailab/module/ansteel/api/service/impl/DataServiceImpl.java
@@ -5,6 +5,7 @@
 import com.iailab.framework.common.util.object.ConvertUtils;
 import com.iailab.module.ansteel.api.dao.*;
 import com.iailab.module.ansteel.api.dto.*;
+import com.iailab.module.ansteel.common.enums.ProcessConfDataTypeEnum;
 import com.iailab.module.ansteel.power.dao.*;
 import com.iailab.module.ansteel.power.entity.PowerCapacitorStatusEntity;
 import com.iailab.module.ansteel.power.entity.PowerControlDetEntity;
@@ -12,6 +13,9 @@
 import com.iailab.module.ansteel.power.entity.PowerNetFactorEntity;
 import com.iailab.module.ansteel.api.service.DataService;
 import com.iailab.module.ansteel.common.constant.CommonConstant;
+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.plan.dto.ApiPlanDataDTO;
 import com.iailab.module.data.api.point.DataPointApi;
@@ -30,12 +34,16 @@
 import java.util.*;
 import java.util.stream.Collectors;
 
+import static com.iailab.framework.common.pojo.CommonResult.success;
+
 @Slf4j
 @Service
 public class DataServiceImpl implements DataService {
 
     @Autowired
     private DataPointApi dataPointApi;
+    @Autowired
+    private IndItemApi indItemApi;
 
     @Autowired
     private McsApi mcsApi;
@@ -105,9 +113,9 @@
     @Override
     public List<MainProcessIndexDTO> getIndexList(Map<String, Object> params) {
         List<MainProcessIndexDTO> list = new ArrayList<>();
-        if("day".equals(params.get("type"))) {
+        if ("day".equals(params.get("type"))) {
             list = ConvertUtils.sourceToTarget(mainProcessIndexDayDao.selectList(new QueryWrapper<>()), MainProcessIndexDTO.class);
-        }else if("team".equals(params.get("type"))){
+        } else if ("team".equals(params.get("type"))) {
             list = ConvertUtils.sourceToTarget(mainProcessIndexTeamDao.selectList(new QueryWrapper<>()), MainProcessIndexDTO.class);
         }
         if (!CollectionUtils.isEmpty(list)) {
@@ -136,6 +144,11 @@
     @Override
     public Boolean useSuggest(StAlarmAndSuggestReqVO ReqVO) {
         return mcsApi.useSuggest(ReqVO);
+    }
+
+    @Override
+    public Boolean ignoreSuggest(StAlarmAndSuggestReqVO ReqVO) {
+        return mcsApi.ignoreSuggest(ReqVO);
     }
 
     @Override
@@ -175,9 +188,12 @@
         PreDataSingleChartRespVO resultOld = mcsApi.getPreDataSingleChart(reqVO);
         PreDataChartRespVO result = ConvertUtils.sourceToTarget(resultOld, PreDataChartRespVO.class);
         PreDataViewDTO preDataView = ConvertUtils.sourceToTarget(resultOld.getDataView(), PreDataViewDTO.class);
-        if(trendsDataH != null) {
+        if (StringUtils.isNotBlank(trendsDataH)) {
+            // 动态上限
             ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO();
             pointValueQueryDTO.setPointNo(trendsDataH);
+            pointValueQueryDTO.setStart(startTime);
+            pointValueQueryDTO.setEnd(endTime);
             List<ApiPointValueDTO> trendsDataHList = ConvertUtils.sourceToTarget(dataPointApi.queryPointHistoryValue(pointValueQueryDTO), ApiPointValueDTO.class);
             List<Object[]> newList = new ArrayList<>();
             trendsDataHList.forEach(item -> {
@@ -188,9 +204,12 @@
             });
             preDataView.setTrendsDataH(newList);
         }
-        if(trendsDataL != null) {
+        if (StringUtils.isNotBlank(trendsDataL)) {
+            // 动态下限
             ApiPointValueQueryDTO pointValueQueryDTO = new ApiPointValueQueryDTO();
             pointValueQueryDTO.setPointNo(trendsDataL);
+            pointValueQueryDTO.setStart(startTime);
+            pointValueQueryDTO.setEnd(endTime);
             List<ApiPointValueDTO> trendsDataLList = ConvertUtils.sourceToTarget(dataPointApi.queryPointHistoryValue(pointValueQueryDTO), ApiPointValueDTO.class);
             List<Object[]> newList = new ArrayList<>();
             trendsDataLList.forEach(item -> {
@@ -203,7 +222,6 @@
         }
 
         preDataView.setPreData(resultOld.getDataView().getPreDataL());
-
         result.setPreDataView(preDataView);
         return result;
     }
@@ -239,7 +257,7 @@
     }
 
     /**
-     *  查询原始计划、修正计划数据
+     * 查询原始计划、修正计划数据
      */
     @Override
     public Map<String, Object> getPlanDataChart(PlanDataChartReqVO reqVO) {
@@ -365,4 +383,79 @@
         wrapper.orderByAsc("sort");
         return ConvertUtils.sourceToTarget(powerControlDetDao.selectList(wrapper), PowerControlDetDTO.class);
     }
+
+    @Override
+    public List<Object[]> getHistoryValue(Map<String, Object> params) {
+        List<Object[]> dataList = new ArrayList<>();
+
+        if (!params.containsKey("dataType") || !params.containsKey("dataNo")) {
+            return dataList;
+        }
+        String dataType = params.get("dataType").toString();
+        String dataNo = params.get("dataNo").toString();
+
+        Date startTime = null;
+        Date endTime = null;
+        Calendar calendar = Calendar.getInstance();
+        calendar.set(Calendar.MILLISECOND, 0);
+        if (!params.containsKey("endTime") || StringUtils.isBlank(params.get("endTime").toString())) {
+            endTime = calendar.getTime();
+        } else {
+            endTime = DateUtils.parse(params.get("endTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND);
+        }
+        if (!params.containsKey("startTime") || StringUtils.isBlank(params.get("startTime").toString())) {
+            calendar.add(Calendar.DAY_OF_YEAR, -1);
+            startTime = calendar.getTime();
+        } else {
+            startTime = DateUtils.parse(params.get("startTime").toString(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND);
+        }
+
+        switch (ProcessConfDataTypeEnum.getEumByCode(dataType)) {
+            case DATAPOINT:
+                ApiPointValueQueryDTO queryParams1 = new ApiPointValueQueryDTO();
+                queryParams1.setPointNo(dataNo);
+                queryParams1.setStart(startTime);
+                queryParams1.setEnd(endTime);
+                List<com.iailab.module.data.api.point.dto.ApiPointValueDTO> pointHisValue = dataPointApi.queryPointHistoryValue(queryParams1);
+                pointHisValue.forEach(item -> {
+                    Object[] values = new Object[2];
+                    values[0] = DateUtils.format(item.getT(), DateUtils.FORMAT_YEAR_MONTH_DAY_HOUR_MINUTE_SECOND);
+                    values[1] = new BigDecimal(item.getV()).setScale(3, BigDecimal.ROUND_HALF_UP);
+                    dataList.add(values);
+                });
+                break;
+            case IND:
+                log.info("IND");
+                ApiIndItemQueryDTO queryParams2 = new ApiIndItemQueryDTO();
+                queryParams2.setItemNo(dataNo);
+                queryParams2.setStart(startTime);
+                queryParams2.setEnd(endTime);
+                List<ApiIndItemValueDTO> indValues = indItemApi.queryIndItemHistoryValue(queryParams2);
+                indValues.forEach(item -> {
+                    Object[] values = new Object[2];
+                    values[0] = item.getDataTime();
+                    values[1] = item.getDataValue();
+                    dataList.add(values);
+                });
+                break;
+            default:
+                break;
+        }
+        return dataList;
+    }
+
+    @Override
+    public List<PreDataViewSimpleDTO> getPreDataByOutIds(PreDataBarLineReqVO reqVO) {
+        PreDataBarLineRespVO preDataBarLineRespVO = mcsApi.getPreDataCharts(reqVO);
+        List<PreDataViewSimpleDTO> preDataViewSimpleDTOList = new ArrayList<>();
+        preDataBarLineRespVO.getDataViewList().forEach(item -> {
+            PreDataViewSimpleDTO preDataViewSimpleDTO = new PreDataViewSimpleDTO();
+            preDataViewSimpleDTO.setItemName(item.getResultName());
+            preDataViewSimpleDTO.setPredictTime(preDataBarLineRespVO.getPredictTime());
+            preDataViewSimpleDTO.setCurData(item.getCurData());
+            preDataViewSimpleDTO.setRealData(item.getRealData());
+            preDataViewSimpleDTOList.add(preDataViewSimpleDTO);
+        });
+        return preDataViewSimpleDTOList;
+    }
 }
\ No newline at end of file

--
Gitblit v1.9.3