From 31189373f177755f0b0ec18c368cc3c33e3cd007 Mon Sep 17 00:00:00 2001
From: aijinhui <aijinhui>
Date: 星期四, 21 九月 2023 09:29:01 +0800
Subject: [PATCH] 设备健康列表

---
 ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java |   81 ++++++++++++++++++++++++++--------------
 1 files changed, 52 insertions(+), 29 deletions(-)

diff --git a/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java b/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
index 1ba9a14..b3c6f7e 100644
--- a/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
+++ b/ard-work/src/main/java/com/ruoyi/device/camera/controller/ArdCamerasController.java
@@ -3,12 +3,13 @@
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletResponse;
 
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
 import com.ruoyi.device.camera.domain.ArdCameras;
+import com.ruoyi.device.camera.domain.CameraCmd;
 import com.ruoyi.device.camera.service.IArdCamerasService;
-import com.ruoyi.device.hiksdk.service.impl.hikClientServiceImpl;
-import com.ruoyi.common.annotation.Anonymous;
-import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.device.hiksdk.service.impl.HikClientServiceImpl;
 import com.ruoyi.common.utils.poi.ExcelUtil;
+import com.ruoyi.inspect.service.IArdVideoInspectTaskService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
@@ -26,8 +27,7 @@
 import com.ruoyi.common.core.domain.AjaxResult;
 import com.ruoyi.common.enums.BusinessType;
 import com.ruoyi.common.core.page.TableDataInfo;
-
-import java.util.List;
+import java.util.*;
 
 /**
  * 鐩告満璁惧Controller
@@ -41,9 +41,11 @@
 @Api(tags = "鐩告満绠$悊鎺ュ彛")
 public class ArdCamerasController extends BaseController {
     @Resource
-    private hikClientServiceImpl sdk;
+    private HikClientServiceImpl sdk;
     @Resource
     private IArdCamerasService ardCamerasService;
+    @Resource
+    private IArdVideoInspectTaskService ardVideoInspectTaskService;
 
     /**
      * 鏌ヨ鐩告満璁惧鍒楄〃
@@ -91,16 +93,7 @@
         //娉ㄩ攢
         sdk.loginOut(camera.getId());
         //鐧诲綍
-        camera = sdk.login(camera);
-        if (camera.getLoginId() >= 0) {
-            log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛锛�" + camera.getLoginId());
-            camera.setUpdateBy(SecurityUtils.getUsername());
-            ardCamerasService.updateArdCameras(camera);
-        }
-        else
-        {
-            log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍澶辫触锛�" + camera.getLoginId());
-        }
+        sdk.login(camera);
         return toAjax(ardCamerasService.insertArdCameras(camera));
     }
 
@@ -113,19 +106,10 @@
     @PutMapping
     public AjaxResult edit(@RequestBody ArdCameras camera) {
         int i = ardCamerasService.updateArdCameras(camera);
-        if(i>0)
-        {
+        if (i > 0) {
             ArdCameras cameras = ardCamerasService.selectArdCamerasById(camera.getId());
             sdk.loginOut(cameras.getId());
-            camera = sdk.login(cameras);
-            if (camera.getLoginId() >= 0) {
-                log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍鎴愬姛锛�" + camera.getLoginId());
-                ardCamerasService.updateArdCameras(camera);
-            }
-            else
-            {
-                log.info("鐩告満" + camera.getIp() + ":" + camera.getPort() + "鐧诲綍澶辫触锛�" + camera.getLoginId());
-            }
+            sdk.login(cameras);
         }
         return toAjax(i);
     }
@@ -139,8 +123,47 @@
     @DeleteMapping("/{ids}")
     public AjaxResult remove(@PathVariable String[] ids) {
         for (String id : ids) {
-               sdk.loginOut(id);
-            }
+            sdk.loginOut(id);
+        }
         return toAjax(ardCamerasService.deleteArdCamerasByIds(ids));
     }
+
+    @GetMapping("/options")
+    @ApiOperation("閫夋嫨鐩告満鏁版嵁")
+    public List options(ArdCameras ardCameras) {
+        List<ArdCameras> list = ardCamerasService.findOptions(ardCameras);
+        List options = new ArrayList();
+        for (ArdCameras item : list) {
+            Map option = new HashMap();
+            option.put("value", item.getId());
+            option.put("label", item.getName());
+            option.put("channel", item.getChanNo());
+            List timeList = ardVideoInspectTaskService.getCameraIdleTimeList(item.getId());
+            option.put("idleTimeList", timeList);//绌洪棽鏃堕棿娈�
+            options.add(option);
+        }
+        return options;
+    }
+    @GetMapping("/getDeptAndCamera")
+    @ApiOperation("鑾峰彇閮ㄩ棬鍜岀浉鏈�")
+    public AjaxResult getDeptAndCamera()
+    {
+        Map deptAndCamera = ardCamerasService.getChildDeptAndCamera(true);
+        return AjaxResult.success(deptAndCamera);
+    }
+    @GetMapping("/getDeptAndCameraWithCheckBox")
+    @ApiOperation("鑾峰彇閮ㄩ棬鍜岀浉鏈�(寮�鍚閫夋)")
+    public AjaxResult getDeptAndCameraWithCheckBox()
+    {
+        Map deptAndCamera = ardCamerasService.getChildDeptAndCamera(false);
+        return AjaxResult.success(deptAndCamera);
+    }
+    @PostMapping("/getNearCamerasBycoordinate")
+    @ApiOperation("鑾峰彇闄勮繎鐨勭浉鏈�")
+    @ApiOperationSupport(includeParameters = {"targetPosition"})
+    public AjaxResult getNearCamerasBycoordinate(@RequestBody CameraCmd cmd)
+    {
+        TreeMap nearCamerasBycoordinate = ardCamerasService.getNearCamerasBycoordinate(cmd);
+        return AjaxResult.success(nearCamerasBycoordinate);
+    }
 }

--
Gitblit v1.9.3