From 92dba8e44a911c92832ecc22e4c98968409d5c68 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期二, 14 十一月 2023 15:01:37 +0800
Subject: [PATCH] 远程封印

---
 ard-work/src/main/java/com/ruoyi/alarmpoints/well/service/impl/ArdAlarmpointsWellServiceImpl.java |  117 ++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 85 insertions(+), 32 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/alarmpoints/well/service/impl/ArdAlarmpointsWellServiceImpl.java b/ard-work/src/main/java/com/ruoyi/alarmpoints/well/service/impl/ArdAlarmpointsWellServiceImpl.java
index c18c197..70182f0 100644
--- a/ard-work/src/main/java/com/ruoyi/alarmpoints/well/service/impl/ArdAlarmpointsWellServiceImpl.java
+++ b/ard-work/src/main/java/com/ruoyi/alarmpoints/well/service/impl/ArdAlarmpointsWellServiceImpl.java
@@ -1,11 +1,13 @@
 package com.ruoyi.alarmpoints.well.service.impl;
 
+import java.util.ArrayList;
 import java.util.List;
 
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.github.pagehelper.PageHelper;
 import com.github.pagehelper.PageInfo;
 import com.ruoyi.alarmpoints.well.domain.ArdAlarmpointsWell;
+import com.ruoyi.alarmpoints.well.domain.ArdAlarmpointsWellDeptVo;
 import com.ruoyi.alarmpoints.well.domain.ArdAlarmpointsWellParam;
 import com.ruoyi.alarmpoints.well.mapper.ArdAlarmpointsWellMapper;
 import com.ruoyi.alarmpoints.well.service.IArdAlarmpointsWellService;
@@ -18,6 +20,7 @@
 import com.ruoyi.common.utils.bean.BeanValidators;
 import com.ruoyi.common.utils.spring.SpringUtils;
 import com.ruoyi.common.utils.uuid.IdUtils;
+import com.ruoyi.utils.gis.GisUtil;
 import lombok.ToString;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -41,6 +44,7 @@
     private ArdAlarmpointsWellMapper ardAlarmpointsWellMapper;
     @Autowired
     protected Validator validator;
+
     /**
      * 鏌ヨ浜曠鐞�
      *
@@ -51,6 +55,7 @@
     public ArdAlarmpointsWell selectArdAlarmpointsWellById(String id) {
         return ardAlarmpointsWellMapper.selectArdAlarmpointsWellById(id);
     }
+
     /**
      * 鏌ヨ浜曠鐞�
      *
@@ -69,18 +74,17 @@
      * @return 浜曠鐞�
      */
     @Override
-    @DataScope(deptAlias = "d",userAlias = "u")
+    @DataScope(deptAlias = "d", userAlias = "u")
     public List<ArdAlarmpointsWell> selectArdAlarmpointsWellList(ArdAlarmpointsWell ardAlarmpointsWell) {
         return ardAlarmpointsWellMapper.selectArdAlarmpointsWellList(ardAlarmpointsWell);
     }
 
     /**
-     *
      * @param ardAlarmpointsWell 鎸変簳缂栧彿鏌ヨ
      * @return
      */
     @Override
-    @DataScope(deptAlias = "d",userAlias = "u")
+    @DataScope(deptAlias = "d", userAlias = "u")
     public List<ArdAlarmpointsWell> selectArdAlarmpointsWellByWellIdLike(ArdAlarmpointsWell ardAlarmpointsWell) {
         return ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellIdLike(ardAlarmpointsWell);
     }
