From 896cb061fbef0e4805bd1e40dc63cd0239070431 Mon Sep 17 00:00:00 2001
From: liuleilei <234@qq.com>
Date: 星期四, 14 十二月 2023 16:40:01 +0800
Subject: [PATCH] 员工列表

---
 server/dmvisit_admin/src/main/java/com/doumee/api/business/CarsController.java                  |    2 
 server/dmvisit_service/src/main/java/com/doumee/dao/business/join/UserActionJoinMapper.java     |    7 
 server/dmvisit_service/src/main/java/com/doumee/service/business/CompanyService.java            |    2 
 server/dmvisit_service/src/main/java/com/doumee/service/business/MemberService.java             |    3 
 server/dmvisit_service/src/main/java/com/doumee/dao/admin/response/MemberInfoDTO.java           |   12 +
 server/dmvisit_service/src/main/java/com/doumee/dao/business/join/TrainTimeJoinMapper.java      |   13 +
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/TrainTimeServiceImpl.java |   79 ++----
 server/dmvisit_service/src/main/java/com/doumee/dao/admin/request/MemberQuery.java              |   13 +
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java      |   12 +
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java    |  211 +++++-------------
 server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Cars.java                    |    2 
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java    |   88 +++++++
 server/dmvisit_admin/src/main/java/com/doumee/api/business/CompanyController.java               |   10 
 server/dmvisit_service/src/main/java/com/doumee/dao/business/model/TrainTime.java               |   59 +++-
 server/dmvisit_service/src/main/java/com/doumee/dao/business/join/DeviceJoinMapper.java         |    8 
 server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Visits.java                  |   20 +
 server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java   |   52 ++++
 server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Company.java                 |    5 
 server/dmvisit_admin/src/main/java/com/doumee/api/business/MemberController.java                |   20 +
 19 files changed, 381 insertions(+), 237 deletions(-)

diff --git a/server/dmvisit_admin/src/main/java/com/doumee/api/business/CarsController.java b/server/dmvisit_admin/src/main/java/com/doumee/api/business/CarsController.java
index 3ea4554..5c38b14 100644
--- a/server/dmvisit_admin/src/main/java/com/doumee/api/business/CarsController.java
+++ b/server/dmvisit_admin/src/main/java/com/doumee/api/business/CarsController.java
@@ -69,7 +69,7 @@
 
     @ApiOperation("鍒嗛〉鏌ヨ")
     @PostMapping("/page")
-    @RequiresPermissions("business:cars:query")
+   // @RequiresPermissions("business:cars:query")
     public ApiResponse<PageData<Cars>> findPage (@RequestBody PageWrap<Cars> pageWrap) {
         return ApiResponse.success(carsService.findPage(pageWrap));
     }
diff --git a/server/dmvisit_admin/src/main/java/com/doumee/api/business/CompanyController.java b/server/dmvisit_admin/src/main/java/com/doumee/api/business/CompanyController.java
index 41cca71..b3480ae 100644
--- a/server/dmvisit_admin/src/main/java/com/doumee/api/business/CompanyController.java
+++ b/server/dmvisit_admin/src/main/java/com/doumee/api/business/CompanyController.java
@@ -73,7 +73,7 @@
     @PostMapping("/updateById")
     @RequiresPermissions("business:company:update")
     public ApiResponse updateById(@RequestBody Company company) {
-        companyService.updateById(company);
+        companyService.updateLaborServicesById(company);
         return ApiResponse.success(null);
     }
 
@@ -84,6 +84,14 @@
         return ApiResponse.success(companyService.findPage(pageWrap));
     }
 
+
+    @ApiOperation("淇敼鐘舵��")
+    @PostMapping("/updateStatusById")
+    @RequiresPermissions("business:company:update")
+    public ApiResponse updateStatusById(@RequestBody Company company) {
+        companyService.updateStatusById(company);
+        return ApiResponse.success(null);
+    }
     @ApiOperation("瀵煎嚭Excel")
     @PostMapping("/exportExcel")
     @RequiresPermissions("business:company:exportExcel")
diff --git a/server/dmvisit_admin/src/main/java/com/doumee/api/business/MemberController.java b/server/dmvisit_admin/src/main/java/com/doumee/api/business/MemberController.java
index edd1a97..e4eb4d3 100644
--- a/server/dmvisit_admin/src/main/java/com/doumee/api/business/MemberController.java
+++ b/server/dmvisit_admin/src/main/java/com/doumee/api/business/MemberController.java
@@ -78,11 +78,19 @@
         return ApiResponse.success(null);
     }
 
-    @ApiOperation("鏍规嵁ID 绂佸惎鐢� 鎷夐粦")
+    @ApiOperation("鏍规嵁ID 绂佸惎鐢�  ")
     @PostMapping("/updateStatusById")
     @RequiresPermissions("business:member:update")
     public ApiResponse updateStatusById(@RequestBody Member member){
         memberService.updateStatusById(member);
+        return ApiResponse.success(null);
+    }
+
+    @ApiOperation("浜哄憳鎷夐粦")
+    @PostMapping("/updateVisitsStatusById")
+    @RequiresPermissions("business:member:update")
+    public ApiResponse updateVisitsStatusById(@RequestBody Member member){
+        memberService.updateVisitsStatusById(member);
         return ApiResponse.success(null);
     }
 
@@ -103,7 +111,7 @@
 
     @ApiOperation("鍒嗛〉鍔冲姟鐢ㄦ埛淇℃伅鏌ヨ")
     @PostMapping("/findLaborMemberInfoPage")
-//    @RequiresPermissions("business:member:query")
+    @RequiresPermissions("business:member:query")
     public ApiResponse<PageData<MemberInfoDTO>> findLaborMemberInfoPage(@RequestBody PageWrap<MemberInfoDTO> pageWrap){
         return ApiResponse.success(memberService.findLaborMemberInfoPage(pageWrap));
     }
@@ -135,4 +143,12 @@
     public ApiResponse<PageData<MemberInfoDTO>> findMemberInfoPage(@RequestBody PageWrap<MemberQuery> pageWrap){
         return ApiResponse.success(memberService.findMemberInfoPage(pageWrap));
     }
