From 6b7647fedbc68e37d7478474bff1817385505967 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期五, 19 七月 2024 14:25:33 +0800
Subject: [PATCH] 代码初始化
---
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java |  235 ++++++++++++++++++++++++++++++++++++++++------------------
 1 files changed, 160 insertions(+), 75 deletions(-)
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
index 384cdcc..1af24c0 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
@@ -375,10 +375,9 @@
 
         //澶勭悊鎶勯�佹暟鎹�
         if(CollectionUtils.isNotEmpty(approveCopyList)){
-            this.organizeApproveCopyData(approveTempl,approveParamList,businessId,approveList);
+            this.organizeApproveCopyData(approveTempl,approveCopyList,businessId,approveList);
         }
         approveJoinMapper.insert(approveList);
-//        approveJoinMapper.insert(approveList);
 
     }
 
@@ -414,15 +413,21 @@
         createUserApprove.setType(Constants.ZERO);
         approveList.add(createUserApprove);
 
+        //鏌ヨ鎵�鏈夊緟澶勭悊浜�
+
         //瀹℃壒涓氬姟鏁版嵁
         for (int i = 0; i < approveParamList.size(); i++) {
             ApproveParam approveParam = approveParamList.get(i);
             List<Integer> ids = this.getApproveUserIds(approveParam,createMember);
+            List<Member> memberList = memberMapper.selectList(new QueryWrapper<Member>().lambda().in(Member::getId,ids));
+            List<String> memberNameList =memberList.stream().map(m->m.getName()).collect(Collectors.toList());
+            String memberNames = String.join(",",memberNameList);
             Integer noticeType = Constants.approveTypeToNoticeType(approveTempl.getType());
             String title = "銆愯瀹㈢敵璇枫�戠敵璇蜂汉 - ";
             Map<String,Object> jsonMap = new HashMap<>();
-            for (int j = 0; j < ids.size(); j++) {
-                Integer memberId = ids.get(j);
+            for (int j = 0; j < memberList.size(); j++) {
+                Member member = memberList.get(j);
+                Integer memberId = member.getId();
                 //鐢熸垚寰呭姙 notices 琛ㄦ暟鎹�
                 if(i==0){
                     if(jsonMap.isEmpty()){
@@ -446,6 +451,9 @@
                         notices.setInfo("澶勭悊涓�");
                         noticesJoinMapper.insert(notices);
                     }
+                    if(CollectionUtils.isEmpty(memberList)){
+                        throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏈煡璇㈠埌瀹℃壒浜轰俊鎭�");
+                    }
                     Notices notices = new Notices();
                     notices.setCreateDate(new Date());
                     notices.setIsdeleted(Constants.ZERO);
@@ -461,7 +469,13 @@
                     notices.setSendacopy(Constants.ZERO);
                     notices.setParam2("0");
                     notices.setParam3("");
-                    notices.setInfo("寰呭鐞�");
+                    notices.setParam5(memberNames);
+                    notices.setRemark(member.getName());
+                    if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){
+                        notices.setInfo("寰�"+memberNameList.get(0)+"澶勭悊涓�");
+                    }else{
+                        notices.setInfo("寰�"+memberNameList.get(0)+"绛�"+memberList.size()+"浜哄鐞嗕腑");
+                    }
                     noticesJoinMapper.insert(notices);
                 }
                 Approve approve = new Approve();
@@ -575,6 +589,7 @@
                     approve.setIsdeleted(Constants.ZERO);
                     approve.setTemplatId(approveTempl.getId());
                     approve.setChekorId(memberId);
+                    approve.setObjType(approveTempl.getType());
                     approve.setObjId(businessId);
                     approve.setType(Constants.ONE);
                     approveList.add(approve);
@@ -608,7 +623,7 @@
             if(Objects.isNull(memberCompany)){
                 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬鏈煡璇㈠埌]");
             }
-            Company auditCompany = this.getAuditCompanyHead(memberCompany.getParentId(),approveParam.getObjLevel());
+            Company auditCompany = this.getAuditCompanyHead(memberCompany.getId(),approveParam.getObjLevel());
             if(Objects.isNull(auditCompany)){
                 //瀹℃壒閮ㄩ棬涓虹┖ 鑷姩娴佽浆涓嬩竴绾у鎵归厤缃�
                 throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬鏈煡璇㈠埌]");
@@ -617,7 +632,7 @@
                 Member headMember = memberMapper.selectById(auditCompany.getHeadId());
                 if(Objects.isNull(headMember)){
                     //鏈煡璇㈠埌閮ㄩ棬璐熻矗浜�  鏍规嵁閰嶇疆澶勭悊   鐢变笂绾т富绠′唬鏇垮鏍�/鐩存帴缁撴潫娴佺▼
-                    if(approveParam.getNoleaderOpt().equals(Constants.ONE)&&!Objects.isNull(auditCompany.getParentId())){
+                    if(Constants.equalsInteger(approveParam.getNoleaderOpt(),Constants.ONE)&&Objects.nonNull(auditCompany.getParentId())){
                         auditCompany = companyMapper.selectOne(new QueryWrapper<Company>().lambda().eq(Company::getId,auditCompany.getParentId()));
                         //鏃犵埗绾� 鐩存帴娴佷紶涓嬩竴绾у鎵�
                         if(Objects.isNull(auditCompany)){
@@ -632,9 +647,11 @@
                             userIds.add(headMember.getId());
                         }
                     }else{
-                        //娣诲姞瀹℃壒浜�
-                        userIds.add(headMember.getId());
+                        throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴侀厤缃敊璇痆鎸囧畾瀹℃壒閮ㄩ棬涓荤鏈煡璇㈠埌]");
                     }
+                }else{
+                    //娣诲姞瀹℃壒浜�
+                    userIds.add(headMember.getId());
                 }
             }
         }