@@ -94,9 +98,8 @@
     @Override
     @Transactional
     public int insertArdAlarmpointsWell(ArdAlarmpointsWell ardAlarmpointsWell) {
-        boolean wellIdExists = ardAlarmpointsWellMapper.checkWellIdExists(ardAlarmpointsWell.getWellId());
-        if(wellIdExists)
-        {
+        boolean wellIdExists = checkWellIdExists(ardAlarmpointsWell);
+        if (wellIdExists) {
             throw new RuntimeException("浜曞彿宸插瓨鍦�");
         }
         ardAlarmpointsWell.setId(IdUtils.simpleUUID());
@@ -115,16 +118,21 @@
     @Override
     @Transactional
     public int updateArdAlarmpointsWell(ArdAlarmpointsWell ardAlarmpointsWell) {
-        boolean wellIdExists = ardAlarmpointsWellMapper.checkWellIdExists(ardAlarmpointsWell.getWellId());
-        if(wellIdExists)
-        {
+        boolean wellIdExists = checkWellIdExists(ardAlarmpointsWell);
+        if (wellIdExists) {
             throw new RuntimeException("浜曞彿宸插瓨鍦�");
         }
         ardAlarmpointsWell.setUpdateBy(SecurityUtils.getUsername());
         ardAlarmpointsWell.setUpdateTime(DateUtils.getNowDate());
         return ardAlarmpointsWellMapper.updateArdAlarmpointsWell(ardAlarmpointsWell);
     }
-
+    @Override
+    @Transactional
+    public int updateArdAlarmpointsWellByWellId(ArdAlarmpointsWell ardAlarmpointsWell) {
+        ardAlarmpointsWell.setUpdateBy(SecurityUtils.getUsername());
+        ardAlarmpointsWell.setUpdateTime(DateUtils.getNowDate());
+        return ardAlarmpointsWellMapper.updateArdAlarmpointsWellByWellId(ardAlarmpointsWell);
+    }
     /**
      * 鎵归噺鍒犻櫎浜曠鐞�
      *
@@ -148,7 +156,7 @@
     }
 
     @Override
-    public String importUser(List<ArdAlarmpointsWell> ardAlarmpointsWellList, Boolean isUpdateSupport, String operName) {
+    public String importWell(List<ArdAlarmpointsWell> ardAlarmpointsWellList, Boolean isUpdateSupport, String operName) {
         if (StringUtils.isNull(ardAlarmpointsWellList) || ardAlarmpointsWellList.size() == 0) {
             throw new ServiceException("瀵煎叆浜曟暟鎹笉鑳戒负绌猴紒");
         }
@@ -161,9 +169,9 @@
                 //鑾峰彇褰撳墠鐧诲綍鐢ㄦ埛id
                 String userId = SecurityUtils.getUserId();
                 well.setUserId(userId);
-                // 楠岃瘉鏄惁瀛樺湪杩欎釜鐢ㄦ埛
-                ArdAlarmpointsWell u = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(well.getWellId());
-                if (StringUtils.isNull(u)) {
+                // 楠岃瘉鏄惁瀛樺湪杩欎釜浜�
+                ArdAlarmpointsWell w = ardAlarmpointsWellMapper.selectArdAlarmpointsWellByWellId(well.getWellId());
+                if (StringUtils.isNull(w)) {
                     BeanValidators.validateWithException(validator, well);
                     well.setCreateBy(operName);
                     this.insertArdAlarmpointsWell(well);
@@ -171,10 +179,9 @@
                     successMsg.append("<br/>" + successNum + "銆佷簳鍙� " + well.getWellId() + " 瀵煎叆鎴愬姛");
                 } else if (isUpdateSupport) {
                     BeanValidators.validateWithException(validator, well);
-                    checkWellAllowed(well);
                     checkWellDataScope(well.getUserId());
                     well.setUpdateBy(operName);
-                    this.updateArdAlarmpointsWell(well);
+                    this.updateArdAlarmpointsWellByWellId(well);
                     successNum++;
                     successMsg.append("<br/>" + successNum + "銆佷簳鍙� " + well.getWellId() + " 鏇存柊鎴愬姛");
                 } else {
@@ -203,10 +210,8 @@
      * @param well 浜曚俊鎭�
      */
     @Override
-    public void checkWellAllowed(ArdAlarmpointsWell well)
-    {
-        if (StringUtils.isNotNull(well.getId()))
-        {
+    public void checkWellAllowed(ArdAlarmpointsWell well) {
+        if (StringUtils.isNotNull(well.getId())) {
             throw new ServiceException("涓嶅厑璁告搷浣滀簳");
         }
     }
@@ -217,25 +222,41 @@
      * @param userId 鐢ㄦ埛id
      */
     @Override
-    public void checkWellDataScope(String userId)
-    {
-        if (!SysUser.isAdmin(SecurityUtils.getUserId()))
-        {
+    public void checkWellDataScope(String userId) {
+        if (!SysUser.isAdmin(SecurityUtils.getUserId())) {
             ArdAlarmpointsWell well = new ArdAlarmpointsWell();
             well.setUserId(userId);
             List<ArdAlarmpointsWell> wells = SpringUtils.getAopProxy(this).selectArdAlarmpointsWellList(well);
-            if (StringUtils.isEmpty(wells))
-            {
+            if (StringUtils.isEmpty(wells)) {
                 throw new ServiceException("娌℃湁鏉冮檺璁块棶浜曟暟鎹紒");
             }
         }
     }
 
+    /**
+     * 鏍稿浜曞彿鏄惁鍞竴
+     *
+     * @param well 闇�瑕佹牳瀵圭殑浜�
+     * @return 缁撴灉
+     */
+    @Override
+    public Boolean checkWellIdExists(ArdAlarmpointsWell well) {
+        // 鏍¢獙锛歸ellId
+        String id = (well.getId() == null) ? "" : well.getId();
+        String wellId = well.getWellId();
+        ArdAlarmpointsWell ardAlarmpointsWell = ardAlarmpointsWellMapper.checkWellIdExists(wellId);
+        String infoId = (ardAlarmpointsWell == null) ? "" : (ardAlarmpointsWell.getId());
+        if ((ardAlarmpointsWell != null) && !((infoId).equals(id))) {
+            //宸插瓨鍦�
+            return true;
+        }
+        return false;
+    }
 
     @Override
     public List<ArdAlarmpointsWell> wellByDeptList(List<Long> deptList) {
         QueryWrapper<ArdAlarmpointsWell> queryWrapper = new QueryWrapper<>();
-        queryWrapper.in("dept_id",deptList);
+        queryWrapper.in("dept_id", deptList);
         return ardAlarmpointsWellMapper.selectList(queryWrapper);
     }
 
@@ -247,18 +268,18 @@
     @Override
     public List<ArdAlarmpointsWell> wellList(List<Long> deptList) {
         QueryWrapper<ArdAlarmpointsWell> queryWrapper = new QueryWrapper<>();
-        queryWrapper.select("id","well_id","oil_production","longitude","latitude","altitude").in("dept_id",deptList);
+        queryWrapper.select("id", "well_id", "oil_production", "longitude", "latitude", "altitude").in("dept_id", deptList);
         return ardAlarmpointsWellMapper.selectList(queryWrapper);
     }
 
     @Override
-    public PageInfo<ArdAlarmpointsWell> conditionList(ArdAlarmpointsWellParam ardAlarmpointsWellParam){
+    public PageInfo<ArdAlarmpointsWell> conditionList(ArdAlarmpointsWellParam ardAlarmpointsWellParam) {
         Integer pageNum = ardAlarmpointsWellParam.getPageNum();
         Integer pageSize = ardAlarmpointsWellParam.getPageSize();
-        PageHelper.startPage(pageNum,pageSize);
+        PageHelper.startPage(pageNum, pageSize);
         QueryWrapper<ArdAlarmpointsWell> queryWrapper = new QueryWrapper<>();
-        queryWrapper.in("dept_id",ardAlarmpointsWellParam.getDeptList())
-        .like(!StringUtils.isBlank(ardAlarmpointsWellParam.getWellId()),"well_id",ardAlarmpointsWellParam.getWellId());
+        queryWrapper.in("dept_id", ardAlarmpointsWellParam.getDeptList())
+                .like(!StringUtils.isBlank(ardAlarmpointsWellParam.getWellId()), "well_id", ardAlarmpointsWellParam.getWellId());
 //        .eq(!StringUtils.isBlank(ardAlarmpointsWellParam.getWellNumber()),"well_number",ardAlarmpointsWellParam.getWellNumber())
 //        .eq(!StringUtils.isBlank(ardAlarmpointsWellParam.getOilProduction()),"oil_production",ardAlarmpointsWellParam.getOilProduction())
 //        .eq(!StringUtils.isBlank(ardAlarmpointsWellParam.getWellBlock()),"well_block",ardAlarmpointsWellParam.getWellBlock())
@@ -273,4 +294,36 @@
         List<ArdAlarmpointsWell> list = ardAlarmpointsWellMapper.selectList(queryWrapper);
         return new PageInfo<>(list);
     }
+
+    @Override
+    public List<ArdAlarmpointsWellDeptVo> wellListDept(List<Long> deptList) {
+        return ardAlarmpointsWellMapper.wellListDept(deptList);
+    }
+
+    @Override
+    public List<ArdAlarmpointsWell> getNearbyWellList(Double longitudeCenter,Double latitudeCenter, Long deptId, Integer range) {
+        List<ArdAlarmpointsWell> nearbyWellList = new ArrayList<>();
+        try {
+            if (longitudeCenter != null && latitudeCenter != null) {
+                ArdAlarmpointsWell ardAlarmpointsWell=new ArdAlarmpointsWell();
+                ardAlarmpointsWell.setDeptId(deptId);
+                List<ArdAlarmpointsWell> ardAlarmpointsWells = ardAlarmpointsWellMapper.selectArdAlarmpointsWellList(ardAlarmpointsWell);
+                if (ardAlarmpointsWells.size() > 0) {
+                    for (ArdAlarmpointsWell well : ardAlarmpointsWells) {
+                        Double longitude = well.getLongitude();
+                        Double latitude = well.getLatitude();
+                        if (longitude != null && latitude != null) {
+                            double distance = GisUtil.getDistance(new Double[]{longitudeCenter, latitudeCenter}, new Double[]{longitude, latitude});
+                            if (distance <= range) {
+                                nearbyWellList.add(well);
+                            }
+                        }
+                    }
+                }
+            }
+        } catch (Exception ex) {
+            log.error("鑾峰彇闄勮繎浜曞紓甯革細" + ex.getMessage());
+        }
+        return nearbyWellList;
+    }
 }

--
Gitblit v1.9.3