+
+    @ApiOperation("鍒嗛〉鏌ヨ璁垮浜哄憳淇℃伅")
+    @PostMapping("/findVisitPage")
+    @RequiresPermissions("business:member:query")
+    public ApiResponse<PageData<MemberInfoDTO>> findVisitPage (@RequestBody PageWrap<MemberQuery> pageWrap) {
+        return ApiResponse.success(memberService.findVisitPage(pageWrap));
+    }
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/admin/request/MemberQuery.java b/server/dmvisit_service/src/main/java/com/doumee/dao/admin/request/MemberQuery.java
index 29b75cc..b7ef45b 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/admin/request/MemberQuery.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/admin/request/MemberQuery.java
@@ -30,4 +30,17 @@
     @ApiModelProperty(value = "鍏徃IDs")
     private List<Integer> companyIds;
 
+    @ApiModelProperty(value = "濮撳悕")
+    private String name;
+
+    @ApiModelProperty(value = "鎵嬫満鍙�")
+    private String phone;
+
+    @ApiModelProperty(value = "鍏徃鍚嶇О")
+    private String companyName;
+
+    @ApiModelProperty(value = "韬唤璇佸彿")
+    private String idcardNo;
+
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/admin/response/MemberInfoDTO.java b/server/dmvisit_service/src/main/java/com/doumee/dao/admin/response/MemberInfoDTO.java
index 42563f5..7a66b78 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/admin/response/MemberInfoDTO.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/admin/response/MemberInfoDTO.java
@@ -1,5 +1,6 @@
 package com.doumee.dao.admin.response;
 
+import com.baomidou.mybatisplus.annotation.TableField;
 import com.doumee.core.annotation.excel.ExcelColumn;
 import com.fasterxml.jackson.annotation.JsonFormat;
 import io.swagger.annotations.ApiModel;
@@ -104,4 +105,15 @@
     @JsonFormat(pattern = "yyyy-MM-dd")
     private Date empowerEndTime;
 
+    @ApiModelProperty(value = "鎷滆娆℃暟")
+    @TableField(exist = false)
+    private Integer visitsCount;
+
+    @ApiModelProperty(value = "鏈�鍚庤瀹㈡椂闂�")
+    @TableField(exist = false)
+    private Date visitsLastDate;
+
+
+
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/DeviceJoinMapper.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/DeviceJoinMapper.java
new file mode 100644
index 0000000..73bbfd7
--- /dev/null
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/DeviceJoinMapper.java
@@ -0,0 +1,8 @@
+package com.doumee.dao.business.join;
+
+import com.doumee.dao.business.model.Device;
+import com.doumee.dao.business.model.UserAction;
+import com.github.yulichang.base.mapper.MPJJoinMapper;
+
+public interface DeviceJoinMapper extends MPJJoinMapper<Device> {
+}
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/TrainTimeJoinMapper.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/TrainTimeJoinMapper.java
new file mode 100644
index 0000000..47a6923
--- /dev/null
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/TrainTimeJoinMapper.java
@@ -0,0 +1,13 @@
+package com.doumee.dao.business.join;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.doumee.dao.business.model.TrainTime;
+import com.github.yulichang.base.mapper.MPJJoinMapper;
+
+/**
+ * @author 姹熻箘韫�
+ * @date 2023/11/30 15:33
+ */
+public interface TrainTimeJoinMapper extends MPJJoinMapper<TrainTime> {
+
+}
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/UserActionJoinMapper.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/UserActionJoinMapper.java
new file mode 100644
index 0000000..c166202
--- /dev/null
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/join/UserActionJoinMapper.java
@@ -0,0 +1,7 @@
+package com.doumee.dao.business.join;
+
+import com.doumee.dao.business.model.UserAction;
+import com.github.yulichang.base.mapper.MPJJoinMapper;
+
+public interface UserActionJoinMapper extends MPJJoinMapper<UserAction> {
+}
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Cars.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Cars.java
index 1e483b8..d55e19a 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Cars.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Cars.java
@@ -20,7 +20,7 @@
 @TableName("`cars`")
 public class Cars {
 
-    @TableId(type = IdType.AUTO)
+    @TableId(value = "id",type = IdType.AUTO)
     @ApiModelProperty(value = "涓婚敭", example = "1")
     @ExcelColumn(name="涓婚敭")
     private Integer id;
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Company.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Company.java
index 875d8cd..d947c43 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Company.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Company.java
@@ -160,4 +160,9 @@
     @TableField(exist = false)
     private String headPhone;
 
+    @ApiModelProperty(value = "涓婄骇缁勭粐鍚嶇О")
+    @TableField(exist = false)
+    private String parentName;
+
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/TrainTime.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/TrainTime.java
index 98b82af..1bcb540 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/TrainTime.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/TrainTime.java
@@ -1,5 +1,6 @@
 package com.doumee.dao.business.model;
 
+import com.baomidou.mybatisplus.annotation.TableField;
 import com.doumee.core.annotation.excel.ExcelColumn;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
@@ -22,53 +23,77 @@
 
     @TableId(type = IdType.AUTO)
     @ApiModelProperty(value = "涓婚敭", example = "1")
-    @ExcelColumn(name="涓婚敭")
     private Integer id;
 
     @ApiModelProperty(value = "鍒涘缓浜虹紪鐮�")
-    @ExcelColumn(name="鍒涘缓浜虹紪鐮�")
     private String creator;
 
-    @ApiModelProperty(value = "鍒涘缓鏃堕棿")
-    @ExcelColumn(name="鍒涘缓鏃堕棿")
-    @JsonFormat(pattern = "yyyy-MM-dd")
-    private Date createDate;
+
 
     @ApiModelProperty(value = "鏇存柊浜虹紪鐮�")
-    @ExcelColumn(name="鏇存柊浜虹紪鐮�")
     private String edirot;
 
     @ApiModelProperty(value = "鏇存柊鏃堕棿")
-    @ExcelColumn(name="鏇存柊鏃堕棿")
     @JsonFormat(pattern = "yyyy-MM-dd")
     private Date editDate;
 
     @ApiModelProperty(value = "鏄惁鍒犻櫎0鍚� 1鏄�", example = "1")
-    @ExcelColumn(name="鏄惁鍒犻櫎0鍚� 1鏄�")
     private Integer isdeleted;
 
     @ApiModelProperty(value = "澶囨敞")
-    @ExcelColumn(name="澶囨敞")
     private String remark;
 
     @ApiModelProperty(value = "浜哄憳缂栫爜", example = "1")
-    @ExcelColumn(name="浜哄憳缂栫爜")
     private Integer memberId;
 
     @ApiModelProperty(value = "鏈夋晥鏈熷紑濮�")
-    @ExcelColumn(name="鏈夋晥鏈熷紑濮�")
     private Date startTime;
 
-    @ApiModelProperty(value = "鏈夋晥鏈熺粨鏉�", example = "1")
-    @ExcelColumn(name="鏈夋晥鏈熺粨鏉�")
-    private Date endTime;
+
 
     @ApiModelProperty(value = "瀵煎叆鐘舵��", example = "1")
-    @ExcelColumn(name="瀵煎叆鐘舵��")
     private Integer importStatus;
 
     @ApiModelProperty(value = "瀵煎叆澶囨敞")
-    @ExcelColumn(name="瀵煎叆澶囨敞")
     private String importInfo;
 
+
+
+    @ApiModelProperty(value = "濮撳悕")
+    @TableField(exist = false)
+    @ExcelColumn(name="濮撳悕", index = 1)
+    private String name;
+
+    @ApiModelProperty(value = "鎵嬫満鍙�")
+    @TableField(exist = false)
+    @ExcelColumn(name="鎵嬫満鍙�", index = 2)
+    private String phone;
+
+    @ApiModelProperty(value = "韬唤璇�")
+    @TableField(exist = false)
+    @ExcelColumn(name="韬唤璇�", index = 3)
+    private String idcardNo;
+
+
+
+    @ApiModelProperty(value = "缁勭粐鍚嶇О")
+    @TableField(exist = false)
+    @ExcelColumn(name="鎵�灞炲叕鍙�", index = 4)
+    private String companyName;
+
+    @ApiModelProperty(value = "鎿嶄綔浜�")
+    @TableField(exist = false)
+    @ExcelColumn(name="鎿嶄綔浜�", index = 5)
+    private String createName;
+
+    @ApiModelProperty(value = "鍩硅鏃堕棿鑷�", example = "1")
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @ExcelColumn(name="鍩硅鏃堕棿鑷�", index = 6 ,dateFormat="yyyy-MM-dd")
+    private Date endTime;
+
+    @ApiModelProperty(value = "鍒涘缓鏃堕棿")
+    @JsonFormat(pattern = "yyyy-MM-dd")
+    @ExcelColumn(name="鎿嶄綔鏃堕棿", index = 7 ,dateFormat="yyyy-MM-dd")
+    private Date createDate;
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Visits.java b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Visits.java
index 607c84d..f9866dc 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Visits.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/dao/business/model/Visits.java
@@ -228,4 +228,24 @@
     @TableField(exist = false)
     private List<Integer> lwWithUserList;
 
+    @ApiModelProperty(value = "琚浜哄憳濮撳悕", example = "1")
+    @ExcelColumn(name="琚浜哄憳濮撳悕")
+    @TableField(exist = false)
+    private String receptMemberName;
+
+    @ApiModelProperty(value = "琚浜哄憳閮ㄩ棬", example = "1")
+    @ExcelColumn(name="琚浜哄憳閮ㄩ棬")
+    @TableField(exist = false)
+    private String receptMemberDepartment;
+
+    @ApiModelProperty(value = "闂ㄧ闆嗗悎", example = "1")
+    @ExcelColumn(name="闂ㄧ闆嗗悎")
+    @TableField(exist = false)
+    private List<Device> deviceList;
+
+    @ApiModelProperty(value = "闅忚浜哄憳鍒楄〃", example = "1")
+    @ExcelColumn(name="闅忚浜哄憳鍒楄〃")
+    @TableField(exist = false)
+    private List<Visits> visitsList;
+
 }
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/CompanyService.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/CompanyService.java
index c7cf7a1..4bfefb3 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/CompanyService.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/CompanyService.java
@@ -103,6 +103,8 @@
      * @return PageData<Company>
      */
     PageData<Company> findPage(PageWrap<Company> pageWrap);
