From 02bc3bfe47e3d5311a0bb041c94e70a34b1ca73c Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期二, 09 四月 2024 09:03:01 +0800
Subject: [PATCH] git ch

---
 server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java |  137 +++++++++++++++++++++++++++++++++++++++------
 1 files changed, 118 insertions(+), 19 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
index 83bb114..1bda1ec 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
@@ -10,9 +10,11 @@
 import com.doumee.core.utils.DateUtil;
 import com.doumee.core.utils.Utils;
 import com.doumee.dao.business.MemberMapper;
+import com.doumee.dao.business.WorktypeMapper;
 import com.doumee.dao.business.dto.MemberImport;
 import com.doumee.dao.business.dto.MemberQueryDTO;
 import com.doumee.dao.business.dto.WorktypeImport;
+import com.doumee.dao.business.join.DispatchUnitJoinMapper;
 import com.doumee.dao.business.join.MemberJoinMapper;
 import com.doumee.dao.business.model.*;
 import com.doumee.service.business.MemberService;
@@ -29,10 +31,8 @@
 import org.springframework.stereotype.Service;
 import org.springframework.web.multipart.MultipartFile;
 
-import java.util.ArrayList;
-import java.util.Date;
-import java.util.List;
-import java.util.Objects;
+import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 鐢ㄥ伐淇℃伅琛⊿ervice瀹炵幇
@@ -47,6 +47,12 @@
 
     @Autowired
     private MemberJoinMapper memberJoinMapper;
