From 19b518e352542ecaf12a6fcc440c834c355a93c7 Mon Sep 17 00:00:00 2001
From: kaiyu <404897439@qq.com>
Date: Thu, 27 May 2021 10:58:44 +0800
Subject: [PATCH] Merge branch 'dev' of http://blit.7drlb.com:8888/r/moral into dev

---
 screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java |   82 +++++++++++++++++++++++++++++++++-------
 1 files changed, 67 insertions(+), 15 deletions(-)

diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
index 14da511..0bf6dc0 100644
--- a/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
+++ b/screen-manage/src/main/java/com/moral/api/service/impl/SensorServiceImpl.java
@@ -5,13 +5,18 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.moral.api.entity.ManageRole;
 import com.moral.api.entity.Sensor;
+import com.moral.api.entity.SysDictData;
+import com.moral.api.entity.VersionSensorUnit;
 import com.moral.api.mapper.SensorMapper;
+import com.moral.api.mapper.SysDictDataMapper;
+import com.moral.api.mapper.VersionSensorUnitMapper;
 import com.moral.api.service.SensorService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.api.util.LogUtils;
 import com.moral.constant.Constants;
 import com.moral.constant.RedisConstants;
 import com.moral.constant.ResponseCodeEnum;
+import com.moral.util.TokenUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.data.redis.core.RedisTemplate;
 import org.springframework.stereotype.Service;
@@ -41,6 +46,12 @@
 
     @Autowired(required = false)
     private SensorMapper sensorMapper;
+
+    @Autowired(required = false)
+    private VersionSensorUnitMapper versionSensorUnitMapper;
+
+    @Autowired(required = false)
+    private SysDictDataMapper sysDictDataMapper;
 
     @Autowired
     LogUtils logUtils;
