From e23023b93f34286f5a807b0b85e9a0619a297ed7 Mon Sep 17 00:00:00 2001
From: Your Name <you@example.com>
Date: 星期二, 21 二月 2023 23:25:34 +0800
Subject: [PATCH] Merge branch 'master' of http://git.homecommunity.cn/supervip/MicroCommunity

---
 service-community/src/main/java/com/java110/community/cmd/visit/ListVisitsCmd.java |  170 ++++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 162 insertions(+), 8 deletions(-)

diff --git a/service-community/src/main/java/com/java110/community/cmd/visit/ListVisitsCmd.java b/service-community/src/main/java/com/java110/community/cmd/visit/ListVisitsCmd.java
index 3a5606f..b7d0397 100644
--- a/service-community/src/main/java/com/java110/community/cmd/visit/ListVisitsCmd.java
+++ b/service-community/src/main/java/com/java110/community/cmd/visit/ListVisitsCmd.java
@@ -1,14 +1,27 @@
 package com.java110.community.cmd.visit;
 
 import com.alibaba.fastjson.JSONObject;
+import com.google.protobuf.Api;
 import com.java110.core.annotation.Java110Cmd;
 import com.java110.core.context.ICmdDataFlowContext;
 import com.java110.core.event.cmd.Cmd;
 import com.java110.core.event.cmd.CmdEvent;
 import com.java110.core.factory.CommunitySettingFactory;
+import com.java110.doc.annotation.*;
+import com.java110.dto.accessControlWhite.AccessControlWhiteDto;
+import com.java110.dto.file.FileRelDto;
+import com.java110.dto.owner.OwnerDto;
 import com.java110.dto.visit.VisitDto;
+import com.java110.dto.visitSetting.VisitSettingDto;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
 import com.java110.intf.community.IVisitInnerServiceSMO;
+import com.java110.intf.community.IVisitSettingV1InnerServiceSMO;
+import com.java110.intf.community.IVisitV1InnerServiceSMO;
+import com.java110.intf.user.IOwnerV1InnerServiceSMO;
+import com.java110.utils.cache.MappingCache;
+import com.java110.utils.constant.MappingConstant;
 import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.utils.util.StringUtil;
 import com.java110.vo.api.visit.ApiVisitDataVo;
@@ -22,12 +35,53 @@
 import java.util.List;
 import java.util.Map;
 
+
+@Java110CmdDoc(title = "鏌ヨ璁垮",
+        description = "渚沺c绔煡璇㈣瀹汉鍛�",
+        httpMethod = "get",
+        url = "http://{ip}:{port}/app/visit.listVisits",
+        resource = "communityDoc",
+        author = "鍚村鏂�",
+        serviceCode = "visit.listVisits"
+)
+
+@Java110ParamsDoc(params = {
+        @Java110ParamDoc(name = "page", type = "int", length = 11, remark = "鍒嗛〉淇℃伅"),
+        @Java110ParamDoc(name = "row", type = "int", length = 11, remark = "琛屾暟"),
+        @Java110ParamDoc(name = "communityId", length = 30, remark = "灏忓尯ID"),
+})
+
+@Java110ResponseDoc(
+        params = {
+                @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "杩斿洖缂栧彿锛�0 鎴愬姛 鍏朵粬澶辫触"),
+                @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "鎴愬姛", remark = "鎻忚堪"),
+                @Java110ParamDoc(name = "visits", type = "Array", remark = "鏈夋晥鏁版嵁"),
+                @Java110ParamDoc(parentNodeName = "visits", name = "vId", type = "String", remark = "璁垮ID"),
+                @Java110ParamDoc(parentNodeName = "visits", name = "vName", type = "String", remark = "璁垮鍚嶇О"),
+                @Java110ParamDoc(parentNodeName = "visits", name = "visitGender", type = "String", remark = "璁垮鎬у埆"),
+                @Java110ParamDoc(parentNodeName = "visits", name = "phoneNumber", type = "String", remark = "鎵嬫満鍙�"),
+                @Java110ParamDoc(parentNodeName = "visits", name = "visitTime", type = "String", remark = "璁块棶鏃堕棿"),
+        }
+)
+
+@Java110ExampleDoc(
+        reqBody = "ttp://localhost:3000/app/visit.listVisits?page=1&row=10&communityId=2022121921870161",
+        resBody = "{\"page\":0,\"records\":0,\"rows\":0,\"total\":0,\"visits\":[]}"
+)
 @Java110Cmd(serviceCode = "visit.listVisits")
 public class ListVisitsCmd extends Cmd {
 
     @Autowired
-    private IVisitInnerServiceSMO visitInnerServiceSMOImpl;
+    private IVisitV1InnerServiceSMO visitV1InnerServiceSMO;
 
+    @Autowired
+    private IVisitSettingV1InnerServiceSMO visitSettingV1InnerServiceSMOImpl;
+
+    @Autowired
+    private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
+
+    @Autowired
+    private IOwnerV1InnerServiceSMO ownerV1InnerServiceSMOImpl;
 
     //閿�
     public static final String CAR_FREE_TIME = "CAR_FREE_TIME";
@@ -35,42 +89,62 @@
     //閿�
     public static final String VISIT_NUMBER = "VISIT_NUMBER";
 
-
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
         super.validatePageInfo(reqJson);
+
+        Assert.hasKeyAndValue(reqJson, "communityId", "鏈寘鍚皬鍖�");
+
     }
 
     @Override
     public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
