From 3b0516a2959e25576e4f3fda697a3b025d06c8c9 Mon Sep 17 00:00:00 2001
From: zxl <763096477@qq.com>
Date: 星期二, 24 六月 2025 14:09:07 +0800
Subject: [PATCH] 每日录像可用指标添加日志,修改大屏为查看当前月平均

---
 ycl-server/src/main/java/com/ycl/platform/service/impl/YwUnitServiceImpl.java |  101 ++++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 84 insertions(+), 17 deletions(-)

diff --git a/ycl-server/src/main/java/com/ycl/platform/service/impl/YwUnitServiceImpl.java b/ycl-server/src/main/java/com/ycl/platform/service/impl/YwUnitServiceImpl.java
index c91c0e6..56546b7 100644
--- a/ycl-server/src/main/java/com/ycl/platform/service/impl/YwUnitServiceImpl.java
+++ b/ycl-server/src/main/java/com/ycl/platform/service/impl/YwUnitServiceImpl.java
@@ -1,40 +1,39 @@
 package com.ycl.platform.service.impl;
 
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
-
-import java.util.Collections;
-import java.util.HashMap;
-import java.util.List;
-
 import com.ycl.platform.base.BaseSelect;
 import com.ycl.platform.domain.entity.YwUnit;
 import com.ycl.platform.domain.form.YwUnitForm;
+import com.ycl.platform.domain.query.DistributeWorkOrderQuery;
 import com.ycl.platform.domain.query.YwUnitQuery;
 import com.ycl.platform.domain.vo.YwUnitVO;
-import com.ycl.system.Result;
 import com.ycl.platform.mapper.YwUnitMapper;
+import com.ycl.platform.service.YwUnitService;
+import com.ycl.system.Result;
 import com.ycl.system.domain.SysUserRole;
 import com.ycl.system.entity.SysRole;
 import com.ycl.system.entity.SysUser;
 import com.ycl.system.mapper.SysRoleMapper;
 import com.ycl.system.mapper.SysUserMapper;
 import com.ycl.system.mapper.SysUserRoleMapper;
+import com.ycl.system.model.LoginUser;
 import com.ycl.system.page.PageUtil;
-import com.ycl.platform.service.YwUnitService;
-import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.ycl.utils.DateUtils;
 import com.ycl.utils.SecurityUtils;
-import org.springframework.stereotype.Service;
+import enumeration.ErrorType;
+import lombok.RequiredArgsConstructor;
+import org.apache.ibatis.annotations.Param;
 import org.springframework.beans.BeanUtils;
+import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.Assert;
-
-import java.util.Objects;
-import java.util.stream.Collectors;
-import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
-import lombok.RequiredArgsConstructor;
 import org.springframework.util.StringUtils;