+
+    void updateStatusById(Company company);
     /**
      * 鏉′欢缁熻
      *
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/MemberService.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/MemberService.java
index 75ae96d..f3bd2d6 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/MemberService.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/MemberService.java
@@ -73,6 +73,8 @@
      */
     void updateStatusById(Member member);
 
+    void updateVisitsStatusById(Member member);
+
     void updateCanVisitById(Member member);
     /**
      * 鎵归噺涓婚敭鏇存柊
@@ -148,6 +150,7 @@
      */
     PageData<MemberInfoDTO> findMemberInfoPage(PageWrap<MemberQuery> pageWrap);
 
+    PageData<MemberInfoDTO> findVisitPage(PageWrap<MemberQuery> pageWrap);
 
 
     /********************************************鍏紬鍙锋帴鍙�***********************************************************************/
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java
index a9e946f..fa224c3 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarsServiceImpl.java
@@ -2,10 +2,12 @@
 
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
+import com.doumee.core.utils.Constants;
 import com.doumee.core.utils.Utils;
 import com.doumee.dao.admin.request.CarsQuery;
 import com.doumee.dao.admin.response.CarsDTO;
 import com.doumee.dao.business.CarsMapper;
+import com.doumee.dao.business.join.CarJoinMapper;
 import com.doumee.dao.business.join.ParkBookJoinMapper;
 import com.doumee.dao.business.model.*;
 import com.doumee.service.business.CarsService;
@@ -30,6 +32,9 @@
 
     @Autowired
     private CarsMapper carsMapper;
+
+    @Autowired
+    private CarJoinMapper carJoinMapper;
 
     @Autowired
     private ParkBookJoinMapper parkBookJoinMapper;