@@ -649,9 +666,9 @@
      * @param objLevel  鏌ヨ绾у埆
      */
     public Company getAuditCompanyHead(Integer companyId, Integer objLevel){
-        Integer queryLevel = Constants.ZERO;
         Company auditCompany =  companyMapper.selectById(companyId);
-        while(queryLevel.equals(objLevel)){
+        Integer queryLevel = Constants.ONE;
+        while(queryLevel<objLevel){
             auditCompany = companyMapper.selectById(auditCompany.getParentId());
             if(Objects.isNull(auditCompany)){
                 return null;
@@ -680,6 +697,8 @@
                         .eq(Approve::getObjId,businessId)
                         .eq(Approve::getObjType,businessType)
                         .orderByAsc(Approve::getLevel)
+                        .orderByAsc(Approve::getStatus)
+
         );
 
         //鏌ユ壘鍏ㄩ儴levelList
@@ -697,6 +716,7 @@
         if (CollectionUtils.isNotEmpty(copyList)) {
             Approve waitModel = new Approve();
             waitModel.setApproveType(Constants.ONE);
+            waitModel.setCheckDate(copyList.get(Constants.ZERO).getCheckDate());
             waitModel.setTitle("鎶勯�佷汉");
             waitModel.setStatus(copyList.get(Constants.ZERO).getStatus());
             waitModel.setType(Constants.ONE);
@@ -1006,6 +1026,7 @@
                 .eq(Notices::getUserId,approve.getChekorId())
                 .eq(Notices::getSendacopy,Constants.ZERO)
                 .eq(Notices::getIsdeleted,Constants.ZERO)
+                .eq(Notices::getStatus,Constants.ZERO)
                 .last(" limit 1 ")
         );
         if(Objects.isNull(notices)){
@@ -1057,29 +1078,29 @@
                     .eq(Approve::getObjType,approve.getObjType())
                     .ne(Approve::getId,approve.getId()));
             //澶勭悊鎵�鏈塏otice閫氱煡涓哄凡澶勭悊
-            if(approve.getApproveType().equals(Constants.ZERO)){
-                //淇敼鑷繁鐨勯�氱煡璁板綍
+            //淇敼鑷繁鐨勯�氱煡璁板綍
+            noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
+                    .set(Notices::getEditDate,new Date())
+                    .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId())
+                    .set(Notices::getInfo,"瀹℃壒鏈�氳繃")
+                    .set(Notices::getReaded,Constants.ONE)
+                    .set(Notices::getParam2,Constants.TWO)
+                    .set(Notices::getStatus,Constants.ONE)
+                    .eq(Notices::getId,notices.getId())
+            );
+            //淇敼 鏈鐞嗙殑 閫氱煡鏁版嵁 涓烘妱閫�
+            if (!Constants.equalsInteger(approve.getApproveType(),Constants.TWO)){
                 noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
                         .set(Notices::getEditDate,new Date())
-                        .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId())
-                        .set(Notices::getReaded,Constants.ONE)
-                        .set(Notices::getParam2,Constants.TWO)
+                        .set(Notices::getSendacopy,Constants.ONE)
                         .set(Notices::getStatus,Constants.ONE)
-                        .eq(Notices::getId,notices.getId())
+                        .set(Notices::getParam2,Constants.TWO)
+                        .set(Notices::getInfo,"瀹℃壒鏈�氳繃")
+                        .eq(Notices::getObjId,notices.getObjId())
+                        .eq(Notices::getObjType,notices.getObjType())
+                        .eq(Notices::getReaded,Constants.ZERO)
+                        .ne(Notices::getId,notices.getId())
                 );
-                //淇敼 鏈鐞嗙殑 閫氱煡鏁版嵁 涓烘妱閫�
-                if (!Constants.equalsInteger(approve.getApproveType(),Constants.TWO)){
-                    noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
-                            .set(Notices::getEditDate,new Date())
-                            .set(Notices::getSendacopy,Constants.ONE)
-                            .set(Notices::getStatus,Constants.ONE)
-                            .set(Notices::getParam2,Constants.TWO)
-                            .eq(Notices::getObjId,notices.getObjId())
-                            .eq(Notices::getObjType,notices.getObjType())
-                            .eq(Notices::getReaded,Constants.ZERO)
-                            .ne(Notices::getId,notices.getId())
-                    );
-                }
             }
         }else{
             //澶勭悊鍏朵粬涓氬姟鏁版嵁
@@ -1116,7 +1137,20 @@
                         .eq(Approve::getObjType,approve.getObjType())
                         .eq(Approve::getLevel,(approve.getLevel()+1))
                 );
