From d68c61517a3a6d4ec4d47844c21bdc143f99cbab Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期三, 17 四月 2024 22:58:05 +0800
Subject: [PATCH] 大屏接口

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java |   62 ++++++++++++++++++++----------
 1 files changed, 41 insertions(+), 21 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java
index 0237113..bfd29a2 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java
@@ -11,7 +11,11 @@
 import com.ruoyi.common.enums.ReportingStatusEnum;
 import com.ruoyi.common.enums.UserTypeEnum;
 import com.ruoyi.common.exception.ServiceException;
-import com.ruoyi.common.utils.*;
+import com.ruoyi.common.utils.BeanUtils;
+import com.ruoyi.common.utils.CollUtils;
+import com.ruoyi.common.utils.DateUtils;
+import com.ruoyi.common.utils.SecurityUtils;
+import com.ruoyi.common.utils.StringUtils;
 import com.ruoyi.system.domain.TbBasicData;
 import com.ruoyi.system.domain.TbDept;
 import com.ruoyi.system.dto.update.DeptFocusDTO;
@@ -23,18 +27,23 @@
 import com.ruoyi.system.service.TbBasicDataService;
 import com.ruoyi.system.service.TbDeptService;
 import com.ruoyi.system.vo.DeptVO;
+import java.io.InputStream;
+import java.time.Instant;
+import java.time.LocalDate;
+import java.time.ZoneId;
+import java.util.ArrayList;
+import java.util.Date;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Map;
+import java.util.Optional;
+import java.util.Set;
+import java.util.stream.Collectors;
 import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.util.CollectionUtils;
 import org.springframework.web.multipart.MultipartFile;
-
-import java.io.InputStream;
-import java.time.Instant;
-import java.time.LocalDate;
-import java.time.ZoneId;
-import java.util.*;
-import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -57,9 +66,12 @@
         Page<SysUser> page = new Page<>(query.getPageNum(), query.getPageSize());
         Page<SysUser> userPage = sysUserService.lambdaQuery()
                 .eq(SysUser::getUserType, UserTypeEnum.DEPARTMENT.getCode())
-                .like(StringUtils.isNotEmpty(query.getAreaName()), SysUser::getAreaName, query.getAreaName())
-                .like(StringUtils.isNotEmpty(query.getUserName()), SysUser::getUserName, query.getUserName())
-                .like(StringUtils.isNotEmpty(query.getPhone()), SysUser::getPhoneNumber, query.getPhone())
+                .like(StringUtils.isNotEmpty(query.getAreaName()), SysUser::getAreaName,
+                        query.getAreaName())
+                .like(StringUtils.isNotEmpty(query.getUserName()), SysUser::getUserName,
+                        query.getUserName())
+                .like(StringUtils.isNotEmpty(query.getPhone()), SysUser::getPhoneNumber,
+                        query.getPhone())
                 .orderByDesc(SysUser::getCreateTime)
                 .page(page);
 
@@ -80,7 +92,8 @@
         //使用自定义校验规则
         importParams.setVerifyHandler(deptVerifyHandler);
         InputStream inputStream = file.getInputStream();
-        ExcelImportResult<DeptExcel> result = ExcelImportUtil.importExcelMore(inputStream, DeptExcel.class, importParams);
+        ExcelImportResult<DeptExcel> result = ExcelImportUtil.importExcelMore(inputStream,
+                DeptExcel.class, importParams);
         inputStream.close();
         List<DeptExcel> list = result.getList();
 
@@ -89,11 +102,12 @@
         }
         List<String> strings = hasDuplicateAreaCode(list);
         if (!CollectionUtils.isEmpty(strings)) {
-            throw new ServiceException(String.format("区划代码%s重复,请修改后重新导入", String.join(",", strings)));
-        }else {
+            throw new ServiceException(
+                    String.format("区划代码%s重复,请修改后重新导入", String.join(",", strings)));
+        } else {
             List<TbDept> tbDeptList = BeanUtils.copyList(list, TbDept.class);
             this.remove(null);
-            tbDeptList.forEach(dept->{
+            tbDeptList.forEach(dept -> {
                 dept.setPassword(SecurityUtils.encryptPassword(dept.getPassword()));
             });
             this.saveBatch(tbDeptList);
@@ -102,6 +116,7 @@
 
     /**
      * 校验区划代码是否重复
+     *
      * @param deptList 部门列表
      * @return 重复的区划代码
      */
@@ -118,7 +133,8 @@
 
     @Override
     public void focus(DeptFocusDTO dto) {
-        Optional<SysUser> sysUser = sysUserService.lambdaQuery().eq(SysUser::getUserId, dto.getUserId()).oneOpt();
+        Optional<SysUser> sysUser = sysUserService.lambdaQuery()
+                .eq(SysUser::getUserId, dto.getUserId()).oneOpt();
         if (sysUser.isPresent()) {
             sysUserService.lambdaUpdate()
                     .eq(SysUser::getUserId, dto.getUserId())
@@ -137,17 +153,21 @@
         //判断当前时间是否在季度初1-15号
         Instant instant = quarterStart.toInstant();
         LocalDate quarterStartLocalDate = instant.atZone(ZoneId.systemDefault()).toLocalDate();
-        LocalDate fifteenDaysLimit = quarterStartLocalDate.plusDays(15);
+        LocalDate fifteenDaysLimit = quarterStartLocalDate.plusDays(14);
         LocalDate now = LocalDate.now();
         //如果当前时间不在规定范围内:季度初1-15号
         if (now.isAfter(quarterStartLocalDate) || now.isBefore(fifteenDaysLimit)) {
             //查询所有的部门
-            List<SysUser> list = sysUserService.lambdaQuery().eq(SysUser::getUserType, UserTypeEnum.DEPARTMENT.getCode()).list();
-            Set<String> deptAreaCodeList = list.stream().map(SysUser::getAreaCode).collect(Collectors.toSet());
+            List<SysUser> list = sysUserService.lambdaQuery()
+                    .eq(SysUser::getUserType, UserTypeEnum.DEPARTMENT.getCode()).list();
+            Set<String> deptAreaCodeList = list.stream().map(SysUser::getAreaCode)
+                    .collect(Collectors.toSet());
             //查询当前季度填报了数据的部门
-            List<TbBasicData> filledBasicData = tbBasicDataService.lambdaQuery().between(TbBasicData::getCreateTime, quarterStartLocalDate, fifteenDaysLimit)
+            List<TbBasicData> filledBasicData = tbBasicDataService.lambdaQuery()
+                    .between(TbBasicData::getCreateTime, quarterStartLocalDate, fifteenDaysLimit)
                     .eq(TbBasicData::getStatus, ReportingStatusEnum.FILLED).list();
-            Set<String> filledDeptCodes = filledBasicData.stream().map(TbBasicData::getDeptAreaCode).collect(Collectors.toSet());
+            Set<String> filledDeptCodes = filledBasicData.stream().map(TbBasicData::getDeptAreaCode)
+                    .collect(Collectors.toSet());
             if (!filledDeptCodes.containsAll(deptAreaCodeList)) {
                 return R.fail("有部门未上传季度数据");
             }

--
Gitblit v1.7.1