From 4a8e93b2b6433f34d066171b41f9c4c11617756f Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 29 四月 2025 16:21:54 +0800
Subject: [PATCH] 最新版本541200007

---
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java |   85 ++++++++++++++++++++++++++++++++----------
 1 files changed, 64 insertions(+), 21 deletions(-)

diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
index 42227d5..63bc845 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
@@ -1321,6 +1321,9 @@
         queryWrapper.isNull(Visits::getParentId);
         queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getMemberId()),Visits::getMemberId,pageWrap.getModel().getMemberId());
         queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getReceptMemberId()),Visits::getReceptMemberId,pageWrap.getModel().getReceptMemberId());
+        queryWrapper.ge(Objects.nonNull(pageWrap.getModel().getQueryStarttime()),Visits::getStarttime,Utils.Date.getStart(pageWrap.getModel().getQueryStarttime()));
+        queryWrapper.le(Objects.nonNull(pageWrap.getModel().getQueryEndtime()),Visits::getStarttime,Utils.Date.getEnd(pageWrap.getModel().getQueryEndtime()));
+
 
         if(Objects.nonNull(pageWrap.getModel().getBusinessStatus())){
             if(Constants.equalsInteger(pageWrap.getModel().getBusinessStatus(),Constants.TWO)){
@@ -1527,8 +1530,24 @@
 
 
     @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
+    public  void  visitLevelForCarOut(Visits visits){
+        visitLevelBiz(visits);
+        visits.setRemark("璺熼殢璁垮杞﹁締绂诲洯鑷姩绛剧");
+    }
+    @Override
+    @Transactional(rollbackFor = {BusinessException.class,Exception.class})
     public void  visitLevel(Integer visitId){
         Visits visits = visitsMapper.selectById(visitId);
+        visits.setRemark("骞冲彴绠$悊鍛樻墜鍔ㄧ绂绘垚鍔�");
+        visitLevelBiz(visits);
+        //浜у嚭鍦ㄥ満浜哄憳淇℃伅
+        retentionMapper.delete(new UpdateWrapper<Retention>().lambda()
+                .eq(Retention::getType,Constants.memberType.visitor)
+                .eq(Retention::getMemberId,visits.getMemberId()));
+    }
+
+    private void visitLevelBiz(Visits visits) {
         if(Objects.isNull(visits)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
@@ -1540,13 +1559,12 @@
         //璋冪敤娴峰悍寮哄埗绛剧
         BaseResponse response =  HKService.iccmSignoff(request);
 //        BaseResponse response =  HKService.outVisitAppiontment(request);
-        visitsMapper.update(null,new UpdateWrapper<Visits>().lambda().set(Visits::getStatus,Constants.VisitStatus.signout)
-                .eq(Visits::getId,visitId));
-        //浜у嚭鍦ㄥ満浜哄憳淇℃伅
-        retentionMapper.delete(new UpdateWrapper<Retention>().lambda()
-                .eq(Retention::getType,Constants.memberType.visitor)
-                .eq(Retention::getMemberId,visits.getMemberId()));
+        visitsMapper.update(null,new UpdateWrapper<Visits>().lambda()
+                .set(Visits::getStatus,Constants.VisitStatus.signout)
+                .set(Visits::getRemark,visits.getRemark())
+                .eq(Visits::getId,visits.getId()));
     }
+
     @Override
     public void  visitCancel(Integer visitId){
         Visits visits = visitsMapper.selectById(visitId);
@@ -1839,6 +1857,7 @@
             List<InterestedListVO> weekVisitList = new ArrayList<>();
             List<InterestedListVO> weekCarList = new ArrayList<>();
             List<InterestedListVO> lwList = new ArrayList<>();
+            List<InterestedListVO> internalList = new ArrayList<>();
             //鏌ヨ涓冨ぉ鍓嶇殑璁垮璁板綍鏁伴噺
             List<Visits> visitsList = visitsMapper.selectList(new QueryWrapper<Visits>().lambda().in(Visits::getStatus,
                     Constants.VisitStatus.signin,Constants.VisitStatus.signout)
@@ -1893,25 +1912,49 @@
                     .eq(Company::getIsdeleted,Constants.ZERO)
             );
 
+
+
             if(CollectionUtils.isNotEmpty(companyList)){
-                List<Integer> companyIds = companyList.stream().map(i->i.getId()).collect(Collectors.toList());
-                List<Retention> retentionList = retentionMapper.selectList(
-                        new QueryWrapper<Retention>().lambda()
-                                .eq(Retention::getType,Constants.TWO)
-                                .in(Retention::getCompanyId,companyIds)
-                );
-                for (Company company:companyList) {
-                    Integer count = retentionList.stream().filter(i->Constants.equalsInteger(i.getCompanyId(),company.getId())).collect(Collectors.toList()).size();
-                    if(count>0){
-                        InterestedListVO lw = new InterestedListVO();
-                        lw.setNum(count);
-                        lw.setName(company.getName());
-                        lwList.add(lw);
+                List<Company>  lwCompanyList  = companyList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.ZERO)).collect(Collectors.toList());
+                if(CollectionUtils.isNotEmpty(lwCompanyList)){
+                    List<Integer> lwCompanyIds = lwCompanyList.stream().map(i->i.getId()).collect(Collectors.toList());
+                    List<Retention> retentionList = retentionMapper.selectList(
+                            new QueryWrapper<Retention>().lambda()
+                                    .eq(Retention::getType,Constants.TWO)
+                                    .in(Retention::getCompanyId,lwCompanyIds)
+                    );
+                    for (Company company:lwCompanyList) {
+                        Integer count = retentionList.stream().filter(i->Constants.equalsInteger(i.getCompanyId(),company.getId())).collect(Collectors.toList()).size();
+                        if(count>0){
+                            InterestedListVO lw = new InterestedListVO();
+                            lw.setNum(count);
+                            lw.setName(company.getName());
+                            lwList.add(lw);
+                        }
+                    }
+                }
+
+                List<Company>  internalCompanyList  = companyList.stream().filter(i->Constants.equalsInteger(i.getType(),Constants.ONE)).collect(Collectors.toList());
+                if(CollectionUtils.isNotEmpty(internalCompanyList)){
+                    List<Integer> internalCompanyIds = internalCompanyList.stream().map(i->i.getId()).collect(Collectors.toList());
+                    List<Retention> retentionList = retentionMapper.selectList(
+                            new QueryWrapper<Retention>().lambda()
+                                    .eq(Retention::getType,Constants.TWO)
+                                    .in(Retention::getCompanyId,internalCompanyIds)
+                    );
+                    for (Company company:internalCompanyList) {
+                        Integer count = retentionList.stream().filter(i->Constants.equalsInteger(i.getCompanyId(),company.getId())).collect(Collectors.toList()).size();
+                        if(count>0){
+                            InterestedListVO lw = new InterestedListVO();
+                            lw.setNum(count);
+                            lw.setName(company.getName());
+                            internalList.add(lw);
+                        }
                     }
                 }
             }
-
-            pcWorkPlatformDataVO.setLwList(lwList   );
+            pcWorkPlatformDataVO.setInternalList(internalList);
+            pcWorkPlatformDataVO.setLwList(lwList);
         }else if(Constants.equalsInteger(queryType,Constants.THREE)) {
             if (Objects.isNull(loginUserInfo.getMemberId())) {
                 pcWorkPlatformDataVO.setNoticesList(new ArrayList<>());

--
Gitblit v1.9.3