@@ -123,14 +134,29 @@
         HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
         String content = "������������:"+oldSensor.getName()+";";
         for (Object key:updateSensorMap.keySet()) {
-            if (key.toString().equals("name")){
-                content = content+"���������:"+oldSensor.getName()+"->"+updateSensorMap.get(key)+";";
+            if (key.toString().equals("name")&&updateSensorMap.get(key)!=null){
+                content = content+"���������:"+oldSensor.getName()+"->"+updateSensorMap.get(key)+";";
             }
-            if (key.toString().equals("code")){
+            if (key.toString().equals("code")&&updateSensorMap.get(key)!=null){
+                /*QueryWrapper<VersionSensorUnit> wrapper_Version = new QueryWrapper<>();
+                wrapper_Version.eq("sensor_code",oldSensor.getCode());
+                wrapper_Version.eq("is_delete","0");
+                VersionSensorUnit versionSensorUnit = new VersionSensorUnit();
+                versionSensorUnit.setSensorCode(updateSensorMap.get(key).toString());
+                versionSensorUnitMapper.update(versionSensorUnit,wrapper_Version);*/
                 content = content+"������:"+oldSensor.getCode()+"->"+updateSensorMap.get(key)+";";
             }
-            if (key.toString().equals("desc")){
+            if (key.toString().equals("desc")&&updateSensorMap.get(key)!=null){
                 content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("upper")&&updateSensorMap.get(key)!=null){
+                content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("lower")&&updateSensorMap.get(key)!=null){
+                content = content+"������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
+            }
+            if (key.toString().equals("default_unit_key")&&updateSensorMap.get(key)!=null){
+                content = content+"������������:"+oldSensor.getDesc()+"->"+updateSensorMap.get(key)+";";
             }
         }
         logUtils.saveOperationForManage(request,content,Constants.UPDATE_OPERATE_TYPE);
@@ -150,11 +176,13 @@
         QueryWrapper<Sensor> wrapper = new QueryWrapper();
         wrapper.eq("is_delete",0);
         int totleNum = sensorMapper.selectCount(wrapper);
-        String orderType = map.get("orderType").toString();
-        if (orderType.equals(Constants.ORDER_ASC)){
-            wrapper.orderByAsc("create_time");
-        }else {
-            wrapper.orderByDesc("create_time");
+        if (!ObjectUtils.isEmpty(map.get("orderType"))){
+            String orderType = map.get("orderType").toString();
+            if (orderType.equals(Constants.ORDER_DESC)){
+                wrapper.orderByDesc("create_time");
+            }else {
+                wrapper.orderByAsc("create_time");
+            }
         }
         Page resultPage = sensorMapper.selectPage(page,wrapper);
         List<Sensor> sensors = resultPage.getRecords();
@@ -167,9 +195,18 @@
             sensorMap.put("createTime",createTime);
             sensorMap.put("updateTime",updateTime);
             sensorMap.put("key",sensor.getId());
+            if (sensor.getDefaultUnitKey()!=null&&sensor.getDefaultUnitKey()!=""){
+                QueryWrapper<SysDictData> wrapper_VSU = new QueryWrapper();
+                wrapper_VSU.eq("is_delete",0);
+                wrapper_VSU.eq("dataKey",sensor.getDefaultUnitKey());
+                wrapper_VSU.eq("dict_type_id",14);
+                if (!ObjectUtils.isEmpty(sysDictDataMapper.selectOne(wrapper_VSU))&&!ObjectUtils.isEmpty(sysDictDataMapper.selectOne(wrapper_VSU).getDataValue())){
+                    sensorMap.put("default_unit_key",sysDictDataMapper.selectOne(wrapper_VSU).getDataValue());
+                }
+            }
             sensorList.add(sensorMap);
         }
-        resultMap.put("manageRoles",sensorList);
+        resultMap.put("sensors",sensorList);
         resultMap.put("totalNumber",totleNum);
         resultMap.put("current",current);
         int totalPageNumber = totleNum/size;
@@ -194,8 +231,14 @@
             return resultMap;
         }
         Sensor deleteSensor = new Sensor();
-        deleteSensor.setIsDelete("1");
+        deleteSensor.setIsDelete(Constants.DELETE);
         sensorMapper.update(deleteSensor,wrapper);
+        QueryWrapper<VersionSensorUnit> wrapper_Version = new QueryWrapper<>();
+        wrapper_Version.eq("sensor_id",sensor.getId());
+        wrapper_Version.eq("is_delete","0");
+        VersionSensorUnit versionSensorUnit = new VersionSensorUnit();
+        versionSensorUnit.setIsDelete(Constants.DELETE);
+        versionSensorUnitMapper.update(versionSensorUnit,wrapper_Version);
         //������������������
         HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest();
         String content = "������������:"+sensor.getName()+";";
@@ -204,6 +247,8 @@
         resultMap.put("msg",ResponseCodeEnum.SUCCESS.getMsg());
         //������������
         refreshCache();
+        //������token
+        TokenUtils.destoryToken(Integer.parseInt(map.get("id").toString()));
         return resultMap;
     }
 
@@ -234,9 +279,16 @@
             sensorMap.put("createTime",createTime);
             sensorMap.put("updateTime",updateTime);
             sensorMap.put("key",sensor.getId());
+            if (sensor.getDefaultUnitKey()!=null&&sensor.getDefaultUnitKey()!=""){
+                QueryWrapper<SysDictData> wrapper_VSU = new QueryWrapper();
+                wrapper_VSU.eq("is_delete",0);
+                wrapper_VSU.eq("dataKey",sensor.getDefaultUnitKey());
+                wrapper_VSU.eq("dict_type_id",14);
+                sensorMap.put("default_unit_key",sysDictDataMapper.selectOne(wrapper_VSU).getDataValue());
+            }
             sensorList.add(sensorMap);
         }
-        resultMap.put("manageRoles",sensorList);
+        resultMap.put("sensors",sensorList);
         resultMap.put("totalNumber",totleNum);
         resultMap.put("current",current);
         int totalPageNumber = totleNum/size;
@@ -250,7 +302,9 @@
     public Map<String,Sensor> getAllSensorFromCache(){
         Map<String,Sensor> sensors = redisTemplate.opsForHash().entries(RedisConstants.SENSOR_KEY);
         if(ObjectUtils.isEmpty(sensors))
-            return getAllSensorFromDB();
+            sensors =  getAllSensorFromDB();
+        //������������
+        refreshCache(sensors);
         return sensors;
     }
 
@@ -262,8 +316,6 @@
         for (Sensor sensor : sensors) {
             result.put(sensor.getCode(),sensor);
         }
-        //������������
-        refreshCache(result);
         return result;
     }
 

--
Gitblit v1.8.0