@@ -93,6 +98,13 @@
 
     @Override
     public PageData<Cars> findPage(PageWrap<Cars> pageWrap) {
+
+        MPJLambdaWrapper<Cars> visRecord = new MPJLambdaWrapper<>();
+        visRecord.selectAll(Cars.class);
+        visRecord.eq(Cars::getIsdeleted, Constants.ZERO);
+        visRecord.eq(Cars::getId, Constants.ZERO);
+        Cars result = carJoinMapper.selectJoinOne(Cars.class,visRecord);
+
         IPage<Cars> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
         QueryWrapper<Cars> queryWrapper = new QueryWrapper<>();
         Utils.MP.blankToNull(pageWrap.getModel());
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
index 68aca87..2ef7904 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
@@ -24,6 +24,7 @@
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import io.swagger.annotations.ApiModelProperty;
 import org.apache.commons.collections.CollectionUtils;
+import org.apache.commons.lang3.StringUtils;
 import org.apache.shiro.SecurityUtils;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -83,7 +84,14 @@
 
     @Override
     public void deleteById(Integer id) {
-        companyMapper.deleteById(id);
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+
+        Company company=new Company();
+        company.setId(id);
+        company.setIsdeleted(Constants.ZERO);
+        company.setEditDate(new Date());
+        company.setEditor(loginUserInfo.getId());
+        companyMapper.updateById(company);
     }
 
     @Override
@@ -97,7 +105,17 @@
         if (CollectionUtils.isEmpty(ids)) {
             return;
         }
-        companyMapper.deleteBatchIds(ids);
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        Company company=new Company();
+
+      //  companyMapper.deleteBatchIds(ids);
+        ids.stream().forEach(s->{
+            company.setId(s);
+            company.setIsdeleted(Constants.ZERO);
+            company.setEditDate(new Date());
+            company.setEditor(loginUserInfo.getId());
+            companyMapper.updateById(company);
+        });
     }
 
     @Override
@@ -166,7 +184,7 @@
             queryWrapper.eq(Company::getIsdeleted, pageWrap.getModel().getIsdeleted());
         }
         if (pageWrap.getModel().getName() != null) {
-            queryWrapper.eq(Company::getName, pageWrap.getModel().getName());
+            queryWrapper.like(Company::getName, pageWrap.getModel().getName());
         }
         if (pageWrap.getModel().getRemark() != null) {
             queryWrapper.eq(Company::getRemark, pageWrap.getModel().getRemark());
@@ -239,18 +257,36 @@
             queryWrapper.le(Company::getFsDate, Utils.Date.getEnd(pageWrap.getModel().getFsDate()));
         }
         queryWrapper.orderByDesc(Company::getCreateDate);
-        queryWrapper.leftJoin(Category.class,Category::getId,Company::getCategoryId)
-                    .leftJoin(Member.class, Member::getId,Company::getHeadId);
+        queryWrapper.leftJoin(Category.class,Category::getId,Company::getCategoryId);
+        /*        .leftJoin(Member.class, Member::getId,Company::getHeadId)*/
+      /*  queryWrapper.leftJoin(" company c on c.id=t.parent_id");*/
         queryWrapper.selectAll(Company.class)
-                    .selectAs(Category::getName,Company::getCategoryName)
-                    .selectAs(Member::getName,Company::getHeadName)
+                .select("(select count(m.id) from member m where m.COMPANY_ID=t.id and m.ISDELETED=0) as countNum")
+                /*.select("c.name as parentName");*/
+                  .selectAs(Category::getName,Company::getCategoryName);
+                   /*   .selectAs(Member::getName,Company::getHeadName)
                     .selectAs(Member::getPhone,Company::getHeadPhone)
-                    .select("count(t1.id) as countNum");
+                    .select("count(t1.id) as countNum");*/
+        queryWrapper.eq(Company::getType,Constants.ZERO);
+        queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getStatus()),Company::getStatus,Constants.ZERO);
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()),Company::getName,pageWrap.getModel().getName());
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getParentName()),"c.name",pageWrap.getModel().getParentName());
         IPage<Company> companyIPage = companyJoinMapper.selectJoinPage(page, Company.class, queryWrapper);
         return PageData.from(companyIPage);
     }
 
     @Override
+    public void updateStatusById(Company company) {
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+
+        company.setEditDate(new Date());
+        company.setEditor(loginUserInfo.getId());
+        company.setStatus(company.getStatus());
+        companyMapper.updateById(company);
+    }
+
+
+    @Override
     public long count(Company company) {
         QueryWrapper<Company> wrapper = new QueryWrapper<>(company);
         return companyMapper.selectCount(wrapper);
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
index 983da41..8bdd4a9 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
@@ -28,6 +28,7 @@
 import com.doumee.dao.business.MemberMapper;
 import com.doumee.dao.business.TrainTimeMapper;
 import com.doumee.dao.business.join.MemberJoinMapper;
+import com.doumee.dao.business.join.UserActionJoinMapper;
 import com.doumee.dao.business.model.*;
 import com.doumee.dao.system.model.SystemUser;
 import com.doumee.dao.web.reqeust.CheckVisitedDTO;
@@ -70,6 +71,8 @@
 
     @Autowired
     private SystemDictDataBiz systemDictDataBiz;
+    @Autowired
+    private UserActionJoinMapper userActionJoinMapper;
 
     @Override
     public Integer create(Member member) {
@@ -119,7 +122,7 @@
         insert.setParentId(member.getParentId());
         memberMapper.insert(insert);
 
-        TrainTime trainTime = new TrainTime();
+    /*    TrainTime trainTime = new TrainTime();
         trainTime.setCreator(loginUserInfo.getId().toString());
         trainTime.setCreateDate(new Date());
         trainTime.setEdirot(loginUserInfo.getId().toString());
@@ -130,13 +133,20 @@
         trainTime.setEndTime(Utils.Date.getDayEnd(member.getEndTime()));
 //        trainTime.setImportStatus();
 //        trainTime.setImportInfo();
-        trainTimeMapper.insert(trainTime);
+        trainTimeMapper.insert(trainTime);*/
         return insert.getId();
     }
 
     @Override
     public void deleteById(Integer id) {
-        memberMapper.deleteById(id);
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+
+        Member member=new Member();
+        member.setId(id);
+        member.setIsdeleted(Constants.ZERO);
+        member.setEditor(loginUserInfo.getId());
+        member.setEditDate(new Date());
+        memberMapper.updateById(member);
     }
 
     @Override
@@ -150,7 +160,16 @@
         if (CollectionUtils.isEmpty(ids)) {
             return;
         }
-        memberMapper.deleteBatchIds(ids);
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        Member member=new Member();
+        ids.stream().forEach(s ->{
+            member.setId(s);
+            member.setIsdeleted(Constants.ZERO);
+            member.setEditor(loginUserInfo.getId());
+            member.setEditDate(new Date());
+            memberMapper.updateById(member);
+        });
+      /*  memberMapper.deleteBatchIds(ids);*/
     }
 
     @Override