-                if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals(
+                if(approveDTO.getObjType().equals(Constants.approveObjectType.unConstructionVisit)
+                        ||approveDTO.getObjType().equals(Constants.approveObjectType.constructionVisit)
+                        ||approveDTO.getObjType().equals(Constants.approveObjectType.visitReporting)) {
+                    Visits visits = visitsMapper.selectById(approve.getObjId());
+                    if(Objects.nonNull(visits)){
+                        if(Constants.equalsInteger(visits.getStatus(),Constants.ZERO)){
+                             visitsMapper.update(null,new UpdateWrapper<Visits>().lambda().set(Visits::getStatus,Constants.ONE).eq(Visits::getId,visits.getId()));
+                        }else{
+                            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌涓氬姟鏁版嵁瀵硅薄!璇峰埛鏂伴噸璇�");
+                        }
+                    }
+
+
+                }else if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals(
                         Constants.approveObjectType.unCityUseCar)){
                     this.updDriver(approveDTO,approve,false);
                 }
@@ -1125,6 +1159,24 @@
                 //鏃犱粬浜哄鎵圭殑鎯呭喌 鍒欎慨鏀规暟鎹姸鎬�
                 if(Constants.equalsInteger(approveList.size(),Constants.ZERO)&&Constants.equalsInteger(approve.getIsEndCheck(),Constants.ONE)){
                     dealBusinessBean = true;
+                }else{
+                    if(Constants.equalsInteger(approveList.size(),Constants.ZERO)&&Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){
+                        /**寮�鍚笅涓�绾у埆鐨勬暟鎹负寰呭鏍�**/
+                        approveJoinMapper.update(null,new UpdateWrapper<Approve>()
+                                .lambda()
+                                .set(Approve::getStatus,Constants.approveStatus.auditIng)
+                                .set(Approve::getTitle,"瀹℃壒浜�")
+                                .set(Approve::getCheckDate,new Date())
+                                .eq(Approve::getStatus,Constants.approveStatus.wait)
+                                .eq(Approve::getObjId,approve.getObjId())
+                                .eq(Approve::getObjType,approve.getObjType())
+                                .eq(Approve::getLevel,(approve.getLevel()+1))
+                        );
+                    }
+                    if(approveDTO.getObjType().equals(Constants.approveObjectType.cityUseCar)||approveDTO.getObjType().equals(
+                            Constants.approveObjectType.unCityUseCar)){
+                        this.updDriver(approveDTO,approve,false);
+                    }
                 }
             }
             this.passNextNotices(dealBusinessBean,notices,approve,approveList,approveCopyList,approveDTO);