+
+import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 杩愮淮鍗曚綅 鏈嶅姟瀹炵幇绫�
@@ -60,18 +59,23 @@
     @Transactional(rollbackFor = Exception.class)
     public Result add(YwUnitForm form) {
         YwUnit entity = YwUnitForm.getEntityByForm(form, null);
+        Date now = new Date();
+        entity.setCreateTime(now);
+        entity.setUpdateTime(now);
         if(baseMapper.insert(entity) > 0) {
             // 鏂板杩愮淮浜哄憳璐﹀彿
             SysUser sysUser = new SysUser();
             sysUser.setDeptId(null);
+            sysUser.setUnitId(entity.getId());
             sysUser.setUserName(entity.getUnitAdminAccount());
             sysUser.setNickName(entity.getUnitContact());
             sysUser.setPhonenumber(entity.getUnitContactPhone());
-            sysUser.setPassword(SecurityUtils.encryptPassword("123456"));
+            sysUser.setPassword(SecurityUtils.encryptPassword(form.getPassword()));
+            sysUser.setDelFlag(0);
             sysUserMapper.insertUser(sysUser);
             // 鑾峰彇杩愮淮浜哄憳瑙掕壊
             SysRole sysRole = sysRoleMapper.selectRoleByKey("yw_user");
-            if (Objects.isNull(sysRole)) { return Result.error("杩愮淮瑙掕壊涓嶅瓨鍦�"); }
+            if (Objects.isNull(sysRole)) { throw new RuntimeException("杩愮淮瑙掕壊涓嶅瓨鍦�"); }
             // 缁戝畾璐﹀彿瑙掕壊鍏崇郴
             SysUserRole sysUserRole = new SysUserRole();
             sysUserRole.setRoleId(sysRole.getRoleId());
@@ -91,10 +95,11 @@
     @Transactional(rollbackFor = Exception.class)
     public Result update(YwUnitForm form) {
         YwUnit entity = baseMapper.selectById(form.getId());
-
         // 涓虹┖鎶汭llegalArgumentException锛屽仛鍏ㄥ眬寮傚父澶勭悊
         Assert.notNull(entity, "璁板綍涓嶅瓨鍦�");
         BeanUtils.copyProperties(form, entity);
+        Date now = new Date();
+        entity.setUpdateTime(now);
         if (baseMapper.updateById(entity) > 0) {
             // 淇敼杩愮淮鍗曚綅璐﹀彿淇℃伅
             SysUser sysUser = sysUserMapper.selectUserByUserName(entity.getUnitAdminAccount());
@@ -211,6 +216,63 @@
     }
 
     @Override
+    public Result workList(DistributeWorkOrderQuery query) {
+        if(query.getStart()!=null) {
+            query.setStart(DateUtils.getDayStart(query.getStart()));
+        }
+        if(query.getEnd()!=null) {
+            query.setEnd(DateUtils.getDayEnd(query.getEnd()));
+        }
+        if (query.getErrorType() != null) {
+            List<String> errorTypeList = new ArrayList<>();
+            errorTypeList.add(query.getErrorType());
+            if (ErrorType.ABNORMAL_PIC.getValue().equals(query.getErrorType())) {
+                //List娣诲姞涔嬪墠鍑犵宸ュ崟绫诲瀷
+                errorTypeList.add(ErrorType.SIGNAL_LOSS.getValue());
+                errorTypeList.add(ErrorType.SCREEN_COLOR_DEVIATION.getValue());
+                errorTypeList.add(ErrorType.SNOW_STORM.getValue());
+                errorTypeList.add(ErrorType.STRIPE_INTERFERENCE.getValue());
+                errorTypeList.add(ErrorType.SCREEN_OCCLUSION.getValue());
+                errorTypeList.add(ErrorType.ABNORMAL_CLARITY.getValue());
+            }
+            query.setErrorTypeList(errorTypeList);
+        }
+        List<YwUnit> ywUnits = baseMapper.selectList(null);
+        List<YwUnitVO> lists = ywUnits.stream().map(item -> {
+            YwUnitVO vo = new YwUnitVO();
+            BeanUtils.copyProperties(item, vo);
+            return vo;
+        }).collect(Collectors.toList());
+        for (YwUnitVO ywUnit : lists) {
+            query.setUnitId(ywUnit.getId());
+            Integer workOrderNum = baseMapper.workList(query);
+            ywUnit.setWorkOrderCount(workOrderNum);
+        }
+        return Result.ok().data(lists);
+    }
+
+    @Override
+    public void setUnitInfo(LoginUser loginUser) {
+        // 鍗曚綅绠$悊鍛樻煡璇�
+        YwUnit unit = new LambdaQueryChainWrapper<>(baseMapper)
+                .eq(YwUnit::getUnitAdminAccount, loginUser.getUsername())
+                .one();
+        if (Objects.nonNull(unit)) {
+            loginUser.setUnitAdmin(Boolean.TRUE);
+            loginUser.setUnitId(unit.getId());
+        } else {
+            unit = baseMapper.getByUserId(loginUser.getUserId());
+            if (Objects.nonNull(unit)) {
+                loginUser.setUnitAdmin(Boolean.FALSE);
+                loginUser.setUnitId(unit.getId());
+            }
+            else {
+                loginUser.setUnitAdmin(Boolean.FALSE);
+            }
+        }
+    }
+
+    @Override
     public List<YwUnitVO> export(YwUnitQuery query) {
         // 鍒嗛〉鏉′欢鏌ヨ浣�
         IPage<YwUnit> page = new LambdaQueryChainWrapper<>(baseMapper)
@@ -230,4 +292,9 @@
                 .collect(Collectors.toList());
         return vos;
     }
+
+    @Override
+    public List<Map<String, Object>> ywUnitCount() {
+        return baseMapper.ywUnitCount();
+    }
 }

--
Gitblit v1.8.0