From 56d111945916746dd9a2486665bf3be6eb58bdf7 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 28 五月 2024 18:28:14 +0800
Subject: [PATCH] 最新版本

---
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarUseBookServiceImpl.java |   73 ++++++++++++++++++++++++++++--------
 1 files changed, 57 insertions(+), 16 deletions(-)

diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarUseBookServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarUseBookServiceImpl.java
index 2479504..04afebc 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarUseBookServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CarUseBookServiceImpl.java
@@ -10,12 +10,16 @@
 import com.doumee.core.utils.DESUtil;
 import com.doumee.core.utils.DateUtil;
 import com.doumee.core.utils.Utils;
+import com.doumee.dao.business.ApproveMapper;
 import com.doumee.dao.business.CarUseBookMapper;
 import com.doumee.dao.business.CarsMapper;
+import com.doumee.dao.business.join.ApproveJoinMapper;
 import com.doumee.dao.business.join.CarUseBookJoinMapper;
 import com.doumee.dao.business.model.*;
 import com.doumee.dao.business.vo.DateIntervalVO;
 import com.doumee.dao.system.model.SystemDictData;
+import com.doumee.dao.system.model.SystemUser;
+import com.doumee.service.business.ApproveService;
 import com.doumee.service.business.CarUseBookService;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
@@ -56,6 +60,12 @@
 
     @Autowired
     private SystemDictDataBiz systemDictDataBiz;
+
+    @Autowired
+    private ApproveJoinMapper approveJoinMapper;
+
+    @Autowired
+    private ApproveService approveService;
 
 
     @Override
@@ -103,6 +113,8 @@
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀛樺湪杞﹁締棰勭害鏃堕棿涓庡凡棰勭害鏃堕棿鍐茬獊~");
         }
         carUseBookMapper.insert(carUseBook);
+        //鐢ㄨ溅鐢宠 瀹℃壒璁板綍鍒涘缓
+        approveService.createApproveFlow(carUseBook.getType()==0?3:4,carUseBook.getId(),carUseBook.getMemberId());
         return carUseBook.getId();
     }
 
@@ -140,21 +152,32 @@
         }
     }
 
+    /**
+     *
+     * @param id 涓婚敭
+     * @param memberId
+     * @return
+     */
     @Override