@@ -167,6 +186,30 @@
         update.setStatus(member.getStatus());
         memberMapper.updateById(update);
     }
+
+
+    @Override
+    public void updateVisitsStatusById(Member member) {
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        Member result=memberMapper.selectById(member.getId());
+        Integer status=result.getStatus();
+        Member update = new Member();
+        update.setEditDate(new Date());
+        update.setEditor(loginUserInfo.getId());
+        update.setStatus(member.getStatus());
+        update.setId(member.getId());
+        memberMapper.updateById(update);
+
+        UserAction userAction=new UserAction();
+        userAction.setIsdeleted(Constants.ZERO);
+        userAction.setCreateDate(new Date());
+        userAction.setCreator(loginUserInfo.getId());
+        userAction.setType(Constants.TWO);
+        userAction.setMemberId(result.getId()+"");
+        userAction.setBeforeStatus(status);
+        userActionJoinMapper.insert(userAction);
+    }
+
 
 
     @Override
@@ -354,16 +397,17 @@
         MemberInfoDTO model = pageWrap.getModel();
         Utils.MP.blankToNull(model);
         Date end =pageWrap.getModel().getTrainTimeEndTime() !=null? Utils.Date.getEnd(pageWrap.getModel().getTrainTimeEndTime()):new Date();
-        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId)
-                .leftJoin(TrainTime.class,TrainTime::getMemberId,Member::getId)
-                .leftJoin(Empower.class,Empower::getMemberId,Member::getId);
+        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
+              /*  .leftJoin(TrainTime.class,TrainTime::getMemberId,Member::getId)
+                .leftJoin(Empower.class,Empower::getMemberId,Member::getId);*/
 
         queryWrapper.selectAll(Member.class)
                     .selectAs(Company::getName,MemberInfoDTO::getCompanyName)
                     .selectAs(Company::getLinkName,MemberInfoDTO::getLinkName)
-                    .select("Max(t1.endTime)","trainTimeEndTime")
-                    .select("Max(t2.endTime)","empowerEndTime");
+                /*.select(" (select Max(tt.END_TIME) from train_time tt where tt.ISDELETED=0 and tt.MEMBER_ID=t.id) as trainTimeEndTime")*/
+                .select(" (select Max(e.END_TIME) from empower e where e.ISDELETED=0 and e.MEMBER_ID=t.id) as empowerEndTime");
 
+        queryWrapper.eq(Member::getType,Constants.ZERO);
         queryWrapper.eq(Objects.nonNull(model.getCompanyId()),Member::getCompanyId,model.getCompanyId())
                     .like(StringUtils.isNotBlank(model.getName()),Member::getName,model.getName())
                     .like(StringUtils.isNotBlank(model.getPhone()),Member::getPhone,model.getPhone())
@@ -455,6 +499,32 @@
         return PageData.from(memberIPage);
     }
 
+
+    @Override
+    public PageData<MemberInfoDTO> findVisitPage(PageWrap<MemberQuery> pageWrap) {
+
+
+        IPage<Member> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
+        MPJLambdaWrapper<Member> queryWrapper = new MPJLambdaWrapper<>();
+        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
+        queryWrapper.selectAll(Member.class)
+                .selectAs(Company::getName,MemberInfoDTO::getCompanyName)
+                .select(" (select count(v.id) from visits v where v.MEMBER_ID=t.id and v.ISDELETED=0) as visitsCount")
+                .select(" (select STARTTIME from visits v where v.MEMBER_ID=t.id and v.ISDELETED=0 order by CREATE_DATE limit 1) as visitsLastDate");
+
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()),Member::getName,pageWrap.getModel().getName())
+                .like(StringUtils.isNotBlank(pageWrap.getModel().getPhone()),Member::getPhone,pageWrap.getModel().getPhone())
+                .like(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),Company::getName,pageWrap.getModel().getCompanyName())
+                .like(StringUtils.isNotBlank(pageWrap.getModel().getIdcardNo()),Member::getIdcardNo,pageWrap.getModel().getIdcardNo())
+                .eq(Member::getStatus,Constants.Status.ENABLE)
+                .orderByDesc(Member::getCreateDate);
+
+
+        IPage<MemberInfoDTO> memberIPage = memberJoinMapper.selectJoinPage(page, MemberInfoDTO.class,queryWrapper);
+        return PageData.from(memberIPage);
+
+    }
+
     /********************************************鍏紬鍙锋帴鍙�***********************************************************************/
 
 
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/TrainTimeServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/TrainTimeServiceImpl.java
index c5d18cc..0a7c27b 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/TrainTimeServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/TrainTimeServiceImpl.java
@@ -1,15 +1,23 @@
 package com.doumee.service.business.impl;
 
+import com.baomidou.mybatisplus.core.toolkit.Constants;
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Utils;
 import com.doumee.dao.business.TrainTimeMapper;
+import com.doumee.dao.business.join.TrainTimeJoinMapper;
+import com.doumee.dao.business.model.Company;
+import com.doumee.dao.business.model.Member;
 import com.doumee.dao.business.model.TrainTime;
+import com.doumee.dao.business.model.Visits;
+import com.doumee.dao.system.model.SystemUser;
 import com.doumee.service.business.TrainTimeService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
+import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.util.CollectionUtils;
@@ -26,6 +34,9 @@
 
     @Autowired
     private TrainTimeMapper trainTimeMapper;
+    @Autowired
+    private TrainTimeJoinMapper trainTimeJoinMapper;
+
 
 
 