@@ -1142,6 +1194,14 @@
      * @param approveList  鍚岀骇寰呭鎵规暟鎹�
      */
     public void passNextNotices(Boolean dealBusinessBean,Notices notices,Approve approve,List<Approve> approveList,List<Approve> copyList,ApproveDTO approveDTO){
+        //鏈紑鍚笅涓�绾ф椂锛屾搷浣滃悗鐨勫緟瀹℃壒浜�
+        String memberNames =notices.getParam5()
+                .replaceAll(","+notices.getRemark(),"")
+                .replaceAll(notices.getRemark()+",","")
+                .replaceAll(notices.getRemark(),"");
+
+
+
         //1銆佷慨鏀硅嚜宸辩殑鏁版嵁璁板綍
         noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
                 .set(Notices::getEditDate,new Date())
@@ -1153,70 +1213,82 @@
         );
         if(Constants.equalsInteger(approve.getApproveType(),Constants.ZERO)){
             //鎴栫
-            //2銆佹洿鏂颁粬浜虹殑鍚岀骇璁板綍 涓烘妱閫�
+            //2銆佹洿鏂颁粬浜虹殑鍚岀骇璁板綍 涓烘妱閫�  骞舵洿鏂� info 淇℃伅
             noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
                     .set(Notices::getEditDate,new Date())
-                    .set(Notices::getReaded,Constants.ONE)
+                    .set(Notices::getReaded,Constants.ZERO)
                     .set(Notices::getSendacopy,Constants.ONE)
                     .set(Notices::getStatus,Constants.ONE)
                     .set(Notices::getParam4,approveDTO.getLoginUserInfo().getMemberId())
                     .set(dealBusinessBean,Notices::getParam2,Constants.ONE)
                     .eq(Notices::getObjId,notices.getObjId())
+                    .eq(Notices::getStatus,Constants.ZERO)
                     .eq(Notices::getObjType,notices.getObjType())
                     .ne(Notices::getId,notices.getId())
             );
             //3銆佸鏋滀笉鏄粓瀹$敓鎴愪笅涓�绾х殑鏁版嵁璁板綍
             if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)&&!dealBusinessBean){
-              this.saveNextNotice(notices,approve);
+                memberNames = this.saveNextNotice(notices,approve);
             }
         }else if(Constants.equalsInteger(approve.getApproveType(),Constants.ONE)){
             //浼氱
             //2銆佸鏋滄槸鏈�鍚庝竴浣嶅鎵逛汉 涓斾笉鏄粓瀹″紑鍚笅涓�绾ф暟鎹�
             if(Constants.equalsInteger(Constants.ZERO,approveList.size())){
                 if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){
-                    this.saveNextNotice(notices,approve);
+                    memberNames = this.saveNextNotice(notices,approve);
                 }
             }
         }else{
             //鍗曚汉绛�
             //2銆� 鏄惁鏄粓瀹� 寮�鍚笅涓�绾ф暟鎹�
             if(Constants.equalsInteger(approve.getIsEndCheck(),Constants.ZERO)){
-                this.saveNextNotice(notices,approve);
+                memberNames = this.saveNextNotice(notices,approve);
             }
         }
+        String info = "";
+        List<String> memberNameList = Arrays.asList(memberNames.split(","));
+        if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){
+            info = "寰� "+memberNameList.get(0)+" 澶勭悊涓�";
+        }else{
+            info = "寰� "+memberNameList.get(0)+" 绛�"+memberNameList.size()+"浜哄鐞嗕腑";
+        }
+        //鏇存柊璇ヤ笟鍔℃暟鎹殑鎵�鏈夎褰曚俊鎭�
+        noticesJoinMapper.update(null,new UpdateWrapper<Notices>().lambda()
+                        .set(!dealBusinessBean,Notices::getInfo,info)
+                        .set(dealBusinessBean,Notices::getInfo,"瀹℃壒閫氳繃")
+                        .set(Notices::getParam5,memberNames)
+                        .eq(Notices::getObjId,notices.getObjId())
+                        .eq(Notices::getObjType,notices.getObjType()));
+
         //缁堝涓氬姟 涓� 澶勭悊鏁版嵁  杩涜鎶勯�佸彂閫�
         if (Constants.equalsInteger(approve.getIsEndCheck(),Constants.ONE) && dealBusinessBean) {
             if(CollectionUtils.isNotEmpty(copyList)){
-                Notices copyNotices = new Notices();
                 for (Approve copyApprove:copyList) {
-                    if(Objects.isNull(copyNotices)){
-                        BeanUtils.copyProperties(notices,copyNotices);
-                        notices.setId(null);
-                        notices.setCreateDate(new Date());
-                        notices.setEditDate(new Date());
-                        notices.setParam2("2");
-                        notices.setParam3("");
-                        notices.setUserId(copyApprove.getChekorId());
-                        notices.setStatus(Constants.ZERO);
-                        notices.setSendacopy(Constants.ONE);
-                        notices.setReaded(Constants.ZERO);
-                        noticesJoinMapper.insert(notices);
-                    }else{
-                        notices.setId(null);
-                        notices.setUserId(copyApprove.getChekorId());
-                        noticesJoinMapper.insert(notices);
-                    }
+                    Notices copyNotices = new Notices();
+                    BeanUtils.copyProperties(notices,copyNotices);
+                    copyNotices.setId(null);
+                    copyNotices.setCreateDate(new Date());
+                    copyNotices.setEditDate(new Date());
+                    copyNotices.setParam2("2");
+                    copyNotices.setParam3("");
+                    copyNotices.setInfo("瀹℃壒閫氳繃");
+                    copyNotices.setUserId(copyApprove.getChekorId());
+                    copyNotices.setStatus(Constants.ZERO);
+                    copyNotices.setSendacopy(Constants.ONE);
+                    copyNotices.setReaded(Constants.ZERO);
+                    noticesJoinMapper.insert(copyNotices);
                 }
             }
-
-
         }
     }
 
 