-    public CarUseBook findById(Integer id) {
+    public CarUseBook findById(Integer id,Integer memberId) {
         MPJLambdaWrapper<CarUseBook>  queryWrapper = new MPJLambdaWrapper<>();
         queryWrapper.selectAll(CarUseBook.class);
         queryWrapper.select("t1.name",CarUseBook::getMemberName);
         queryWrapper.select("t1.phone",CarUseBook::getMemberPhone);
         queryWrapper.select("t2.name",CarUseBook::getDriverName);
-        queryWrapper.select("t3.phone",CarUseBook::getDriverPhone);
+        queryWrapper.select("t2.phone",CarUseBook::getDriverPhone);
         queryWrapper.select("t4.company_name_path",CarUseBook::getCompanyName);
         queryWrapper.leftJoin(Member.class,Member::getId,CarUseBook::getMemberId)
-                .leftJoin("company t4 on t1.company_id=t4.id")
                 .leftJoin(Member.class,Member::getId,CarUseBook::getDriverId)
+                .leftJoin("company t4 on t1.company_id=t4.id")
                 .eq(CarUseBook::getId,id)
                 .last("limit 1"  );
         CarUseBook model = carUseBookMapper.selectJoinOne(CarUseBook.class,queryWrapper);
+        model.setApproveDateVO(
+               approveService.arrangeApprovedData(id,
+                       model.getType().equals(Constants.ZERO)?3:4,
+                       memberId)
+        );
         return  model;
     }
 
@@ -180,11 +203,11 @@
         queryWrapper.select("t1.name",CarUseBook::getMemberName);
         queryWrapper.select("t1.phone",CarUseBook::getMemberPhone);
         queryWrapper.select("t2.name",CarUseBook::getDriverName);
-        queryWrapper.select("t3.phone",CarUseBook::getDriverPhone);
+        queryWrapper.select("t2.phone",CarUseBook::getDriverPhone);
         queryWrapper.select("t4.company_name_path",CarUseBook::getCompanyName);
         queryWrapper.leftJoin(Member.class,Member::getId,CarUseBook::getMemberId)
-                    .leftJoin("company t4 on t1.company_id=t4.id")
-                    .leftJoin(Member.class,Member::getId,CarUseBook::getDriverId);
+                    .leftJoin(Member.class,Member::getId,CarUseBook::getDriverId)
+                    .leftJoin("company t4 on t1.company_id=t4.id");
         queryWrapper
                 .eq(pageWrap.getModel().getId() != null, CarUseBook::getId, pageWrap.getModel().getId())
                 .eq(pageWrap.getModel().getCreator() != null, CarUseBook::getCreator, pageWrap.getModel().getCreator())
@@ -207,10 +230,8 @@
                 .le(pageWrap.getModel().getCheckDate() != null, CarUseBook::getCheckDate, Utils.Date.getEnd(pageWrap.getModel().getCheckDate()))
                 .eq(pageWrap.getModel().getCheckUserId() != null, CarUseBook::getCheckUserId, pageWrap.getModel().getCheckUserId())
                 .eq(pageWrap.getModel().getCheckInfo() != null, CarUseBook::getCheckInfo, pageWrap.getModel().getCheckInfo())
-                .ge(pageWrap.getModel().getCancelType() != null, CarUseBook::getCancelType, Utils.Date.getStart(pageWrap.getModel().getCancelType()))
-                .le(pageWrap.getModel().getCancelType() != null, CarUseBook::getCancelType, Utils.Date.getEnd(pageWrap.getModel().getCancelType()))
-                .ge(pageWrap.getModel().getCancelStatus() != null, CarUseBook::getCancelStatus, Utils.Date.getStart(pageWrap.getModel().getCancelStatus()))
-                .le(pageWrap.getModel().getCancelStatus() != null, CarUseBook::getCancelStatus, Utils.Date.getEnd(pageWrap.getModel().getCancelStatus()))
+                .eq(pageWrap.getModel().getCancelType() != null, CarUseBook::getCancelType,  pageWrap.getModel().getCancelType())
+                .eq(pageWrap.getModel().getCancelStatus() != null, CarUseBook::getCancelStatus, pageWrap.getModel().getCancelStatus())
                 .ge(pageWrap.getModel().getCancelTime() != null, CarUseBook::getCancelTime, Utils.Date.getStart(pageWrap.getModel().getCancelTime()))
                 .le(pageWrap.getModel().getCancelTime() != null, CarUseBook::getCancelTime, Utils.Date.getEnd(pageWrap.getModel().getCancelTime()))
                 .eq(pageWrap.getModel().getCancelUser() != null, CarUseBook::getCancelUser, pageWrap.getModel().getCancelUser())
@@ -222,6 +243,7 @@
                 .eq(pageWrap.getModel().getAddr() != null, CarUseBook::getAddr, pageWrap.getModel().getAddr())
                 .eq(pageWrap.getModel().getMemberId() != null, CarUseBook::getMemberId, pageWrap.getModel().getMemberId())
                 .eq(pageWrap.getModel().getDriverId() != null, CarUseBook::getDriverId, pageWrap.getModel().getDriverId())
+                .apply(pageWrap.getModel().getCompanyName() != null, "t4.company_name_path like '%"+pageWrap.getModel().getCompanyName()+"%'")
                 .and(StringUtils.isNotBlank(pageWrap.getModel().getQueryDate()),
                         i->i.and(j->j.lt(CarUseBook::getStartTime,pageWrap.getModel().getQueryDate() +"00:00:00").gt(CarUseBook::getStartTime,pageWrap.getModel().getQueryDate() +"23:59:59"))
                         .or()
@@ -233,8 +255,8 @@
                 )
                 .and(StringUtils.isNotBlank(pageWrap.getModel().getMemberName()), ms->ms.like(Member::getName,pageWrap.getModel().getMemberName())
                         .or().like(Member::getPhone,pageWrap.getModel().getMemberName()))
-                .ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), Empower::getCreateDate,pageWrap.getModel().getQueryStartTime())
-                .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()),Empower::getCreateDate,pageWrap.getModel().getQueryEndTime())
+                .ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), CarUseBook::getPlanUseDate,pageWrap.getModel().getQueryStartTime())
+                .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()),CarUseBook::getPlanUseDate,pageWrap.getModel().getQueryEndTime())
                 .orderByDesc(Visits::getCreateDate)
         ;
         for(PageWrap.SortData sortData: pageWrap.getSorts()) {
@@ -377,11 +399,30 @@
     }
 
 
-    public void revoke(Integer id, LoginUserInfo loginUserInfo){
+    @Override
+    public void revoke(Integer id, String info, LoginUserInfo loginUserInfo){
        CarUseBook carUseBook = carUseBookMapper.selectById(id);
-
-
-
+       if(Objects.isNull(carUseBook)){
+           throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"鏈煡璇㈠埌鐢ㄨ溅鐢宠淇℃伅");
+       }
+       carUseBook.setCancelInfo(info);
+       carUseBook.setCancelTime(new Date());
+       carUseBook.setCancelStatus(Constants.ONE);
+       carUseBook.setStatus(Constants.FOUR);
+       carUseBook.setCancelUser(loginUserInfo.getId());
+       carUseBook.setCancelType(Constants.ONE);
+       if(loginUserInfo.getId().equals(carUseBook.getCreator())){
+           carUseBook.setCancelType(Constants.ZERO);
+       }
+       carUseBookMapper.updateById(carUseBook);
+       //澶勭悊瀹℃壒璁板綍
+       approveJoinMapper.update(null,new UpdateWrapper<Approve>()
+                .lambda()
+                .set(Approve::getStatus,Constants.FOUR)
+                .set(Approve::getCheckInfo,"鐢ㄨ溅鐢宠鍙栨秷")
+                .in(Approve::getStatus,Constants.ZERO,Constants.ONE)
+                .eq(Approve::getObjId,id)
+        );
     }
 
 

--
Gitblit v1.9.3