From 440f3671c552a58d9a911dbe184b583e3d17be16 Mon Sep 17 00:00:00 2001
From: renkang <8417338+k94314517@user.noreply.gitee.com>
Date: 星期六, 30 十一月 2024 16:13:48 +0800
Subject: [PATCH] 客户资料 巡检任务业务

---
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java |   97 +++++++++++++++++++++++++++++++++++-------------
 1 files changed, 70 insertions(+), 27 deletions(-)

diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
index d2da52a..4795aa6 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
@@ -33,6 +33,7 @@
 import java.math.BigDecimal;
 import java.time.temporal.ChronoUnit;
 import java.util.*;
+import java.util.stream.Collectors;
 
 /**
  * 杩愮淮鍚堝悓淇℃伅琛⊿ervice瀹炵幇
@@ -311,6 +312,9 @@
         update.setBtFee(param.getBtFee());
         update.setBtRemark(getbackRentRemarkByParam(param));
         ywContractMapper.updateById(update);
+//        if(1==1){
+//            throw new BusinessException(ResponseStatus.NOT_ALLOWED);
+//        }
         dealLogBiz(param,Constants.YwLogType.CONTRACT_BACK, param.getLoginUserInfo().getRealname(),getbackRentLogByParam(param));
         return param.getId();
     }
@@ -348,7 +352,7 @@
         List<YwContractBill> canBills = new ArrayList<>();//鍙��绉熶慨鏀规暟鎹�
         List<YwContractBill> allBills = ywContractBillMapper.selectList(new QueryWrapper<YwContractBill>().
                 select("*," +
-                        "( select ifnull(sum(yw.ACT_RECEIVABLE_FEE),0) from  yw_contract_revenue yw where yw.bill_id = yw_contract_bill.id and yw.status = 0 and yw.isdeleted = 0 ) as  actReceivableFee " )
+                        "( select ifnull(sum(case when yw.REVENUE_TYPE = 0 then yw.ACT_RECEIVABLE_FEE  else  -yw.ACT_RECEIVABLE_FEE end),0) from  yw_contract_revenue yw where yw.bill_id = yw_contract_bill.id and yw.status = 0 and yw.isdeleted = 0 ) as  actReceivableFee " )
                 .lambda().
                 eq(YwContractBill::getIsdeleted,Constants.ZERO)
                 .eq(YwContractBill::getContractId,param.getId()));
@@ -365,15 +369,23 @@
                 }
                 if(Constants.equalsInteger(bill.getPayStatus(),Constants.ZERO)
                         ||Constants.equalsInteger(bill.getPayStatus(),Constants.THREE)){
-                    if(bill.getStartDate().getTime()>param.getEditDate().getTime()){
+                    if(bill.getStartDate().getTime()<param.getBtDate().getTime()){
+                        canBills.add(bill);
+                    }else{
                         //濡傛灉杩樻病寮�濮嬶紝璐﹀崟鐩存帴鍏抽棴
                         closeBills.add(bill);
                         noBills.add(bill);
-                    }else{
-                        canBills.add(bill);
                     }
+//                    if(bill.getStartDate().getTime()>param.getEditDate().getTime()){
+//                        //濡傛灉杩樻病寮�濮嬶紝璐﹀崟鐩存帴鍏抽棴
+//                        closeBills.add(bill);
+//                        noBills.add(bill);
+//                    }else{
+//                        canBills.add(bill);
+//                    }
                 }else  if(Constants.equalsInteger(bill.getPayStatus(),Constants.ONE) ){
-                    if(bill.getEndDate().getTime()<param.getEditDate().getTime()){
+                    if(bill.getStartDate().getTime()>param.getBtDate().getTime()){
+//                    if(bill.getEndDate().getTime()<param.getEditDate().getTime()){
                         //濡傛灉宸茬粨娓咃紝璐﹀崟鐩存帴鍏抽棴
                         noBills.add(bill);
                     }else{
@@ -394,16 +406,7 @@
                 ywContractBillMapper.updateById(b);
             }
         }
-        int yjNoBills =0;
-        if(yjBills.size()>0){
-            // 濡傛灉鏄娂閲戞垨鑰呬繚璇侀噾锛屼笉鏀寔閫�娆撅紝淇濇寔鍘熸潵鐨勭姸鎬侊紝 0=绉熻祦璐癸紱1=鐗╀笟璐癸紱2=绉熻祦鎶奸噾锛�3=鐗╀笟鎶奸噾锛�4=姘寸數璐癸紱5=鏉傞」璐癸紱6=鍏朵粬;7=淇濊瘉閲�
-            for(YwContractBill bill : yjBills){
-               if(!Constants.equalsInteger(bill.getPayStatus(),Constants.ONE) ){
-                   //濡傛灉鏄湭缁撴竻鎶奸噾
-                   yjNoBills ++;
-               }
-            }
-        }
+
         BigDecimal totalBackFee = new BigDecimal(0);
         if(canBills.size()>0){
             //鐩存帴鍏抽棴鍏抽棴璐﹀崟
@@ -416,14 +419,15 @@
                     fee = Constants.formatBigdecimal(b.getActReceivableFee()).subtract(editBill.getReceivableFee());
                     if(fee.compareTo(new BigDecimal(0))== 0){
                         //濡傛灉璐圭敤姝eソ锛屽垯淇敼璐﹀崟淇℃伅涓哄凡缁撴竻
-                        b.setStatus(Constants.ONE);
+                        b.setPayStatus(Constants.ONE);
                     }else if(fee.compareTo(new BigDecimal(0))> 0){
                         //濡傛灉闇�瑕佽繘琛岄��娆撅紝鏇存柊璐﹀崟淇℃伅涓哄緟閫�娆�
-                        b.setStatus(Constants.FOUR);
+                        b.setPayStatus(Constants.FOUR);
                     }else if(fee.compareTo(new BigDecimal(0)) < 0){
                         //濡傛灉璐﹀崟杩樻湁娆惧緟鏀讹紝鍒欎繚鎸佺姸鎬佷笉鍙�
                     }
                 }
+                b.setReceivableFee(editBill.getReceivableFee());
                 b.setEditDate(param.getEditDate());
                 b.setEditor(param.getEditor());
                 b.setBtActDate(param.getBtActDate());
@@ -444,6 +448,10 @@
                 addBill.setContractId(param.getId());
                 addBill.setType(Constants.ONE);
                 addBill.setStatus(Constants.ZERO);
+                if(Constants.equalsInteger(addBill.getFeeType(),Constants.ONE)){
+                    addBill.setStartDate(addBill.getPlanPayDate());
+                    addBill.setEndDate(addBill.getPlanPayDate());
+                }
                 if(Constants.equalsInteger(addBill.getBillType(),Constants.ZERO)){
                     //濡傛灉鏄敹娆�
                     totalBackFee = totalBackFee.add(Constants.formatBigdecimal(addBill.getActReceivableFee()));
@@ -466,6 +474,28 @@
                 newBills.add(addBill);
             }
             ywContractBillMapper.insert(param.getAddBillList());//鎵归噺鎻掑叆鏁版嵁
+        }
+
+        int yjNoBills =0;
+        if(yjBills.size()>0){
+            // 濡傛灉鏄娂閲戞垨鑰呬繚璇侀噾锛屼笉鏀寔閫�娆撅紝淇濇寔鍘熸潵鐨勭姸鎬侊紝 0=绉熻祦璐癸紱1=鐗╀笟璐癸紱2=绉熻祦鎶奸噾锛�3=鐗╀笟鎶奸噾锛�4=姘寸數璐癸紱5=鏉傞」璐癸紱6=鍏朵粬;7=淇濊瘉閲�
+            for(YwContractBill bill : yjBills){
+                if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(param.getCanBackRentBills())){
+                    List<YwContractBill> optional = param.getCanBackRentBills().stream().filter(i->Constants.equalsInteger(bill.getId(),i.getId())).collect(Collectors.toList());
+                    if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(optional)){
+                        YwContractBill canBill = optional.get(Constants.ZERO);
+                        YwContractBill yjBill = new YwContractBill();
+                        yjBill.setId(bill.getId());
+                        yjBill.setEditDate(param.getEditDate());
+                        yjBill.setEditor(param.getEditor());
+                        yjBill.setReceivableFee(BigDecimal.ZERO);
+                        yjBill.setPayStatus(Constants.FOUR);
+                        yjBill.setPlanPayDate(canBill.getPlanPayDate());
+                        ywContractBillMapper.updateById(yjBill);
+                    }
+                }
+                yjNoBills ++;
+            }
         }
         param.setBtWaitBill(canBills.size() + newBills.size()+yjNoBills);//鏈竻绠楃殑璐﹀崟鏁伴噺
         param.setBtCLoseBill(closeBills.size());
@@ -649,7 +679,10 @@
         bill.setType(Constants.ZERO);
         bill.setCostType(type);
         bill.setPlanPayDate(bill.getStartDate());
-        bill.setTotleFee(type==Constants.THREE?model.getZlDeposit():model.getWyDeposit());//鎶奸噾璐圭敤
+        bill.setTotleFee(type==Constants.TWO?
+                Objects.isNull(model.getZlDeposit())?BigDecimal.ZERO:model.getZlDeposit()
+                :
+                Objects.isNull(model.getWyDeposit())?BigDecimal.ZERO:model.getWyDeposit());//鎶奸噾璐圭敤
         bill.setReceivableFee(bill.getTotleFee());
         bill.setBillType(Constants.ZERO);
         bill.setPayStatus(Constants.ZERO);
@@ -762,14 +795,10 @@
             bill.setTotleFee(totalFee);
             bill.setReceivableFee(totalFee);
             bill.setBillType(Constants.ZERO);
-
-
             bill.setCompanyId(model.getCompanyId());
             list.add(bill);
         }
     }
-
-
     private BigDecimal getTotalFeeByStartEnd(YwContract model, YwContractDetail d, YwContractBill bill,Date freeStart,Date freeEnd) {
         BigDecimal totalFee = new BigDecimal(0);
         DateCompare dateCompare =   DateCompare.dayCompare(bill.getStartDate(),DateUtil.addDaysToDate(bill.getEndDate(),1),freeStart,DateUtil.addDaysToDate(freeEnd,1));
@@ -1206,9 +1235,15 @@
             //鏌ヨ璐﹀崟闆嗗悎
             model.setBillList(ywContractBillMapper.selectJoinList(YwContractBill.class,new MPJLambdaWrapper<YwContractBill>()
                             .selectAll(YwContractBill.class )
+                            .select(" ( select ifnull(sum(case when yw.REVENUE_TYPE = 0 then yw.ACT_RECEIVABLE_FEE  else  -yw.ACT_RECEIVABLE_FEE end),0) from  yw_contract_revenue yw where yw.bill_id = t.id and yw.status = 0 and yw.isdeleted = 0 ) as  actReceivableFee  ")
                             .eq(  YwContractBill::getContractId,model.getId())
                             .eq(YwContractBill::getIsdeleted,Constants.ZERO)
                             .orderByAsc(YwContractBill::getSortnum,YwContractBill::getCreateDate)));
+
+            for (YwContractBill ywContractBill:model.getBillList()) {
+                ywContractBill.setNeedReceivableFee(ywContractBill.getReceivableFee().subtract(ywContractBill.getActReceivableFee()));
+            }
+
             model.setCanBackRentBills(new ArrayList<>());
             long nowStart = Utils.Date.getStart(new Date()).getTime();
             long nowEnd = Utils.Date.getEnd(new Date()).getTime();
@@ -1226,7 +1261,7 @@
                     }else  if(Constants.equalsInteger(bill.getPayStatus(),Constants.ONE) ){
                         if(bill.getEndDate().getTime()<nowStart){
                             //濡傛灉宸茬粨娓咃紝璐﹀崟鐩存帴鍏抽棴
-                          continue;
+                            continue;
                         }
                         model.getCanBackRentBills().add(bill);
                     }else  if(Constants.equalsInteger(bill.getPayStatus(),Constants.TWO) ){
@@ -1248,10 +1283,18 @@
 
     @Override
     public List<YwContract> findList(YwContract ywContract) {
-        QueryWrapper<YwContract> wrapper = new QueryWrapper<>();
-        wrapper.lambda().eq(YwContract::getIsdeleted,Constants.ZERO);
-        wrapper.lambda().in(YwContract::getStatus,Constants.ZERO,Constants.ONE,Constants.TWO);
-        return ywContractMapper.selectList(wrapper);
+        return ywContractMapper.selectJoinList(YwContract.class,new MPJLambdaWrapper<YwContract>().selectAll(YwContract.class )
+                .selectAs(Company::getName,YwContract::getCompanyName )
+                .selectAs(SystemUser::getRealname,YwContract::getUserName )
+                .selectAs(YwCustomer::getName,YwContract::getRenterName )
+                .selectAs(YwProject::getName,YwContract::getProjectName )
+                .leftJoin(Company.class,Company::getId,YwContract::getCompanyId)
+                .leftJoin(SystemUser.class,SystemUser::getId,YwContract::getUserId)
+                .leftJoin(SystemUser.class,SystemUser::getId,YwContract::getCreator)
+                .leftJoin(YwProject.class,YwProject::getId,YwContract::getProjectId)
+                .leftJoin(YwCustomer.class,YwCustomer::getId,YwContract::getRenterId)
+                .eq(YwContract::getIsdeleted,Constants.ZERO)
+                .in(YwContract::getStatus,Constants.ZERO,Constants.ONE,Constants.TWO));
     }
   
     @Override

--
Gitblit v1.9.3