-    public void saveNextNotice(Notices notices,Approve approve){
-        List<Approve> nextApproveList = approveJoinMapper.selectList(new QueryWrapper<Approve>()
-                .lambda()
+
+    public String saveNextNotice(Notices notices,Approve approve){
+        List<Approve> nextApproveList = approveJoinMapper.selectJoinList(Approve.class,new MPJLambdaWrapper<Approve>()
+                .selectAll(Approve.class)
+                .selectAs(Member::getName,Approve::getMemberName)
+                .leftJoin(Member.class,Member::getId,Approve::getChekorId)
                 .eq(Approve::getObjId,approve.getObjId())
                 .eq(Approve::getObjType,approve.getObjType())
                 .eq(Approve::getType,Constants.ZERO)
@@ -1225,26 +1297,30 @@
         if(CollectionUtils.isEmpty(nextApproveList)){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀹℃壒娴佹暟鎹紓甯�");
         }
-        Notices newNotices = new Notices();
+        List<String> memberNameList =nextApproveList.stream().map(m->m.getMemberName()).collect(Collectors.toList());
+        String memberNames = String.join(",",memberNameList);
         for (Approve nextDealApprove:nextApproveList) {
-            if(Objects.isNull(newNotices)){
-                BeanUtils.copyProperties(notices,newNotices);
-                notices.setId(null);
-                notices.setCreateDate(new Date());
-                notices.setParam2("0");
-                notices.setParam3("");
-                notices.setEditDate(new Date());
-                notices.setUserId(nextDealApprove.getChekorId());
-                notices.setStatus(Constants.ZERO);
-                notices.setSendacopy(Constants.ZERO);
-                notices.setReaded(Constants.ZERO);
-                noticesJoinMapper.insert(notices);
+            Notices newNotices = new Notices();
+            BeanUtils.copyProperties(notices,newNotices);
+            newNotices.setId(null);
+            newNotices.setCreateDate(new Date());
+            newNotices.setParam2("0");
+            newNotices.setParam3("");
+            newNotices.setEditDate(new Date());
+            newNotices.setUserId(nextDealApprove.getChekorId());
+            newNotices.setStatus(Constants.ZERO);
+            newNotices.setSendacopy(Constants.ZERO);
+            newNotices.setReaded(Constants.ZERO);
+            notices.setParam5(memberNames);
+            notices.setRemark(nextDealApprove.getMemberName());
+            if(Constants.equalsInteger(memberNameList.size(),Constants.ONE)){
+                notices.setInfo("寰� "+memberNameList.get(0)+" 澶勭悊涓�");
             }else{
-                notices.setId(null);
-                notices.setUserId(nextDealApprove.getChekorId());
-                noticesJoinMapper.insert(notices);
+                notices.setInfo("寰� "+memberNameList.get(0)+" 绛�"+memberNameList.size()+"浜哄鐞嗕腑");
             }
+            noticesJoinMapper.insert(newNotices);
         }
+        return memberNames;
     }
 
     public void dealBusinessData(ApproveDTO approveDTO,Approve approve){
@@ -1269,6 +1345,15 @@
         }else{
             throw new BusinessException(ResponseStatus.BAD_REQUEST);
         }
+        if(Constants.equalsInteger(approveDTO.getStatus(),Constants.TWO)){
+            //澶勭悊閫氳繃 鏄剧ず鎵�鏈夌殑鎶勯�佽褰�
+            approveMapper.update(null,new UpdateWrapper<Approve>().lambda().set(Approve::getStatus,Constants.TWO)
+                    .set(Approve::getCheckDate,new Date())
+                    .eq(Approve::getObjId,approve.getObjId())
+                    .eq(Approve::getObjType,approve.getObjType())
+                    .eq(Approve::getType,Constants.ONE)
+            );
+        }
     }
 
 
--
Gitblit v1.9.3