+
+
         ResponseEntity<String> responseEntity = new ResponseEntity<String>("", HttpStatus.OK);
         if (reqJson.containsKey("addVisitType") && !StringUtil.isEmpty(reqJson.getString("addVisitType"))
                 && "initAddVisitParameter".equals(reqJson.getString("addVisitType"))) {
             //棰勭害杞﹀厤璐规椂闀�
             String freeTime = CommunitySettingFactory.getValue(reqJson.getString("communityId"), CAR_FREE_TIME);
-            //棰勭害杞﹀厤璐规鏁�
-            int number = Integer.parseInt(CommunitySettingFactory.getValue(reqJson.getString("communityId"), VISIT_NUMBER));
+            String numStr = CommunitySettingFactory.getValue(reqJson.getString("communityId"), VISIT_NUMBER);
+            int number = 999;
+            if (StringUtil.isInteger(numStr)) {
+                number = Integer.parseInt(numStr);
+            }
             Map initAddVisitParameter = new HashMap();
             initAddVisitParameter.put("freeTime", freeTime);
             initAddVisitParameter.put("freeTimes", number);
+            //涓氫富绔幏鍙栬瀹㈢櫥璁扮浉鍏抽厤缃弬鏁�
             responseEntity = new ResponseEntity<String>(JSONObject.toJSONString(initAddVisitParameter), HttpStatus.OK);
         } else {
             VisitDto visitDto = BeanConvertUtil.covertBean(reqJson, VisitDto.class);
-            int count = visitInnerServiceSMOImpl.queryVisitsCount(visitDto);
-
+            if (reqJson.containsKey("channel") && !StringUtil.isEmpty(reqJson.getString("channel"))
+                    && "PC".equals(reqJson.getString("channel"))) {
+                visitDto.setCreateUserId("");
+            }
+            int count = visitV1InnerServiceSMO.queryVisitsCount(visitDto);
             List<ApiVisitDataVo> visits = new ArrayList<>();
             if (count > 0) {
-                List<VisitDto> visitDtos = visitInnerServiceSMOImpl.queryVisits(visitDto);
+                List<VisitDto> visitDtos = visitV1InnerServiceSMO.queryVisits(visitDto);
                 for (VisitDto visit : visitDtos) {
                     ApiVisitDataVo apiVisitDataVo = BeanConvertUtil.covertBean(visit, ApiVisitDataVo.class);
                     if (!StringUtil.isEmpty(visit.getFileSaveName())) {
-                        apiVisitDataVo.setUrl("/callComponent/download/getFile/file?fileId=" + visit.getFileSaveName() + "&communityId=-1");
+                        apiVisitDataVo.setUrl(visit.getFileSaveName());
                     }
                     visits.add(apiVisitDataVo);
                 }
             } else {
                 visits = new ArrayList<>();
             }
+
+            //鍒峰叆娴佺▼ID
+            refreshOwners(visits, reqJson);
+
+            //鍒峰叆娴佺▼ID
+            refreshSetting(visits, reqJson);
+
+            // 鍒峰叆浜鸿劯
+            refreshPhoto(visits, reqJson);
 
             ApiVisitVo apiVisitVo = new ApiVisitVo();
             apiVisitVo.setTotal(count);
@@ -82,4 +156,84 @@
         context.setResponseEntity(responseEntity);
 
     }
