From 4f708def438b40d2a55c4bb479eb67acf8076a95 Mon Sep 17 00:00:00 2001
From: fengxiang <110431245@qq.com>
Date: Wed, 25 Apr 2018 13:09:59 +0800
Subject: [PATCH] 微信展示数据详情页面

---
 src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java |  201 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 196 insertions(+), 5 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
index 77ecb3f..3274397 100644
--- a/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/MonitorPointServiceImpl.java
@@ -1,26 +1,217 @@
 package com.moral.service.impl;
 
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
+import java.util.stream.Collectors;
 
 import javax.annotation.Resource;
 
+import org.apache.commons.collections.CollectionUtils;
 import org.springframework.stereotype.Service;
 
+import com.github.pagehelper.PageHelper;
+import com.moral.common.bean.Constants;
+import com.moral.common.bean.PageBean;
+import com.moral.common.util.ExampleUtil;
+import com.moral.common.util.RedisUtils;
+import com.moral.common.util.StringUtils;
 import com.moral.common.util.ValidateUtil;
+import com.moral.entity.Device;
 import com.moral.entity.MonitorPoint;
+import com.moral.mapper.DeviceMapper;
 import com.moral.mapper.MonitorPointMapper;
 import com.moral.service.MonitorPointService;
 
+import tk.mybatis.mapper.entity.Example;
+import tk.mybatis.mapper.entity.Example.Criteria;
+
 @Service
 public class MonitorPointServiceImpl implements MonitorPointService {
-	@Resource
-	private MonitorPointMapper monitorPointMapper;
+    @Resource
+    private MonitorPointMapper monitorPointMapper;
+    @Resource
+    private DeviceMapper deviceMapper;
+    @Resource
+    RedisUtils redisUtils;
+    private static Class ENTITY_CLASS = MonitorPoint.class;
+    @Override
+    public List<MonitorPoint> getMonitorPointsByAreaName(Map<String, Object> parameters) {
+        ValidateUtil.notNull(parameters.get("areaName"), "param.is.null");
+        return monitorPointMapper.getMonitorPointsByAreaName(parameters);
+    }
+    @Override
+    public List<MonitorPoint> queryWithStateByMap(Map<String, Object> params){
+        params.put("isDelete",Constants.IS_DELETE_FALSE);
+        List<MonitorPoint> monitorPointList = monitorPointMapper.selectByMap(params);
+        for(MonitorPoint monitorPoint:monitorPointList){
+            Integer state = getStateFromRedis(monitorPoint.getId());
+            monitorPoint.setState(state);
+        }
+        return monitorPointList;
+    }
+    private Integer getStateFromRedis(Integer monitorPointId){
+        StringBuilder key = new StringBuilder();
+        key.append("state_").append(monitorPointId).append("_*");
+        List<Map> stateList = redisUtils.getList(key.toString(),Map.class);
+        int state = -1;
+        if(stateList!=null){
+            for (Map deviceState:stateList){
+                int s =  Integer.parseInt(deviceState.get("state").toString());
+                state = s>state&&s<4?s:state;
+            }
+        }
+        state = state==-1?4:state;
+        return state;
+    }
+    @Override
+    public PageBean queryByPageBean(PageBean pageBean) {
+        Example example = ExampleUtil.generateExample(ENTITY_CLASS,pageBean);
+        List<Example.Criteria> criteriaList = example.getOredCriteria();
+        if(criteriaList!=null&&criteriaList.size()>0){
+            for(Example.Criteria cri : criteriaList){
+                cri.andNotEqualTo("isDelete", Constants.IS_DELETE_TRUE);
+            }
+        }else {
+            example.or().andNotEqualTo("isDelete",Constants.IS_DELETE_TRUE);
+        }
+        PageHelper.startPage(pageBean.getPageIndex(),pageBean.getPageSize());
+        List<MonitorPoint> monitorPointList = monitorPointMapper.selectWithAreaNameByExample(example);
+        return new PageBean(monitorPointList);
+    }
+    @Override
+   public MonitorPoint queryWithRelationById(Integer id){
+         Example example = new Example(ENTITY_CLASS);
+         example.or().andEqualTo("id",id);
+         List<MonitorPoint> monitorPointList = monitorPointMapper.selectWithAreaNameByExample(example);
+         return monitorPointList!=null&&monitorPointList.size()>0?monitorPointList.get(0):null;
+    }
+    @Override
+    public void addOrModify(MonitorPoint monitorPoint) {
+        try{
+            if(monitorPoint.getId()==null){
+                monitorPoint.setIsDelete(Constants.IS_DELETE_FALSE);
+                monitorPointMapper.insertSelective(monitorPoint);
+            }else{
+                monitorPointMapper.updateByPrimaryKeySelective(monitorPoint);
+                // ������������������������������ ���redis���������������
+                refreshDevicesInRedis(monitorPoint.getId());
+            }
+        }
+        catch (Exception ex){
+            throw  ex;
+        }
+    }
+    /*
+      ������������������������������ ���redis���������������
+     */
+    private void  refreshDevicesInRedis(int monitorPointId){
+        Device device = new Device();
+        device.setMonitorPointId(monitorPointId);
+        List<Device> deviceList = deviceMapper.select(device);
+        if (!CollectionUtils.isEmpty(deviceList)){
+            List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(monitorPointId);
+            if (!CollectionUtils.isEmpty(orgIds)){
+                deviceList.stream().forEach(dev ->{
+                    if(!StringUtils.isNullOrEmpty(dev.getMac())){
+                        String key = "device_"+dev.getMac();
+                        // ��������������������� ������������redis
+                        Device simpleDevice = new Device();
+                        simpleDevice.setId(dev.getId());
+                        simpleDevice.setDeviceVersion(dev.getDeviceVersion());
+                        simpleDevice.setMac(dev.getMac());
+                        simpleDevice.setMonitorPointId(dev.getMonitorPointId());
+                        // ������������������������������������������������������������������
+                        simpleDevice.setOrganizationIds(orgIds);
+                        redisUtils.set(key,simpleDevice);
+                    }
+                });
+            }
+        }
+
+    }
+    @Override
+    public void deleteByIds(Integer... ids) {
+        MonitorPoint monitorPoint = new MonitorPoint();
+        monitorPoint.setIsDelete(Constants.IS_DELETE_TRUE);
+        if(ids!=null&&ids.length>0){
+            if(ids.length==1){
+                monitorPoint.setId(ids[0]);
+                monitorPointMapper.updateByPrimaryKeySelective(monitorPoint);
+            }else{
+                Example example = new Example(ENTITY_CLASS);
+                example.or().andIn("id", Arrays.asList(ids));
+                monitorPointMapper.updateByExampleSelective(monitorPoint,example);
+            }
+
+        }
+    }
 
 	@Override
-	public List<MonitorPoint> getMonitorPointsByAreaName(Map<String, Object> parameters) {
-		ValidateUtil.notNull(parameters.get("areaName"), "param.is.null");
-		return monitorPointMapper.getMonitorPointsByAreaName(parameters);
+	public List<MonitorPoint> getMonitorPointsByName(String name) {
+		Example example = new Example(MonitorPoint.class);
+		Criteria criteria = example.createCriteria();
+
+		criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE).andLike("name", "%" + name + "%");
+		example.or().andEqualTo("isDelete", Constants.IS_DELETE_FALSE)
+				.andCondition("getPY(" + getReplaceStr("name") + ") like ", "%" + name + "%");
+
+		List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
+		return monitorPoints;
 	}
 
+	private String getReplaceStr(String name){
+        List<String[]> list = new ArrayList<String[]>();
+        list.add(new String[]{"���",""});
+        list.add(new String[]{"���",""});
+        for (String[] string : list) {
+        	name = replace(name,string[0],string[1]);
+		}
+		return name;
+	}
+	
+	private  String replace(String name,String fromStr,String toStr){
+		return "REPLACE (" + name + ",'" + fromStr + "','" + toStr + "')";
+	}
+
+    /**
+     *
+     * @param idList
+     * @return  {id:,state:}
+     */
+    @Override
+    public List<Map<String, String>> queryMonitroPointsState(List<Integer> idList) {
+        List<Map<String, String>> list = idList.stream().map( id -> {
+           Integer state = getStateFromRedis(id);
+           Map<String,String> stateMap = new HashMap<>();
+           stateMap.put("id",id.toString());
+           stateMap.put("state",state.toString());
+           return stateMap;
+        }).collect(Collectors.toList());
+        return list;
+    }
+
+    @Override
+	public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) {
+		Example example = new Example(MonitorPoint.class);
+		Criteria criteria = example.createCriteria();
+		
+		criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
+		if (Constants.isNotSpecialOrgId(orgId)) {
+			criteria.andEqualTo("organizationId", orgId);
+		}
+		example.orderBy("name").asc();
+		return monitorPointMapper.selectByExample(example);
+	}
+	@Override
+	public List<MonitorPoint> getMonitorPointsByRegion(Map<String, Object> parameters) {
+		Example example = new Example(MonitorPoint.class);
+		Criteria criteria = example.createCriteria();
+		
+		criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
+		criteria.andEqualTo(parameters.get("name").toString(), parameters.get("value"));
+		return monitorPointMapper.selectByExample(example);
+	}
 }

--
Gitblit v1.8.0