+
+    @Autowired
+    private DispatchUnitJoinMapper dispatchUnitJoinMapper;
+
+    @Autowired
+    private WorktypeMapper worktypeMapper;
 
     @Override
     public Integer create(Member member) {
@@ -95,6 +101,29 @@
     public Member findById(Integer id) {
         return memberMapper.selectById(id);
     }
+
+    @Override
+    public Member findDetailById(Integer id) {
+        MPJLambdaWrapper<Member> queryWrapper = new MPJLambdaWrapper<>();
+        queryWrapper.selectAll(Member.class)
+                .selectAs(DispatchUnit::getName,Member::getDuName)
+                .selectAs(Worktype::getName,Member::getWorkTypeName)
+                .selectAs(Solutions::getName,Member::getSolutionName)
+                .selectAs(Company::getName,Member::getCompanyName)
+                .select(" case when  now() between t.start_time and t.end_time then 1  else 2 end solutionsStatus ")
+                .leftJoin(InsuranceApply.class,InsuranceApply::getId,Member::getApplyId)
+                .leftJoin(Solutions.class,Solutions::getId,InsuranceApply::getSolutionId)
+                .leftJoin(DispatchUnit.class,DispatchUnit::getId,Member::getDuId)
+                .leftJoin(Worktype.class,Worktype::getId,Member::getWorktypeId)
+                .leftJoin(Company.class,Company::getId,Member::getCompanyId)
+                .eq(Member::getId,id)
+                .eq(Member::getIsdeleted, Constants.ZERO)
+                .last(" limit 1 ")
+        ;
+        return memberJoinMapper.selectJoinOne(Member.class,queryWrapper);
+    }
+
+
 
     @Override
     public Member findOne(Member member) {
@@ -201,13 +230,17 @@
                 .leftJoin(DispatchUnit.class,DispatchUnit::getId,Member::getDuId)
                 .leftJoin(Worktype.class,Worktype::getId,Member::getWorktypeId)
                 .leftJoin(Company.class,Company::getId,Member::getCompanyId)
+                .and(StringUtils.isNotBlank(memberQueryDTO.getKeywords()),
+                        i->i.like(Member::getName, memberQueryDTO.getKeywords()).or().like(
+                                Member::getIdcardNo,memberQueryDTO.getKeywords()
+                        ))
                 .eq(Member::getIsdeleted, Constants.ZERO)
 //                .eq(Member::getCompanyId, memberQueryDTO.getCompanyId())
                 .like(StringUtils.isNotBlank(memberQueryDTO.getName()),Member::getName, memberQueryDTO.getName())
                 .like(StringUtils.isNotBlank(memberQueryDTO.getIdCard()),Member::getIdcardNo, memberQueryDTO.getIdCard())
                 .like(StringUtils.isNotBlank(memberQueryDTO.getDuName()),DispatchUnit::getName, memberQueryDTO.getDuName())
                 .eq(!Objects.isNull(memberQueryDTO.getDuId()),Member::getDuId, memberQueryDTO.getDuId())
-                .eq(!Objects.isNull(memberQueryDTO.getSolutionsId()),Solutions::getId, memberQueryDTO.getSolutionsId())
+                .eq(!Objects.isNull(memberQueryDTO.getSolutionsId()),Solutions::getBaseId, memberQueryDTO.getSolutionsId())
                 .apply(!Objects.isNull(memberQueryDTO.getSolutionsStatus())&&memberQueryDTO.getSolutionsStatus().equals(Constants.ONE),"now() between t.start_time and t.end_time")
                 .apply(!Objects.isNull(memberQueryDTO.getSolutionsStatus())&&memberQueryDTO.getSolutionsStatus().equals(Constants.TWO),"now()  >  t.end_time")
         ;
@@ -221,6 +254,15 @@
 //            }
 //        }
         PageData<Member> pageData = PageData.from(memberJoinMapper.selectJoinPage(page,Member.class, queryWrapper));
+
+        Integer sn = 0;
+        for (Member member:pageData.getRecords()) {
+            sn = sn + 1;
+            member.setSn(sn);
+            if(StringUtils.isNotBlank(member.getIdcardNo())){
+                member.setAge(Constants.getAgeByIdCard(member.getIdcardNo()));
+            }
+        }
         return pageData;
     }
 
@@ -248,9 +290,10 @@
                 .apply(!Objects.isNull(memberQueryDTO.getSolutionsStatus())&&memberQueryDTO.getSolutionsStatus().equals(Constants.ONE),"now() between t.start_time and t.end_time")
                 .apply(!Objects.isNull(memberQueryDTO.getSolutionsStatus())&&memberQueryDTO.getSolutionsStatus().equals(Constants.TWO),"now()  >  t.end_time")
                 .like(StringUtils.isNotBlank(memberQueryDTO.getName()),Member::getName, memberQueryDTO.getName())
-                .notExists(!Objects.isNull(memberQueryDTO.getNotInInsuranceApplyId()),
-                        " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getNotInInsuranceApplyId()+" and ad.END_TIME > now() and ad.isdeleted = 0 " +
-                                " and ad.member_id = t.id ");
+                .notExists(!Objects.isNull(memberQueryDTO.getNotInInsuranceApplyId())&&!Objects.isNull(memberQueryDTO.getValidTime()),
+                        " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getNotInInsuranceApplyId()+"" +
+                                " and ad.END_TIME >= '"+DateUtil.DateToStr(memberQueryDTO.getValidTime(),"yyyy-MM-dd HH:mm:ss.SSS")+"' and ad.START_TIME <= '"+DateUtil.DateToStr(memberQueryDTO.getValidTime(),"yyyy-MM-dd HH:mm:ss.SSS")+"' and ad.isdeleted = 0 " +
+                                " and ad.member_id = t.id ") ;
         if(!Objects.isNull(memberQueryDTO.getInsuranceApplyId())){
             lambdaWrapper = new MPJLambdaWrapper<Member>()
                     .selectAll(Member.class)
@@ -263,20 +306,20 @@
                     .leftJoin(Worktype.class,Worktype::getId,ApplyDetail::getWorktypeId)
                     .eq(Member::getIsdeleted, Constants.ZERO)
                     .eq(InsuranceApply::getId,memberQueryDTO.getInsuranceApplyId())
+                    .like(StringUtils.isNotBlank(memberQueryDTO.getName()),Member::getName, memberQueryDTO.getName())
                     .le(!Objects.isNull(memberQueryDTO.getValidTime()),ApplyDetail::getStartTime,memberQueryDTO.getValidTime())
                     .ge(!Objects.isNull(memberQueryDTO.getValidTime()),ApplyDetail::getEndTime,memberQueryDTO.getValidTime())
-                    .exists(!Objects.isNull(memberQueryDTO.getInsuranceApplyId()),
-                            " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getInsuranceApplyId()+" and ad.END_TIME > now() and ad.isdeleted = 0 " +
+                    .exists(!Objects.isNull(memberQueryDTO.getInsuranceApplyId())&&!Objects.isNull(memberQueryDTO.getValidTime()),
+                            " select 1 from apply_detail ad where ad.apply_id = "+memberQueryDTO.getInsuranceApplyId()+"" +
+                                    " and ad.END_TIME >= '"+DateUtil.DateToStr(memberQueryDTO.getValidTime(),"yyyy-MM-dd HH:mm:ss.SSS")+"' and ad.START_TIME <= '"+DateUtil.DateToStr(memberQueryDTO.getValidTime(),"yyyy-MM-dd HH:mm:ss.SSS")+"' and ad.isdeleted = 0 " +
                                     " and ad.member_id = t.id ");
         }
         List<Member> memberList = memberJoinMapper.selectJoinList(Member.class,lambdaWrapper);
         return memberList;
     }
 
-
-
     @Override
-    public List<MemberImport> importBatch(MultipartFile file){
+    public List<MemberImport> importBatch(MultipartFile file,Integer  solutionId){
         LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
         if(!loginUserInfo.getType().equals(Constants.ONE)){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"闈炰紒涓氫汉鍛樻棤娉曡繘琛岃鎿嶄綔");
@@ -287,6 +330,7 @@
                 .selectAs(Worktype::getName,Member::getWorkTypeName)
                 .leftJoin(DispatchUnit.class,DispatchUnit::getId,Member::getDuId)
                 .leftJoin(Worktype.class,Worktype::getId,Member::getWorktypeId)
+                .isNotNull(Member::getIdcardNo)
                 .eq(Member::getCompanyId,loginUserInfo.getCompanyId())
                 .eq(Member::getIsdeleted,Constants.ZERO)
         );
@@ -301,15 +345,50 @@
         if(dataList == null || dataList.size() ==0){
             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝褰曞叆鏁版嵁涓虹┖锛�");
         }
+        List<String> idCardList = dataList.stream().map(m->m.getIdCard()).collect(Collectors.toList());
+        Set<String> set = new HashSet<>(idCardList);
+        if(idCardList.size() != set.size()){
+            throw new BusinessException(ResponseStatus.DATA_ERRO.getCode(),"瀵逛笉璧凤紝褰曞叆鏁版嵁瀛樺湪韬唤璇佸彿鐩稿悓鏁版嵁锛�");
+        }
+        List<DispatchUnit> dispatchUnitList = new ArrayList<>();
+        if(!Objects.isNull(solutionId)){
+            dispatchUnitList  = dispatchUnitJoinMapper.selectJoinList(DispatchUnit.class,
+                    new MPJLambdaWrapper<DispatchUnit>()
+                            .selectAll(DispatchUnit.class)
+                            .select("(select b.id from du_solution b where b.isdeleted=0 and b.dispatch_unit_id=t.id and b.solution_id="+solutionId+" limit 1) as du_solution_id" )
+                            .eq(DispatchUnit::getIsdeleted,Constants.ZERO)
+                            .eq(DispatchUnit::getStatus,Constants.ZERO)
+                            .eq(DispatchUnit::getDataType,Constants.TWO)
+                            .eq(loginUserInfo.getType().equals(Constants.ONE),DispatchUnit::getCompanyId,loginUserInfo.getCompanyId())
+                            .exists("select b.id from du_solution b where b.isdeleted=0 and b.dispatch_unit_id=t.id and b.status = 1 and  b.solution_id="+solutionId )
+            );
+            if(CollectionUtils.isNotEmpty(dispatchUnitList)){
+                for (DispatchUnit dispatchUnit:dispatchUnitList) {
+                    List<Worktype> worktypeList = worktypeMapper.selectList(new QueryWrapper<Worktype>().lambda()
+                            .eq(Worktype::getIsdeleted,Constants.ZERO)
+                            .eq(Worktype::getDataType,Constants.TWO)
+                            .eq(Worktype::getStatus,Constants.ZERO)
+                            .apply("id in ( select  dw.work_type_id from du_worktype dw where dw.status = 1" +
+                                    " and  dw.du_solution_id = "+dispatchUnit.getDuSolutionId()+" )")
+                    );
+                    dispatchUnit.setWorktypeList(worktypeList);
+                }
+            }
+        }
+        long index = Constants.TWO;
         for(MemberImport model : dataList){
+            if(StringUtils.isBlank(model.getIdCard())||model.getIdCard().length()!=18){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绗�"+index+"琛屾暟鎹韩浠借瘉淇℃伅寮傚父锛�");
+            }
+            if(StringUtils.isBlank(model.getName())){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绗�"+index+"琛屾暟鎹鍚嶄俊鎭紓甯革紒");
+            }
+            index = index + Constants.ONE;
             if(CollectionUtils.isNotEmpty(list)){
-                Member member = list.stream().filter(m->m.getIdcardNo().equals(model.getIdCard())).findAny().get();
-                if(!Objects.isNull(member)){
-//                    model.setWorkTypeId(member.getWorktypeId());
-//                    model.setWorkTypeName(member.getWorkTypeName());
+                Optional<Member>  memberOptional= list.stream().filter(m->m.getIdcardNo().equals(model.getIdCard())).findFirst();
+                if(memberOptional.isPresent()){
+                    Member member =  memberOptional.get();
                     model.setIdCard(member.getIdcardNo());
-//                    model.setDuId(member.getDuId());
-//                    model.setDuName(member.getDuName());
                     model.setSex(member.getSex());
                 }else{
                     model.setSex(Constants.getSexByIdCard(model.getIdCard()));
@@ -317,6 +396,26 @@
             }else{
                 model.setSex(Constants.getSexByIdCard(model.getIdCard()));
             }
+            if(StringUtils.isNotBlank(model.getDuName())&&CollectionUtils.isNotEmpty(dispatchUnitList)){
+                Optional<DispatchUnit>  dispatchUnitOptional= dispatchUnitList.stream().filter(m->m.getName().equals(model.getDuName())).findFirst();
+                if(dispatchUnitOptional.isPresent()){
+                    DispatchUnit dispatchUnit =  dispatchUnitOptional.get();
+                    model.setDuId(dispatchUnit.getId());
+                    if(StringUtils.isNotBlank(model.getWorkTypeName())&&CollectionUtils.isNotEmpty(dispatchUnit.getWorktypeList())){
+                        Optional<Worktype>  worktypeOptional= dispatchUnit.getWorktypeList().stream().filter(m->m.getName().equals(model.getWorkTypeName())).findFirst();
+                        if(worktypeOptional.isPresent()){
+                            Worktype worktype = worktypeOptional.get();
+                            model.setWorktypeId(worktype.getId());
+                        }
+                    }
+                }
+            }
+            if(Objects.isNull(model.getDuId())){
+                model.setWorkTypeName(null);
+                model.setDuName(null);
+            }else if(Objects.isNull(model.getWorktypeId())){
+                model.setWorkTypeName(null);
+            }
         }
         return dataList;
     }

--
Gitblit v1.9.3