+
+    private void refreshOwners(List<ApiVisitDataVo> visits, JSONObject reqJson) {
+
+        if(visits == null || visits.size() < 1){
+            return ;
+        }
+
+        List<String> ownerIds = new ArrayList<>();
+        for(ApiVisitDataVo apiVisitDataVo: visits){
+            ownerIds.add(apiVisitDataVo.getOwnerId());
+        }
+
+        OwnerDto ownerDto = new OwnerDto();
+        ownerDto.setOwnerIds(ownerIds.toArray(new String[ownerIds.size()]));
+        ownerDto.setOwnerTypeCd(OwnerDto.OWNER_TYPE_CD_OWNER);
+        ownerDto.setCommunityId(reqJson.getString("communityId"));
+       List<OwnerDto> ownerDtos =  ownerV1InnerServiceSMOImpl.queryOwners(ownerDto);
+
+        for(ApiVisitDataVo apiVisitDataVo: visits){
+            for(OwnerDto tmpOwnerDto : ownerDtos){
+                if(StringUtil.isEmpty(apiVisitDataVo.getOwnerId())){
+                    continue;
+                }
+                if(!apiVisitDataVo.getOwnerId().equals(tmpOwnerDto.getOwnerId())){
+                    continue;
+                }
+                apiVisitDataVo.setOwnerName(tmpOwnerDto.getName());
+                apiVisitDataVo.setOwnerTel(tmpOwnerDto.getLink());
+            }
+        }
+
+    }
+
+    private void refreshPhoto(List<ApiVisitDataVo> visits, JSONObject reqJson) {
+
+        List<String> vIds = new ArrayList<>();
+        for(ApiVisitDataVo apiVisitDataVo: visits){
+            vIds.add(apiVisitDataVo.getvId());
+        }
+
+        FileRelDto fileRelDto = new FileRelDto();
+        fileRelDto.setObjIds(vIds.toArray(new String[vIds.size()]));
+        List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+
+        if(fileRelDtos == null || fileRelDtos.size() < 1){
+            return ;
+        }
+        String imgUrl = MappingCache.getValue(MappingConstant.FILE_DOMAIN,"IMG_PATH");
+        for(ApiVisitDataVo apiVisitDataVo: visits){
+            for(FileRelDto tmpFileRelDto : fileRelDtos){
+                if(!apiVisitDataVo.getvId().equals(tmpFileRelDto.getObjId())){
+                    continue;
+                }
+                if(tmpFileRelDto.getFileSaveName().startsWith("http")){
+                    apiVisitDataVo.setUrl(tmpFileRelDto.getFileSaveName() );
+                }else{
+                    apiVisitDataVo.setUrl(imgUrl +tmpFileRelDto.getFileSaveName() );
+                }
+            }
+        }
+    }
+
+    private void refreshSetting(List<ApiVisitDataVo> visits, JSONObject reqJson) {
+        VisitSettingDto visitSettingDto = new VisitSettingDto();
+        visitSettingDto.setCommunityId(reqJson.getString("communityId"));
+        List<VisitSettingDto> visitSettingDtos = visitSettingV1InnerServiceSMOImpl.queryVisitSettings(visitSettingDto);
+
+        if (visitSettingDtos == null || visitSettingDtos.size() < 1) {
+            return;
+        }
+
+        if(visits == null || visits.size() < 1){
+            return;
+        }
+
+        for(ApiVisitDataVo visitDataVo:visits){
+            visitDataVo.setFlowId(visitSettingDtos.get(0).getFlowId());
+        }
+
+    }
 }

--
Gitblit v1.8.0