From 4b4a35fc7cc56a8b304ca35f0a9ec0bdd2e0e036 Mon Sep 17 00:00:00 2001
From: jinpengyong <jpy123456>
Date: Mon, 22 Apr 2024 11:41:48 +0800
Subject: [PATCH] fix:路径规划补充提交

---
 screen-api/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java |  102 +++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 94 insertions(+), 8 deletions(-)

diff --git a/screen-api/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java
index 0d730ba..bc6608c 100644
--- a/screen-api/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java
+++ b/screen-api/src/main/java/com/moral/api/service/impl/OrganizationServiceImpl.java
@@ -1,17 +1,25 @@
 package com.moral.api.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.moral.api.entity.Organization;
+import com.moral.api.mapper.DeviceMapper;
+import com.moral.api.mapper.MonitorPointMapper;
 import com.moral.api.mapper.OrganizationMapper;
+import com.moral.api.pojo.vo.device.DeviceVO;
+import com.moral.api.pojo.vo.monitorPoint.MonitorPointVos;
+import com.moral.api.service.DeviceService;
 import com.moral.api.service.OrganizationService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.moral.constant.Constants;
+import com.moral.util.TokenUtils;
+import org.apache.commons.collections4.CollectionUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.util.ObjectUtils;
-
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Map;
 
 /**
  * <p>
@@ -27,6 +35,14 @@
     @Autowired
     OrganizationMapper organizationMapper;
 
+    @Autowired
+    MonitorPointMapper monitorPointMapper;
+
+
+    @Autowired
+    DeviceMapper deviceMapper;
+
+
 
     @Override
     public List<Organization> getChildrenOrganizationsById(Integer id) {
@@ -36,14 +52,11 @@
     }
 
     @Override
-    public Organization getStateControlStation() {
-        QueryWrapper<Organization> wrapper = new QueryWrapper<>();
-        wrapper.select("id");
-        wrapper.eq("name","���������");
-        wrapper.eq("is_delete",Constants.NOT_DELETE);
-        Organization organization = organizationMapper.selectOne(wrapper);
-        return organization;
+    public Organization getOrganizationById(Integer id) {
+        return organizationMapper.selectById(id);
     }
+
+
 
     /**
     * @Description: ���������������������������������������������������children���
@@ -67,4 +80,77 @@
             return;
         }
     }
+
+    @Override
+    public List<Integer> orgIdList(Integer organizationId) {
+        return this.baseMapper.orgIdList(organizationId);
+    }
+
+    /**
+     * ������id������������������
+     *
+     * @param
+     * @return
+     */
+    @Override
+    public List<Organization> getOrganizationId() {
+        //������������������
+        Map<String, Object> userInfo = (Map<String, Object>) TokenUtils.getUserInfo();
+        Map<String, Object> orgInfo = (Map<String, Object>) userInfo.get("organization");
+        Integer organizationId = (Integer) orgInfo.get("id");
+         ArrayList<Organization> rsList = new ArrayList<>();
+        if (organizationId==24){
+            LambdaQueryWrapper<Organization> wrapper = new LambdaQueryWrapper<>();
+            wrapper.eq(Organization::getParentId,organizationId);
+            wrapper.eq(Organization::getIsDelete,Constants.NOT_DELETE);
+            wrapper.orderByDesc(Organization::getCreateTime);
+            List<Organization> organizations = organizationMapper.selectList(wrapper);
+            rsList.addAll(organizations);
+        }else {
+            Organization organizationById = this.getOrganizationById(organizationId);
+            rsList.add(organizationById);
+        }
+        return rsList;
+    }
+
+    /**
+     * ������������������
+     * @return
+     */
+    @Override
+    public List<Organization> queryDevices() {
+        Map<String, Object> userInfo = (Map<String, Object>) TokenUtils.getUserInfo();
+        Map<String, Object> orgInfo = (Map<String, Object>) userInfo.get("organization");
+        Integer organizationId = (Integer) orgInfo.get("id");
+        LambdaQueryWrapper<Organization> wrapper = new LambdaQueryWrapper<>();
+        wrapper.select(Organization::getId,Organization::getAddress,Organization::getAreaName,Organization::getName);
+        wrapper.eq(Organization::getIsDelete,Constants.NOT_DELETE);
+        wrapper.orderByDesc(Organization::getCreateTime);
+        List<Organization> organizations;
+        if (organizationId==24){
+            wrapper.eq(Organization::getParentId,organizationId);
+             organizations = organizationMapper.selectList(wrapper);
+        }else {
+            wrapper.eq(Organization::getId,organizationId);
+             organizations = organizationMapper.selectList(wrapper);
+        }
+        if (CollectionUtils.isNotEmpty(organizations)){
+            organizations.forEach(it ->{
+                //������������
+//                QueryWrapper<MonitorPoint> queryMonitorPointsWrapper = new QueryWrapper<>();
+//                queryMonitorPointsWrapper.eq("organization_id", it.getId());
+//                queryMonitorPointsWrapper.eq("is_delete", Constants.NOT_DELETE);
+//                List<MonitorPoint> monitorPoints = monitorPointMapper.selectList(queryMonitorPointsWrapper);
+                List<MonitorPointVos> monitorPoints = monitorPointMapper.getMonitorPoint(it.getId());
+                //���������������������������
+                for (MonitorPointVos monitorPoint : monitorPoints) {
+//                    List<Device> devices = deviceService.getDevicesByMonitorPointId(monitorPoint.getId());
+                    List<DeviceVO> listVo = deviceMapper.getListVo(monitorPoint.getId());
+                    monitorPoint.setMonitorPoint(listVo);
+                }
+                it.setMonitorPoint(monitorPoints);
+            } );
+        }
+        return organizations;
+    }
 }

--
Gitblit v1.8.0