From ba421d977e745d18a6264353c739bcaaf44c40d6 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 08 四月 2024 18:39:41 +0800
Subject: [PATCH] 历史数据模块接口

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TbDeptServiceImpl.java |   96 +++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 79 insertions(+), 17 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 d22ad84..0237113 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
@@ -6,12 +6,21 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.ruoyi.common.basic.PageDTO;
-import com.ruoyi.common.utils.CollUtils;
-import com.ruoyi.common.utils.StringUtils;
+import com.ruoyi.common.core.domain.R;
+import com.ruoyi.common.core.domain.entity.SysUser;
+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.system.domain.TbBasicData;
 import com.ruoyi.system.domain.TbDept;
+import com.ruoyi.system.dto.update.DeptFocusDTO;
 import com.ruoyi.system.handler.DeptVerifyHandler;
+import com.ruoyi.system.importExcel.DeptExcel;
 import com.ruoyi.system.mapper.TbDeptMapper;
 import com.ruoyi.system.query.DeptQuery;
+import com.ruoyi.system.service.ISysUserService;
+import com.ruoyi.system.service.TbBasicDataService;
 import com.ruoyi.system.service.TbDeptService;
 import com.ruoyi.system.vo.DeptVO;
 import lombok.RequiredArgsConstructor;
@@ -21,7 +30,11 @@
 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>
@@ -36,19 +49,24 @@
 public class TbDeptServiceImpl extends ServiceImpl<TbDeptMapper, TbDept> implements TbDeptService {
 
     private final DeptVerifyHandler deptVerifyHandler;
+    private final ISysUserService sysUserService;
+    private final TbBasicDataService tbBasicDataService;
 
     @Override
     public PageDTO<DeptVO> queryPage(DeptQuery query) {
-        Page<TbDept> page = new Page<>(query.getPageNum(), query.getPageSize());
-        Page<TbDept> tbDeptPage = this.lambdaQuery().like(StringUtils.isNotEmpty(query.getAreaName()), TbDept::getAreaName, query.getAreaName())
-                .like(StringUtils.isNotEmpty(query.getAccount()), TbDept::getAccount, query.getAccount())
-                .like(StringUtils.isNotEmpty(query.getPhone()), TbDept::getPhone, query.getPhone())
-                .orderByDesc(TbDept::getCreateTime)
+        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())
+                .orderByDesc(SysUser::getCreateTime)
                 .page(page);
-        if (CollUtils.isEmpty(tbDeptPage.getRecords())) {
+
+        if (CollUtils.isEmpty(userPage.getRecords())) {
             return PageDTO.empty(page);
         }
-        return PageDTO.of(tbDeptPage, DeptVO.class);
+        return PageDTO.of(userPage, DeptVO.class);
     }
 
     @Override
@@ -62,18 +80,23 @@
         //使用自定义校验规则
         importParams.setVerifyHandler(deptVerifyHandler);
         InputStream inputStream = file.getInputStream();
-        ExcelImportResult<TbDept> result = ExcelImportUtil.importExcelMore(inputStream, TbDept.class, importParams);
+        ExcelImportResult<DeptExcel> result = ExcelImportUtil.importExcelMore(inputStream, DeptExcel.class, importParams);
         inputStream.close();
-        List<TbDept> list = result.getList();
-        if (Objects.requireNonNull(result).isVerfiyFail() || CollectionUtils.isEmpty(list)) {
-            throw new RuntimeException("文件校验失败,请检查数据填写是否完整");
+        List<DeptExcel> list = result.getList();
+
+        if (result.isVerifyFail() || CollectionUtils.isEmpty(list)) {
+            throw new ServiceException("文件校验失败,请检查数据填写是否完整");
         }
         List<String> strings = hasDuplicateAreaCode(list);
         if (!CollectionUtils.isEmpty(strings)) {
-            throw new RuntimeException(String.format("区划代码%s重复,请修改后重新导入", String.join(",", strings)));
+            throw new ServiceException(String.format("区划代码%s重复,请修改后重新导入", String.join(",", strings)));
         }else {
+            List<TbDept> tbDeptList = BeanUtils.copyList(list, TbDept.class);
             this.remove(null);
-            this.saveBatch(list);
+            tbDeptList.forEach(dept->{
+                dept.setPassword(SecurityUtils.encryptPassword(dept.getPassword()));
+            });
+            this.saveBatch(tbDeptList);
         }
     }
 
@@ -82,14 +105,53 @@
      * @param deptList 部门列表
      * @return 重复的区划代码
      */
-    public List<String> hasDuplicateAreaCode(List<TbDept> deptList) {
+    public List<String> hasDuplicateAreaCode(List<DeptExcel> deptList) {
         Set<String> areaCodes = new HashSet<>();
         List<String> result = new ArrayList<>();
-        for (TbDept dept : deptList) {
+        for (DeptExcel dept : deptList) {
             if (!areaCodes.add(dept.getAreaCode())) {
                 result.add(dept.getAreaCode());
             }
         }
         return result;
     }
+
+    @Override
+    public void focus(DeptFocusDTO dto) {
+        Optional<SysUser> sysUser = sysUserService.lambdaQuery().eq(SysUser::getUserId, dto.getUserId()).oneOpt();
+        if (sysUser.isPresent()) {
+            sysUserService.lambdaUpdate()
+                    .eq(SysUser::getUserId, dto.getUserId())
+                    .set(SysUser::getFocussed, dto.getFocussed())
+                    .update();
+        }
+    }
+
+    @Override
+    public R<Void> reportingMessage() {
+        Map<String, Date> quarterDate = DateUtils.getQuarterDate(new Date());
+        //当前季度开始
+        Date quarterStart = quarterDate.get("first");
+        //当前季度结束
+        Date quarterEnd = quarterDate.get("last");
+        //判断当前时间是否在季度初1-15号
+        Instant instant = quarterStart.toInstant();
+        LocalDate quarterStartLocalDate = instant.atZone(ZoneId.systemDefault()).toLocalDate();
+        LocalDate fifteenDaysLimit = quarterStartLocalDate.plusDays(15);
+        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<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());
+            if (!filledDeptCodes.containsAll(deptAreaCodeList)) {
+                return R.fail("有部门未上传季度数据");
+            }
+        }
+        return R.ok();
+    }
 }

--
Gitblit v1.7.1