@@ -89,54 +100,26 @@
     @Override
     public PageData<TrainTime> findPage(PageWrap<TrainTime> pageWrap) {
         IPage<TrainTime> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
-        QueryWrapper<TrainTime> queryWrapper = new QueryWrapper<>();
-        Utils.MP.blankToNull(pageWrap.getModel());
-        if (pageWrap.getModel().getId() != null) {
-            queryWrapper.lambda().eq(TrainTime::getId, pageWrap.getModel().getId());
-        }
-        if (pageWrap.getModel().getCreator() != null) {
-            queryWrapper.lambda().eq(TrainTime::getCreator, pageWrap.getModel().getCreator());
-        }
-        if (pageWrap.getModel().getCreateDate() != null) {
-            queryWrapper.lambda().ge(TrainTime::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
-            queryWrapper.lambda().le(TrainTime::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
-        }
-        if (pageWrap.getModel().getEdirot() != null) {
-            queryWrapper.lambda().eq(TrainTime::getEdirot, pageWrap.getModel().getEdirot());
-        }
-        if (pageWrap.getModel().getEditDate() != null) {
-            queryWrapper.lambda().ge(TrainTime::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
-            queryWrapper.lambda().le(TrainTime::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
-        }
-        if (pageWrap.getModel().getIsdeleted() != null) {
-            queryWrapper.lambda().eq(TrainTime::getIsdeleted, pageWrap.getModel().getIsdeleted());
-        }
-        if (pageWrap.getModel().getRemark() != null) {
-            queryWrapper.lambda().eq(TrainTime::getRemark, pageWrap.getModel().getRemark());
-        }
-        if (pageWrap.getModel().getMemberId() != null) {
-            queryWrapper.lambda().eq(TrainTime::getMemberId, pageWrap.getModel().getMemberId());
-        }
-        if (pageWrap.getModel().getStartTime() != null) {
-            queryWrapper.lambda().eq(TrainTime::getStartTime, pageWrap.getModel().getStartTime());
-        }
-        if (pageWrap.getModel().getEndTime() != null) {
-            queryWrapper.lambda().eq(TrainTime::getEndTime, pageWrap.getModel().getEndTime());
-        }
-        if (pageWrap.getModel().getImportStatus() != null) {
-            queryWrapper.lambda().eq(TrainTime::getImportStatus, pageWrap.getModel().getImportStatus());
-        }
-        if (pageWrap.getModel().getImportInfo() != null) {
-            queryWrapper.lambda().eq(TrainTime::getImportInfo, pageWrap.getModel().getImportInfo());
-        }
-        for(PageWrap.SortData sortData: pageWrap.getSorts()) {
-            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
-                queryWrapper.orderByDesc(sortData.getProperty());
-            } else {
-                queryWrapper.orderByAsc(sortData.getProperty());
-            }
-        }
-        return PageData.from(trainTimeMapper.selectPage(page, queryWrapper));
+        MPJLambdaWrapper<TrainTime> queryWrapper = new MPJLambdaWrapper<>();
+
+        queryWrapper.leftJoin(Member.class,Member::getId,TrainTime::getMemberId);
+        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
+        queryWrapper.leftJoin(SystemUser.class,SystemUser::getId,TrainTime::getCreator);
+
+        queryWrapper.selectAll(TrainTime.class);
+        queryWrapper.selectAs(Member::getName,TrainTime::getName);
+        queryWrapper.selectAs(Member::getPhone,TrainTime::getPhone);
+        queryWrapper.selectAs(Member::getIdcardNo,TrainTime::getIdcardNo);
+        queryWrapper.selectAs(Company::getName,TrainTime::getCompanyName);
+        queryWrapper.selectAs(SystemUser::getUsername,TrainTime::getCreateName);
+
+        queryWrapper.eq(TrainTime::getIsdeleted, Constants.ZERO);
+        queryWrapper.and(StringUtils.isNotBlank(pageWrap.getModel().getName()), ms->ms.like(Member::getPhone,pageWrap.getModel().getName())
+                .or().like(Member::getName,pageWrap.getModel().getName()));
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),Company::getName,pageWrap.getModel().getCompanyName());
+        queryWrapper.orderByDesc(TrainTime::getCreateDate);
+        IPage<TrainTime> result = trainTimeJoinMapper.selectJoinPage(page, TrainTime.class,queryWrapper);
+        return PageData.from(result);
     }
 
     @Override
diff --git a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
index c3f0a31..cd6e234 100644
--- a/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
+++ b/server/dmvisit_service/src/main/java/com/doumee/service/business/impl/VisitsServiceImpl.java
@@ -17,19 +17,20 @@
 import com.doumee.core.utils.DESUtil;
 import com.doumee.core.utils.DateUtil;
 import com.doumee.core.utils.Utils;
+import com.doumee.dao.admin.response.MemberInfoDTO;
 import com.doumee.dao.business.DeviceRoleMapper;
 import com.doumee.dao.business.MemberMapper;
 import com.doumee.dao.business.ProblemLogMapper;
 import com.doumee.dao.business.VisitsMapper;
-import com.doumee.dao.business.model.DeviceRole;
-import com.doumee.dao.business.model.Member;
-import com.doumee.dao.business.model.ProblemLog;
-import com.doumee.dao.business.model.Visits;
+import com.doumee.dao.business.join.DeviceJoinMapper;
+import com.doumee.dao.business.join.VisitsJoinMapper;
+import com.doumee.dao.business.model.*;
 import com.doumee.service.business.VisitsService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import org.apache.commons.lang3.StringUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
@@ -37,10 +38,7 @@
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.DigestUtils;
 
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
 
 /**
  * 璁垮鐢宠淇℃伅琛⊿ervice瀹炵幇
@@ -58,9 +56,15 @@
     private ProblemLogMapper problemLogMapper ;
     @Autowired
     private MemberMapper memberMapper ;
+    @Autowired
+    private VisitsJoinMapper visitsJoinMapper;
 
     @Autowired
     private SystemDictDataBiz systemDictDataBiz;
+    @Autowired
+    private DeviceJoinMapper deviceJoinMapper;
+
+
     @Override
     public Integer create(Visits visits) {
         visitsMapper.insert(visits);
@@ -445,7 +449,36 @@
 
     @Override
     public Visits findById(Integer id) {
-        return visitsMapper.selectById(id);
+
+        MPJLambdaWrapper<Visits> queryWrapper = new MPJLambdaWrapper<>();
+        queryWrapper.selectAll(Visits.class);
+        queryWrapper.selectAs(Member::getName,Visits::getReceptMemberName);
+        queryWrapper.selectAs(Company::getName,Visits::getReceptMemberDepartment);
+        queryWrapper.leftJoin(Member.class,Member::getId,Visits::getReceptMemberId);
+        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
+
+        queryWrapper.eq(Visits::getId,id);
+        Visits result = visitsJoinMapper.selectJoinOne(Visits.class,queryWrapper);
+
+        if(result!=null){
+            if(StringUtils.isNotBlank(result.getDoors())){
+                String[] doorList=result.getDoors().split(",");
+                MPJLambdaWrapper<Device> deviceQuery = new MPJLambdaWrapper<>();
+                deviceQuery.in(Device::getId,doorList);
+                List<Device> deviceList= deviceJoinMapper.selectList(deviceQuery);
+                result.setDeviceList(deviceList);
+            }
+        }
+
+        MPJLambdaWrapper<Visits> visitQuery = new MPJLambdaWrapper<>();
+        visitQuery.selectAll(Visits.class);
+        visitQuery.eq(Visits::getParentId,result.getId());
+        visitQuery.isNotNull(Visits::getParentId);
+        visitQuery.eq(Visits::getIsdeleted,Constants.ZERO);
+        List<Visits> visitsList = visitsJoinMapper.selectList(visitQuery);
+        visitsList.add(0,result);
+        result.setVisitsList(visitsList);
+        return result;
     }
 
     @Override
@@ -463,147 +496,25 @@
     @Override
     public PageData<Visits> findPage(PageWrap<Visits> pageWrap) {
         IPage<Visits> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
-        QueryWrapper<Visits> queryWrapper = new QueryWrapper<>();
-        Utils.MP.blankToNull(pageWrap.getModel());
-        if (pageWrap.getModel().getId() != null) {
-            queryWrapper.lambda().eq(Visits::getId, pageWrap.getModel().getId());
-        }
-        if (pageWrap.getModel().getCreator() != null) {
-            queryWrapper.lambda().eq(Visits::getCreator, pageWrap.getModel().getCreator());
-        }
-        if (pageWrap.getModel().getCreateDate() != null) {
-            queryWrapper.lambda().ge(Visits::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
-            queryWrapper.lambda().le(Visits::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
-        }
-        if (pageWrap.getModel().getEditor() != null) {
-            queryWrapper.lambda().eq(Visits::getEditor, pageWrap.getModel().getEditor());
-        }
-        if (pageWrap.getModel().getEditDate() != null) {
-            queryWrapper.lambda().ge(Visits::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
-            queryWrapper.lambda().le(Visits::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
-        }
-        if (pageWrap.getModel().getIsdeleted() != null) {
-            queryWrapper.lambda().eq(Visits::getIsdeleted, pageWrap.getModel().getIsdeleted());
-        }
-        if (pageWrap.getModel().getRemark() != null) {
-            queryWrapper.lambda().eq(Visits::getRemark, pageWrap.getModel().getRemark());
-        }
-        if (pageWrap.getModel().getMemberId() != null) {
-            queryWrapper.lambda().eq(Visits::getMemberId, pageWrap.getModel().getMemberId());
-        }
-        if (pageWrap.getModel().getCompanyId() != null) {
-            queryWrapper.lambda().eq(Visits::getCompanyId, pageWrap.getModel().getCompanyId());
-        }
-        if (pageWrap.getModel().getFaceImg() != null) {
-            queryWrapper.lambda().eq(Visits::getFaceImg, pageWrap.getModel().getFaceImg());
-        }
-        if (pageWrap.getModel().getImgurl() != null) {
-            queryWrapper.lambda().eq(Visits::getImgurl, pageWrap.getModel().getImgurl());
-        }
-        if (pageWrap.getModel().getType() != null) {
-            queryWrapper.lambda().eq(Visits::getType, pageWrap.getModel().getType());
-        }
-        if (pageWrap.getModel().getName() != null) {
-            queryWrapper.lambda().eq(Visits::getName, pageWrap.getModel().getName());
-        }
-        if (pageWrap.getModel().getBirthday() != null) {
-            queryWrapper.lambda().ge(Visits::getBirthday, Utils.Date.getStart(pageWrap.getModel().getBirthday()));
-            queryWrapper.lambda().le(Visits::getBirthday, Utils.Date.getEnd(pageWrap.getModel().getBirthday()));
-        }
-        if (pageWrap.getModel().getPhone() != null) {
-            queryWrapper.lambda().eq(Visits::getPhone, pageWrap.getModel().getPhone());
-        }
-        if (pageWrap.getModel().getCompanyName() != null) {
-            queryWrapper.lambda().eq(Visits::getCompanyName, pageWrap.getModel().getCompanyName());
-        }
-        if (pageWrap.getModel().getIdcardNo() != null) {
-            queryWrapper.lambda().eq(Visits::getIdcardNo, pageWrap.getModel().getIdcardNo());
-        }
-        if (pageWrap.getModel().getCode() != null) {
-            queryWrapper.lambda().eq(Visits::getCode, pageWrap.getModel().getCode());
-        }
-        if (pageWrap.getModel().getClasses() != null) {
-            queryWrapper.lambda().eq(Visits::getClasses, pageWrap.getModel().getClasses());
-        }
-        if (pageWrap.getModel().getMemberNum() != null) {
-            queryWrapper.lambda().eq(Visits::getMemberNum, pageWrap.getModel().getMemberNum());
-        }
-        if (pageWrap.getModel().getStarttime() != null) {
-            queryWrapper.lambda().ge(Visits::getStarttime, Utils.Date.getStart(pageWrap.getModel().getStarttime()));
-            queryWrapper.lambda().le(Visits::getStarttime, Utils.Date.getEnd(pageWrap.getModel().getStarttime()));
-        }
-        if (pageWrap.getModel().getEndtime() != null) {
-            queryWrapper.lambda().ge(Visits::getEndtime, Utils.Date.getStart(pageWrap.getModel().getEndtime()));
-            queryWrapper.lambda().le(Visits::getEndtime, Utils.Date.getEnd(pageWrap.getModel().getEndtime()));
-        }
-        if (pageWrap.getModel().getReason() != null) {
-            queryWrapper.lambda().eq(Visits::getReason, pageWrap.getModel().getReason());
-        }
-        if (pageWrap.getModel().getDoorSelect() != null) {
-            queryWrapper.lambda().eq(Visits::getDoorSelect, pageWrap.getModel().getDoorSelect());
-        }
-        if (pageWrap.getModel().getDoors() != null) {
-            queryWrapper.lambda().eq(Visits::getDoors, pageWrap.getModel().getDoors());
-        }
-        if (pageWrap.getModel().getReceptMemberId() != null) {
-            queryWrapper.lambda().eq(Visits::getReceptMemberId, pageWrap.getModel().getReceptMemberId());
-        }
-        if (pageWrap.getModel().getStatus() != null) {
-            queryWrapper.lambda().eq(Visits::getStatus, pageWrap.getModel().getStatus());
-        }
-        if (pageWrap.getModel().getCheckorId() != null) {
-            queryWrapper.lambda().eq(Visits::getCheckorId, pageWrap.getModel().getCheckorId());
-        }
-        if (pageWrap.getModel().getCheckDate() != null) {
-            queryWrapper.lambda().ge(Visits::getCheckDate, Utils.Date.getStart(pageWrap.getModel().getCheckDate()));
-            queryWrapper.lambda().le(Visits::getCheckDate, Utils.Date.getEnd(pageWrap.getModel().getCheckDate()));
-        }
-        if (pageWrap.getModel().getCheckInfo() != null) {
-            queryWrapper.lambda().eq(Visits::getCheckInfo, pageWrap.getModel().getCheckInfo());
-        }
-        if (pageWrap.getModel().getEndCheckorId() != null) {
-            queryWrapper.lambda().eq(Visits::getEndCheckorId, pageWrap.getModel().getEndCheckorId());
-        }
-        if (pageWrap.getModel().getEndCheckDate() != null) {
-            queryWrapper.lambda().ge(Visits::getEndCheckDate, Utils.Date.getStart(pageWrap.getModel().getEndCheckDate()));
-            queryWrapper.lambda().le(Visits::getEndCheckDate, Utils.Date.getEnd(pageWrap.getModel().getEndCheckDate()));
-        }
-        if (pageWrap.getModel().getEndCheckInfo() != null) {
-            queryWrapper.lambda().eq(Visits::getEndCheckInfo, pageWrap.getModel().getEndCheckInfo());
-        }
-        if (pageWrap.getModel().getIdcardType() != null) {
-            queryWrapper.lambda().eq(Visits::getIdcardType, pageWrap.getModel().getIdcardType());
-        }
-        if (pageWrap.getModel().getCarNos() != null) {
-            queryWrapper.lambda().eq(Visits::getCarNos, pageWrap.getModel().getCarNos());
-        }
-        if (pageWrap.getModel().getParentId() != null) {
-            queryWrapper.lambda().eq(Visits::getParentId, pageWrap.getModel().getParentId());
-        }
-        if (pageWrap.getModel().getUserAnswerId() != null) {
-            queryWrapper.lambda().eq(Visits::getUserAnswerId, pageWrap.getModel().getUserAnswerId());
-        }
-        if (pageWrap.getModel().getHkId() != null) {
-            queryWrapper.lambda().eq(Visits::getHkId, pageWrap.getModel().getHkId());
-        }
-        if (pageWrap.getModel().getHkStatus() != null) {
-            queryWrapper.lambda().eq(Visits::getHkStatus, pageWrap.getModel().getHkStatus());
-        }
-        if (pageWrap.getModel().getHkDate() != null) {
-            queryWrapper.lambda().ge(Visits::getHkDate, Utils.Date.getStart(pageWrap.getModel().getHkDate()));
-            queryWrapper.lambda().le(Visits::getHkDate, Utils.Date.getEnd(pageWrap.getModel().getHkDate()));
-        }
-        if (pageWrap.getModel().getErpId() != null) {
-            queryWrapper.lambda().eq(Visits::getErpId, pageWrap.getModel().getErpId());
-        }
-        for(PageWrap.SortData sortData: pageWrap.getSorts()) {
-            if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
-                queryWrapper.orderByDesc(sortData.getProperty());
-            } else {
-                queryWrapper.orderByAsc(sortData.getProperty());
-            }
-        }
-        return PageData.from(visitsMapper.selectPage(page, queryWrapper));
+        MPJLambdaWrapper<Visits> queryWrapper = new MPJLambdaWrapper<>();
+
+        queryWrapper.selectAll(Visits.class);
+        queryWrapper.selectAs(Member::getName,Visits::getReceptMemberName);
+        queryWrapper.selectAs(Company::getName,Visits::getReceptMemberDepartment);
+        queryWrapper.leftJoin(Member.class,Member::getId,Visits::getReceptMemberId);
+        queryWrapper.leftJoin(Company.class,Company::getId,Member::getCompanyId);
+
+        queryWrapper.eq(Visits::getIsdeleted,Constants.ZERO);
+        queryWrapper.eq(Objects.nonNull(pageWrap.getModel().getType()),Visits::getType,pageWrap.getModel().getType());
+        queryWrapper.and(StringUtils.isNotBlank(pageWrap.getModel().getName()),ms->ms.like(Visits::getPhone,pageWrap.getModel().getName())
+                .or().like(Visits::getPhone,pageWrap.getModel().getName()))
+                .eq(StringUtils.isNotBlank(pageWrap.getModel().getIdcardNo()),Visits::getIdcardNo,StringUtils.isNotBlank(pageWrap.getModel().getIdcardNo()))
+                .eq(StringUtils.isNotBlank(pageWrap.getModel().getCompanyName()),Visits::getCompanyName,pageWrap.getModel().getCompanyName())
+                .eq(Objects.nonNull(pageWrap.getModel().getStatus()),Visits::getStatus,pageWrap.getModel().getStatus());
+        queryWrapper.isNull(Visits::getParentId);
+        queryWrapper.orderByDesc(Visits::getCreateDate);
+        IPage<Visits> result = visitsJoinMapper.selectJoinPage(page, Visits.class,queryWrapper);
+        return PageData.from(result);
     }
 
     @Override

--
Gitblit v1.9.3