From 22271e641e4505ba906c3770905b7e84e3ad8d85 Mon Sep 17 00:00:00 2001
From: MrShi <1878285526@qq.com>
Date: 星期二, 02 四月 2024 17:05:57 +0800
Subject: [PATCH] mrshi

---
 server/service/src/main/java/com/doumee/service/business/impl/NoticesServiceImpl.java |   78 ++++++++++++++++++++++++++++++++++++++
 1 files changed, 77 insertions(+), 1 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/NoticesServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/NoticesServiceImpl.java
index 23965eb..3607ba6 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/NoticesServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/NoticesServiceImpl.java
@@ -1,5 +1,6 @@
 package com.doumee.service.business.impl;
 
+import com.doumee.core.model.LoginUserInfo;
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Constants;
@@ -10,6 +11,7 @@
 import com.doumee.dao.business.model.Company;
 import com.doumee.dao.business.model.InsuranceApply;
 import com.doumee.dao.business.model.Notices;
+import com.doumee.dao.business.vo.ApplyNoticeVO;
 import com.doumee.service.business.NoticesService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
@@ -17,9 +19,11 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.github.xiaoymin.knife4j.core.util.CollectionUtils;
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
+import org.apache.shiro.SecurityUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import java.util.List;
+import java.util.stream.Collectors;
 
 /**
  * 绯荤粺娑堟伅淇℃伅琛⊿ervice瀹炵幇
@@ -94,6 +98,19 @@
         IPage<Notices> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
         MPJLambdaWrapper<Notices> queryWrapper = new MPJLambdaWrapper<>();
         Utils.MP.blankToNull(pageWrap.getModel());
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+
+        //浼佷笟浜哄憳鏌ョ湅鏈紒涓氭暟鎹�
+        if(loginUserInfo.getType().equals(Constants.ONE)){
+            queryWrapper.eq(Notices::getCompanyId, loginUserInfo.getCompanyId());
+        }else{
+            if(loginUserInfo.getCompanyIdList()!=null && loginUserInfo.getCompanyIdList().size()>0){
+                queryWrapper.in(Notices::getCompanyId, loginUserInfo.getCompanyIdList());
+            }else{
+                queryWrapper.eq(Notices::getCompanyId, -1);
+            }
+        }
+
         queryWrapper.selectAll(Notices.class);
         queryWrapper.selectAs(Company::getName,Notices::getCompanyName);
         queryWrapper.leftJoin(Company.class,Company::getId,Notices::getCompanyId);
@@ -118,6 +135,19 @@
         if (pageWrap.getModel().getReaded() != null) {
             queryWrapper.eq(Notices::getReaded, pageWrap.getModel().getReaded());
         }
+        if(pageWrap.getModel().getQueryType()!=null){
+            if(pageWrap.getModel().getQueryType().equals(Constants.ZERO)){
+                queryWrapper.in(Notices::getObjType,new Integer[]{Constants.NoticeObjectType.INSURANCE_APPLY.getKey(),
+                        Constants.NoticeObjectType.APPLY_CHANGE.getKey(),
+                        Constants.NoticeObjectType.DISPATCH_UNIT.getKey(),
+                        Constants.NoticeObjectType.CHANGE_FACTORY.getKey()});
+            } else if(pageWrap.getModel().getQueryType().equals(Constants.ONE)){
+                queryWrapper.in(Notices::getObjType,new Integer[]{Constants.NoticeObjectType.TAXES.getKey() });
+            } else if(pageWrap.getModel().getQueryType().equals(Constants.TWO)){
+                queryWrapper.in(Notices::getObjType,new Integer[]{Constants.NoticeObjectType.SETTLE_CLAIMS.getKey() });
+
+            }
+        }
         if(CollectionUtils.isNotEmpty(pageWrap.getSorts())){
             for(PageWrap.SortData sortData: pageWrap.getSorts()) {
                 if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
@@ -133,7 +163,7 @@
         PageData<Notices> pageData = PageData.from(noticesMapper.selectJoinPage(page,Notices.class, queryWrapper));
         pageData.getRecords().forEach(i->{
             i.setTypeDetail(
-                    Constants.NoticeType.getDetail(i.getObjType(),i.getType())
+                    Constants.NoticeType.getDetail(i.getType(),i.getObjType())
             );
         });
         return pageData;
@@ -144,4 +174,50 @@
         QueryWrapper<Notices> wrapper = new QueryWrapper<>(notices);
         return noticesMapper.selectCount(wrapper);
     }
+
+
+    /**
+     * 鏌ヨ鎶曚繚鍗� 鎻愰啋鏁伴噺
+     * @param companyId
+     * @return
+     */
+    @Override
+    public ApplyNoticeVO getApplyNotice(Integer companyId){
+        ApplyNoticeVO applyNoticeVO = new ApplyNoticeVO();
+        applyNoticeVO.setWaitSignNum(Constants.ZERO);
+        applyNoticeVO.setRenewalNum(Constants.ZERO);
+        List<Notices> noticesList = noticesMapper.selectList(new QueryWrapper<Notices>()
+                .lambda()
+                .select(Notices::getType)
+                .eq(Notices::getPalt,Constants.ONE)
+                .eq(Notices::getCompanyId,companyId)
+                .eq(Notices::getObjType,Constants.NoticeObjectType.INSURANCE_APPLY.getKey())
+                .eq(Notices::getStatus,Constants.ZERO)
+                .in(Notices::getType,Constants.NoticeType.SIX.getStatus(),Constants.NoticeType.ONE.getStatus())
+        );
+        if(CollectionUtils.isNotEmpty(noticesList)){
+            applyNoticeVO.setRenewalNum(noticesList.stream().filter(m->m.getType().equals(Constants.NoticeType.SIX.getStatus())).collect(Collectors.toList()).size());
+            applyNoticeVO.setWaitSignNum(noticesList.size() - applyNoticeVO.getRenewalNum());
+        }
+        return applyNoticeVO ;
+    }
+
+    /**
+     * 鍏抽棴鎻愰啋
+     * @param companyId
+     * @param type
+     */
+    @Override
+    public void closeApplyNotice(Integer companyId,Integer type){
+        noticesMapper.update(null,new UpdateWrapper<Notices>()
+                .lambda()
+                .set(Notices::getStatus,Constants.ONE)
+                .eq(Notices::getPalt,Constants.ONE)
+                .eq(Notices::getCompanyId,companyId)
+                .eq(Notices::getStatus,Constants.ZERO)
+                .eq(Notices::getObjType,Constants.NoticeObjectType.INSURANCE_APPLY.getKey())
+                .eq(Notices::getType,type)
+        );
+    }
+
 }

--
Gitblit v1.9.3