| package com.doumee.service.business.impl; | 
|   | 
| import com.doumee.core.constants.ResponseStatus; | 
| import com.doumee.core.exception.BusinessException; | 
| import com.doumee.core.model.LoginUserInfo; | 
| import com.doumee.core.model.PageData; | 
| import com.doumee.core.model.PageWrap; | 
| import com.doumee.core.utils.Constants; | 
| import com.doumee.core.utils.DateCompare; | 
| import com.doumee.core.utils.DateUtil; | 
| import com.doumee.core.utils.Utils; | 
| import com.doumee.dao.business.*; | 
| import com.doumee.dao.business.dao.CompanyMapper; | 
| import com.doumee.dao.business.model.*; | 
| import com.doumee.dao.system.MultifileMapper; | 
| import com.doumee.dao.system.SystemUserMapper; | 
| import com.doumee.dao.system.model.Multifile; | 
| import com.doumee.dao.system.model.SystemUser; | 
| import com.doumee.service.business.YwContractService; | 
| 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.checkerframework.checker.units.qual.C; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.transaction.annotation.Transactional; | 
| import org.springframework.util.CollectionUtils; | 
|   | 
| import java.math.BigDecimal; | 
| import java.time.temporal.ChronoUnit; | 
| import java.util.*; | 
|   | 
| /** | 
|  * 运维合同信息表Service实现 | 
|  * @author 江蹄蹄 | 
|  * @date 2024/11/19 16:07 | 
|  */ | 
| @Service | 
| public class YwContractServiceImpl implements YwContractService { | 
|   | 
|     @Autowired | 
|     private YwContractMapper ywContractMapper; | 
|     @Autowired | 
|     private YwContractDetailMapper ywContractDetailMapper; | 
|     @Autowired | 
|     private YwContractBillMapper ywContractBillMapper; | 
|     @Autowired | 
|     private MultifileMapper multifileMapper; | 
|     @Autowired | 
|     private CompanyMapper companyMapper; | 
|     @Autowired | 
|     private YwProjectMapper projectMapper; | 
|     @Autowired | 
|     private YwRoomMapper roomMapper; | 
|     @Autowired | 
|     private SystemUserMapper systemUserMapper; | 
|     @Autowired | 
|     private YwCustomerMapper customerMapper; | 
|     @Autowired | 
|     private MemberMapper memberMapper; | 
|   | 
|     @Override | 
|     @Transactional(rollbackFor = {BusinessException.class,Exception.class}) | 
|     public Integer create(YwContract model) { | 
|         isParamValidCreated(model); | 
|   | 
|         model.setCreator(model.getLoginUserInfo().getId()); | 
|         model.setIsdeleted(Constants.ZERO); | 
|         model.setCreateDate(new Date()); | 
|         model.setStatus(Constants.ZERO); | 
|         model.setEditDate(model.getCreateDate()); | 
|         model.setEditor(model.getCreator()); | 
|         model.setStatus(Constants.ZERO);//待执行 | 
|         ywContractMapper.insert(model); | 
|         dealDetailListBiz(model);//处理条款信息 | 
|         dealMultifileBiz(model);//处理附件信息 | 
|         return model.getId(); | 
|     } | 
|   | 
|     private void dealDetailListBiz(YwContract model) { | 
|         List<YwContractDetail> details = new ArrayList<>(); | 
|         int num = 0; | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.ONE)){ | 
|             for(YwContractDetail d :model.getZlDetailList()){ | 
|                d.setCreateDate(model.getEditDate()); | 
|                d.setCreator(model.getEditor()); | 
|                d.setIsdeleted(Constants.ZERO); | 
|                d.setContractId(model.getId()); | 
|                d.setType(Constants.ZERO); | 
|                d.setSortnum(num++); | 
|                d.setStatus(Constants.ZERO); | 
|                details.add(d); | 
|             } | 
|         } | 
|         num = 0; | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.TWO)){ | 
|             for(YwContractDetail d :model.getWyDetailList()){ | 
|                 d.setCreateDate(model.getEditDate()); | 
|                 d.setCreator(model.getEditor()); | 
|                 d.setIsdeleted(Constants.ZERO); | 
|                 d.setType(Constants.ONE); | 
|                 d.setContractId(model.getId()); | 
|                 d.setSortnum(num++); | 
|                 d.setStatus(Constants.ZERO); | 
|                 details.add(d); | 
|             } | 
|         } | 
|         ywContractDetailMapper.insert(details);//批量插入条款信息信息 | 
|         //处理账单信息 | 
|         dealBillListBiz(model,details); | 
|     } | 
|   | 
|     /** | 
|      * 支付方式 0=一次性付款;1=每三个月一付;2=六个月一付;3=一年一付 | 
|      * @param model | 
|      * @param details | 
|      */ | 
|     private void dealBillListBiz(YwContract model, List<YwContractDetail> details) { | 
|         List<YwContractBill> billList = new ArrayList<>(); | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.ONE)){ | 
|             //如果有租赁条款 | 
|             if(Constants.formatBigdecimal(model.getZlDeposit()).compareTo(new BigDecimal(0))>0){ | 
|                     //如果有租赁押金 | 
|                 billList.add(initDepoistBill(Constants.THREE,model)); | 
|             } | 
|             if(Constants.equalsInteger(model.getZlPayType(), Constants.ZERO)){ | 
|                 //如果是一次性付清 | 
|                 billList.addAll(getBillsByParamOnce(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.ONE)){ | 
|                 //如果每三个月一付 | 
|                 billList.addAll(getBillsByParam3Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.TWO)){ | 
|                 //如果六个月一付 | 
|                 billList.addAll(getBillsByParam6Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.THREE)){ | 
|                 //如果一年一付 | 
|                 billList.addAll(getBillsByParam1Year(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate())); | 
|             } | 
|         } | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.TWO)){ | 
|             //如果物业条款 | 
|             if(Constants.formatBigdecimal(model.getWyDeposit()).compareTo(new BigDecimal(0))>0){ | 
|                 //如果有租赁押金 | 
|                 billList.add(initDepoistBill(Constants.FOUR,model)); | 
|             } | 
|             if(Constants.equalsInteger(model.getWyPayType(), Constants.ZERO)){ | 
|                 //如果是一次性付清 | 
|                 billList.addAll(getBillsByParamOnce(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.ONE)){ | 
|                 //如果每三个月一付 | 
|                 billList.addAll(getBillsByParam3Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.TWO)){ | 
|                 //如果六个月一付 | 
|                 billList.addAll(getBillsByParam6Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate())); | 
|             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.THREE)){ | 
|                 //如果一年一付 | 
|                 billList.addAll(getBillsByParam1Year(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate())); | 
|             } | 
|         } | 
|         for(int i=0;i<billList.size();i++){ | 
|             billList.get(i).setSortnum(i+1); | 
|         } | 
|         ywContractBillMapper.insert(billList); | 
|   | 
|     } | 
|   | 
|     private YwContractBill initDepoistBill(int type,  YwContract model) { | 
|         YwContractBill bill  = new YwContractBill(); | 
|         bill.setCreateDate(model.getEditDate()); | 
|         bill.setCreator(model.getEditor()); | 
|         bill.setEditDate(model.getEditDate()); | 
|         bill.setEditor(model.getEditor()); | 
|         bill.setIsdeleted(Constants.ZERO); | 
|         bill.setContractId(model.getId()); | 
|         bill.setStatus(Constants.ZERO); | 
|         bill.setStartDate(model.getStartDate()); | 
|         bill.setEndDate(model.getEndDate()); | 
|         bill.setType(type); | 
|         bill.setTotleFee(type==Constants.THREE?model.getZlDeposit():model.getWyDeposit());//押金费用 | 
|         bill.setSortnum(0); | 
|         bill.setTitle(type==Constants.THREE?"租赁押金":"物业押金" ); | 
|         return bill; | 
|     } | 
|   | 
|     /** | 
|      * 如果3个月一付 | 
|      * 付款周期类型 0=元每平米天;1=元每平米月;2=元每平米年;3=元每天;4=元每月;5=元每年;6=元每场;" | 
|      * @param model | 
|      * @param details | 
|      * @return | 
|      */ | 
|     private Collection<? extends YwContractBill> getBillsByParam6Months(YwContract model, List<YwContractDetail> details, Date freeStart, Date freeEnd) { | 
|         List<YwContractBill> list = new ArrayList<>(); | 
|         for(YwContractDetail d : details){ | 
|             List<Date> dateList = getCircleDatesBy6Month(d.getStartDate(),d.getEndDate()); | 
|             if(dateList.size() ==0){ | 
|                 continue; | 
|             } | 
|             dealCircleDateBillBiz(dateList,model,d,freeStart,freeEnd,list); | 
|         } | 
|         return list; | 
|     } | 
|     /** | 
|      * 如果3个月一付 | 
|      * 付款周期类型 0=元每平米天;1=元每平米月;2=元每平米年;3=元每天;4=元每月;5=元每年;6=元每场;" | 
|      * @param model | 
|      * @param details | 
|      * @return | 
|      */ | 
|     private Collection<? extends YwContractBill> getBillsByParam3Months(YwContract model, List<YwContractDetail> details, Date freeStart, Date freeEnd) { | 
|         List<YwContractBill> list = new ArrayList<>(); | 
|         for(YwContractDetail d : details){ | 
|             List<Date> dateList = getCircleDatesBy3Month(d.getStartDate(),d.getEndDate()); | 
|             if(dateList.size() ==0){ | 
|                 continue; | 
|             } | 
|             dealCircleDateBillBiz(dateList,model,d,freeStart,freeEnd,list); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     private List<Date> getCircleDatesBy6Month(Date startDate, Date endDate) { | 
|         DateCompare dateCompare =   DateCompare.monthYearCompare(startDate, endDate ); | 
|         int months = dateCompare.getMonth(); | 
|         int monthSix = months / 6;//6个月维度数量 | 
|         int restMonth = months % 6;//剩余的整月 | 
|         int monthDays =   dateCompare.getMonthDays();//不满一个月的天数 | 
|         Date date = new Date(); | 
|         List<Date> list = new ArrayList<>(); | 
|         for (int i = 0; i < monthSix; i++) { | 
|             list.add(DateUtil.addMonthToDate(date,i*6)); | 
|         } | 
|         if(restMonth>0 || monthDays>0){ | 
|             list.add(DateUtil.addDaysToDate(date,monthSix)); | 
|         } | 
|         return list; | 
|     } | 
|     private List<Date> getCircleDatesBy3Month(Date startDate, Date endDate) { | 
|         DateCompare dateCompare =   DateCompare.monthYearCompare(startDate, endDate ); | 
|         int months = dateCompare.getMonth(); | 
|         int monthThree = months / 3;//3个月维度数量 | 
|         int restMonth = months % 3;//剩余的整月 | 
|         int monthDays =   dateCompare.getMonthDays();//不满一个月的天数 | 
|         Date date = new Date(); | 
|         List<Date> list = new ArrayList<>(); | 
|         for (int i = 0; i < monthThree; i++) { | 
|             list.add(DateUtil.addMonthToDate(date,i*3)); | 
|         } | 
|         if(restMonth>0 || monthDays>0){ | 
|             list.add(DateUtil.addDaysToDate(date,monthThree)); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     /** | 
|      * 如果一年一付 | 
|      * 付款周期类型 0=元每平米天;1=元每平米月;2=元每平米年;3=元每天;4=元每月;5=元每年;6=元每场;" | 
|      * @param model | 
|      * @param details | 
|      * @return | 
|      */ | 
|     private List<YwContractBill>  getBillsByParam1Year(YwContract model, List<YwContractDetail> details,Date freeStart,Date freeEnd) { | 
|         List<YwContractBill> list = new ArrayList<>(); | 
|         for(YwContractDetail d : details){ | 
|             List<Date> dateList = getCircleDatesByYear(d.getStartDate(),d.getEndDate()); | 
|             if(dateList.size() ==0){ | 
|                 continue; | 
|             } | 
|             dealCircleDateBillBiz(dateList,model,d,freeStart,freeEnd,list); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     private void dealCircleDateBillBiz(  List<Date> dateList ,YwContract model, YwContractDetail d, Date freeStart, Date freeEnd, List<YwContractBill> list ) { | 
|         for(Date start : dateList){ | 
|             Date end = DateUtil.addDaysToDate(DateUtil.addYearToDate(start,1),-1);//结束日期为下一个周期的前一天 | 
|             if(end.getTime()> d.getEndDate().getTime() ){ | 
|                 end = d.getEndDate(); | 
|             } | 
|             YwContractBill bill = initCreateBillModel(model,d ); | 
|             bill.setStartDate(start);//账单开始 | 
|             bill.setEndDate(end);//账单结束 | 
|             bill.setPlanPayDate(DateUtil.addDaysToDate(d.getStartDate(),Constants.formatIntegerNum(d.getAdvanceDays()) * -1)); | 
|             BigDecimal totalFee =getTotalFeeByStartEnd(model,d,freeStart,freeEnd); | 
|             bill.setTotleFee(totalFee); | 
|   | 
|             list.add(bill); | 
|         } | 
|     } | 
|   | 
|   | 
|   | 
|     private BigDecimal getTotalFeeByStartEnd(YwContract model, YwContractDetail d,Date freeStart,Date freeEnd) { | 
|         BigDecimal totalFee = new BigDecimal(0); | 
|         DateCompare dateCompare =   DateCompare.dayCompare(d.getStartDate(),d.getEndDate(),freeStart,freeEnd); | 
|         if(Constants.equalsInteger(d.getCircleType(),Constants.ZERO)){ | 
|             //0=元每平米天 | 
|             int days = dateCompare.getDay(); | 
|             BigDecimal areas = getAreasNumBYRooms(model.getRoomList()); | 
|             totalFee = new BigDecimal(days).multiply(areas).multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.ONE)){ | 
|             //1=元每平米月 | 
|             BigDecimal areas = getAreasNumBYRooms(model.getRoomList()); | 
|             BigDecimal month =dateCompare.getMonthFloat(); | 
|             totalFee = month.multiply(areas).multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.TWO)){ | 
|             //2=元每平米年 | 
|             BigDecimal areas = getAreasNumBYRooms(model.getRoomList()); | 
|             BigDecimal year =  dateCompare.getYearFloat(); | 
|             totalFee = year.multiply(areas).multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.THREE)){ | 
|             //3=元每天 | 
|             int days = dateCompare.getDay(); | 
|             totalFee = new BigDecimal(days).multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.FOUR)){ | 
|             //4=元每月 | 
|             BigDecimal month = dateCompare.getMonthFloat(); | 
|             totalFee = month.multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.FIVE)){ | 
|             //5=元每年 | 
|             BigDecimal year =  dateCompare.getYearFloat(); | 
|             totalFee = year.multiply(Constants.formatBigdecimal(d.getPrice()));//总价格 | 
|         }else  if(Constants.equalsInteger(d.getCircleType(),Constants.SIX)){ | 
|             //6=元每场 | 
|             totalFee =Constants.formatBigdecimal(d.getPrice()); | 
|         } | 
|         if(Constants.equalsInteger(model.getRoundedUp(),Constants.ONE)){ | 
|             //如果强制取整 | 
|             totalFee = Constants.formatBigdecimal0Float(totalFee); | 
|         }else{ | 
|             //四舍五入两位小数 | 
|             totalFee = Constants.formatBigdecimal2Float(totalFee); | 
|         } | 
|         return totalFee; | 
|     } | 
|   | 
|     private List<Date> getCircleDatesByYear(Date startDate, Date endDate ) { | 
|         DateCompare dateCompare =   DateCompare.monthYearCompare(startDate, endDate ); | 
|         int years = dateCompare.getYear(); | 
|         int yeardays = dateCompare.getYearDays(); | 
|         Date date = new Date(); | 
|         List<Date> list = new ArrayList<>(); | 
|         for (int i = 0; i < years; i++) { | 
|             list.add(DateUtil.addYearToDate(date,i)); | 
|         } | 
|         if(yeardays>0){ | 
|             list.add(DateUtil.addYearToDate(date,years)); | 
|         } | 
|         return list; | 
|     } | 
|   | 
|     /** | 
|      * 一次性付款账单 | 
|      * 付款周期类型 0=元每平米天;1=元每平米月;2=元每平米年;3=元每天;4=元每月;5=元每年;6=元每场;" | 
|      * @param model | 
|      * @param details | 
|      * @return | 
|      */ | 
|     private  List<YwContractBill> getBillsByParamOnce(YwContract model, List<YwContractDetail> details,Date freeStart,Date freeEnd) { | 
|         List<YwContractBill> list = new ArrayList<>(); | 
|         for(YwContractDetail d : details){ | 
|             YwContractBill bill = initCreateBillModel(model,d); | 
|             bill.setStartDate(d.getStartDate());//账单开始 | 
|             bill.setEndDate(d.getEndDate());//账单结束 | 
|             bill.setPlanPayDate(DateUtil.addDaysToDate(d.getStartDate(),Constants.formatIntegerNum(d.getAdvanceDays()) * -1)); | 
|             bill.setTotleFee(getTotalFeeByStartEnd(model,d,freeStart,freeEnd)); | 
|             list.add(bill); | 
|         } | 
|         return list; | 
|   | 
|     } | 
|   | 
|     private YwContractBill initCreateBillModel(YwContract model,YwContractDetail d) { | 
|         YwContractBill bill  = new YwContractBill(); | 
|         bill.setCreateDate(model.getEditDate()); | 
|         bill.setCreator(model.getEditor()); | 
|         bill.setEditDate(model.getEditDate()); | 
|         bill.setEditor(model.getEditor()); | 
|         bill.setIsdeleted(Constants.ZERO); | 
|         bill.setContractId(model.getId()); | 
|         bill.setStatus(Constants.ZERO); | 
|         bill.setDetailId(d.getId()); | 
|         bill.setType(d.getType()); | 
|         return bill; | 
|     } | 
|   | 
|   | 
|     private BigDecimal getAreasNumBYRooms(List<YwRoom> roomList) { | 
|         BigDecimal data= new BigDecimal(0); | 
|         for(YwRoom r :roomList){ | 
|             data = data.add(Constants.formatBigdecimal(r.getArea())); | 
|         } | 
|         return  data; | 
|     } | 
|   | 
|   | 
|   | 
|   | 
|     private void dealMultifileBiz(YwContract model) { | 
|         List<Multifile> fileList = new ArrayList<>(); | 
|         if(model.getFileList()!=null && model.getFileList().size()>0){ | 
|             for (int i = 0; i <  model.getFileList().size(); i++) { | 
|                 Multifile multifile =  model.getFileList().get(i); | 
|                 if(StringUtils.isBlank(multifile.getFileurl())){ | 
|                     continue; | 
|                 } | 
|                 multifile.setCreateDate(model.getEditDate()); | 
|                 multifile.setCreator(model.getEditor()); | 
|                 multifile.setIsdeleted(Constants.ZERO); | 
|                 multifile.setObjId(model.getId()); | 
|                 multifile.setCreator(model.getCreator()); | 
|                 multifile.setObjType(Constants.MultiFile.YW_WORKORDER_PROBLEM.getKey()); | 
|                 multifile.setSortnum(i+1); | 
|                 fileList.add(multifile); | 
|             } | 
|         } | 
|         if(fileList.size()>0){ | 
|             multifileMapper.insert(fileList); | 
|         } | 
|   | 
|     } | 
|   | 
|     private void isParamValidCreated(YwContract model) { | 
|         if(model.getType()==null || model.getType()>2 || model.getType()<0 | 
|                 ||model.getUserId() == null | 
|                 ||model.getStartDate() == null | 
|                 ||model.getEndDate() == null | 
|                 ||model.getSignDate() == null | 
|                 ||model.getProjectId() == null | 
|                 ||model.getCompanyId() == null | 
|                 ||model.getRoundedUp() == null | 
|                 ||model.getRenterId() == null | 
|                 ||model.getMemberId() == null | 
|                 ||model.getRoomIds() == null | 
|                 ||model.getRoomIds().size() == 0 | 
|         ){ | 
|             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请按页面要求填写合同信息"); | 
|         } | 
|         if(model.getEndDate().getTime()<= model.getStartDate().getTime()){ | 
|   | 
|             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,合同有效期结束时间不得早于开始时间!"); | 
|         } | 
|   | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.ONE)){ | 
|             if(  model.getZlDeposit() == null | 
|                     ||model.getZlPayType() == null | 
|                     || model.getZlPayType()>3 | 
|                     || model.getZlPayType()<0 | 
|                     ||model.getZlDetailList()==null | 
|                     ||model.getZlDetailList().size() ==0){ | 
|                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请按页面要求填写租赁条款信息"); | 
|             } | 
|             if(!(model.getZlFreeEndDate()==null &&  model.getZlFreeStartDate()==null) && ( | 
|                         (model.getZlFreeEndDate()!=null &&  model.getZlFreeStartDate()==null) | 
|                         ||(model.getZlFreeEndDate()==null &&  model.getZlFreeStartDate()!=null) | 
|                         ||model.getZlFreeEndDate().getTime()<= model.getZlFreeStartDate().getTime()) | 
|                   ){ | 
|                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请选择正确的租赁条款免租期信息!"); | 
|             } | 
|             for(YwContractDetail d :model.getZlDetailList()){ | 
|                 if(  d.getStartDate() == null | 
|                         ||d.getEndDate() == null | 
|                         ||d.getPrice() == null | 
|                         ||d.getCircleType() == null | 
|                         || d.getCircleType()>6 | 
|                         || d.getCircleType()<0 | 
|                 ){ | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请按页面要求填写租赁条款信息!"); | 
|                 } | 
|                 if(d.getEndDate().getTime()<= d.getStartDate().getTime()){ | 
|   | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,租赁条款有效期结束时间不得早于开始时间!"); | 
|                 } | 
|                 if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) && | 
|                         Constants.equalsInteger(d.getCircleType(),Constants.SIX)){ | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,租赁条款只有选择一次性付款时,才能选择该按每场收费;"); | 
|                 } | 
|             } | 
|         } | 
|         if(Constants.equalsInteger(model.getType(),Constants.ZERO ) | 
|                 || Constants.equalsInteger(model.getType(),Constants.TWO)){ | 
|             if(  model.getWyDeposit() == null | 
|                     ||model.getWyPayType() == null | 
|                     || model.getWyPayType()>3 | 
|                     || model.getWyPayType()<0 | 
|                     ||model.getWyDetailList()==null | 
|                     ||model.getWyDetailList().size() ==0 | 
|             ){ | 
|                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请按页面要求填写物业条款信息"); | 
|             } | 
|             if(!(model.getWyFreeEndDate()==null &&  model.getWyFreeStartDate()==null) && ( | 
|                     (model.getWyFreeEndDate()!=null &&  model.getWyFreeStartDate()==null) | 
|                             ||(model.getWyFreeEndDate()==null &&  model.getWyFreeStartDate()!=null) | 
|                             ||model.getWyFreeEndDate().getTime()<= model.getWyFreeStartDate().getTime())){ | 
|                 throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请选择正确的物业条款免租期信息!"); | 
|             } | 
|             for(YwContractDetail d :model.getWyDetailList()){ | 
|                 if(  d.getStartDate() == null | 
|                         ||d.getEditDate() == null | 
|                         ||d.getPrice() == null | 
|                         ||d.getCircleType() == null | 
|                         || d.getCircleType()>6 | 
|                         || d.getCircleType()<0 | 
|                 ){ | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请按页面要求填写物业条款信息!"); | 
|                 } | 
|                 if(d.getEndDate().getTime()<= d.getStartDate().getTime()){ | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,物业条款有效期结束时间不得早于开始时间!"); | 
|                 } | 
|                 if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) && | 
|                         Constants.equalsInteger(d.getCircleType(),Constants.SIX)){ | 
|                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,物业条款只有选择一次性付款时,才能选择该按每场收费;"); | 
|                 } | 
|             } | 
|         } | 
|   | 
|         YwProject project = projectMapper.selectById(model.getCompanyId()); | 
|         if(project ==null || Constants.equalsInteger(project.getIsdeleted(),Constants.ONE)){ | 
|             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,请选择正确的项目信息!"); | 
|         } | 
|         List<YwRoom> rooms = roomMapper.selectList(new QueryWrapper<YwRoom>().lambda() | 
|                 .eq(YwRoom::getIsdeleted,Constants.ZERO) | 
|                 .in(YwRoom::getId,model.getRoomIds()) | 
|                 .eq(YwRoom::getProjectId,model.getProjectId())  ); | 
|         if(rooms ==null || rooms.size()==0){ | 
|             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,请选择对应项目下正确的房源信息"); | 
|         } | 
|         if(rooms.size() != rooms.size()){ | 
|             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"对不起,存在无效的房源信息!"); | 
|         } | 
|         YwCustomer customer = customerMapper.selectById(model.getRenterId()); | 
|         if(customer ==null || Constants.equalsInteger(customer.getIsdeleted(),Constants.ONE)){ | 
|             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,选择租客信息不存在,请返回刷新重试!"); | 
|         } | 
|         Member member = memberMapper.selectOne(new QueryWrapper<Member>().lambda() | 
|                 .eq(Member::getIsdeleted,Constants.ZERO) | 
|                 .eq(Member::getType,Constants.THREE) | 
|                 .eq(Member::getCustomerId,model.getRenterId()) | 
|                 .eq(Member::getId,model.getMemberId()) | 
|                 .last("limit 1")); | 
|         if(member ==null ){ | 
|             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,选择租客联系人信息不存在,请返回刷新重试!"); | 
|         } | 
|         Company company = companyMapper.selectById(model.getCompanyId()); | 
|         if(company ==null || Constants.equalsInteger(company.getIsdeleted(),Constants.ONE) | 
|                 || !Constants.equalsInteger(company.getType(),Constants.TWO)){ | 
|             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,请选择正确的公司信息!"); | 
|         } | 
|         SystemUser user = systemUserMapper.selectById(model.getUserId()); | 
|         if(user ==null || (user.getDeleted()!=null && user.getDeleted()) ){ | 
|             throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,经办人信息不存在,请尝试刷新页面重试!"); | 
|         } | 
|   | 
|     } | 
|   | 
|     @Override | 
|     public void deleteById(Integer id, LoginUserInfo user) { | 
|         ywContractMapper.deleteById(id); | 
|     } | 
|   | 
|     @Override | 
|     public void delete(YwContract ywContract) { | 
|         UpdateWrapper<YwContract> deleteWrapper = new UpdateWrapper<>(ywContract); | 
|         ywContractMapper.delete(deleteWrapper); | 
|     } | 
|   | 
|     @Override | 
|     public void deleteByIdInBatch(List<Integer> ids, LoginUserInfo user) { | 
|         if (CollectionUtils.isEmpty(ids)) { | 
|             return; | 
|         } | 
|         ywContractMapper.deleteBatchIds(ids); | 
|     } | 
|   | 
|     @Override | 
|     public void updateById(YwContract ywContract) { | 
|         ywContractMapper.updateById(ywContract); | 
|     } | 
|   | 
|     @Override | 
|     public void updateByIdInBatch(List<YwContract> ywContracts) { | 
|         if (CollectionUtils.isEmpty(ywContracts)) { | 
|             return; | 
|         } | 
|         for (YwContract ywContract: ywContracts) { | 
|             this.updateById(ywContract); | 
|         } | 
|     } | 
|   | 
|     @Override | 
|     public YwContract findById(Integer id) { | 
|         return ywContractMapper.selectById(id); | 
|     } | 
|   | 
|     @Override | 
|     public YwContract findOne(YwContract ywContract) { | 
|         QueryWrapper<YwContract> wrapper = new QueryWrapper<>(ywContract); | 
|         return ywContractMapper.selectOne(wrapper); | 
|     } | 
|   | 
|     @Override | 
|     public List<YwContract> findList(YwContract ywContract) { | 
|         QueryWrapper<YwContract> wrapper = new QueryWrapper<>(ywContract); | 
|         return ywContractMapper.selectList(wrapper); | 
|     } | 
|    | 
|     @Override | 
|     public PageData<YwContract> findPage(PageWrap<YwContract> pageWrap) { | 
|         IPage<YwContract> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); | 
|         MPJLambdaWrapper<YwContract> queryWrapper = new MPJLambdaWrapper<>(); | 
|         queryWrapper.selectAll(YwContract.class ) | 
|                 .selectAs(Company::getName,YwContract::getCompanyName ) | 
|                 .select("(select sum(r.area) from yw_contract_room cr left join yw_room r on r.id = cr.room_id where r.isdeleted=0 and cr.contract_id =t.id)",YwContract::getTotalArea ) | 
|                 .leftJoin(Company.class,Company::getId,YwContract::getCompanyId); | 
|         Utils.MP.blankToNull(pageWrap.getModel()); | 
|         if (pageWrap.getModel().getId() != null) { | 
|             queryWrapper.eq(YwContract::getId, pageWrap.getModel().getId()); | 
|         } | 
|         if (pageWrap.getModel().getCreator() != null) { | 
|             queryWrapper.eq(YwContract::getCreator, pageWrap.getModel().getCreator()); | 
|         } | 
|         if (pageWrap.getModel().getCreateDate() != null) { | 
|             queryWrapper.ge(YwContract::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate())); | 
|             queryWrapper.le(YwContract::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate())); | 
|         } | 
|         if (pageWrap.getModel().getEditor() != null) { | 
|             queryWrapper.eq(YwContract::getEditor, pageWrap.getModel().getEditor()); | 
|         } | 
|         if (pageWrap.getModel().getEditDate() != null) { | 
|             queryWrapper.ge(YwContract::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate())); | 
|             queryWrapper.le(YwContract::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate())); | 
|         } | 
|         if (pageWrap.getModel().getIsdeleted() != null) { | 
|             queryWrapper.eq(YwContract::getIsdeleted, pageWrap.getModel().getIsdeleted()); | 
|         } | 
|         if (pageWrap.getModel().getRemark() != null) { | 
|             queryWrapper.eq(YwContract::getRemark, pageWrap.getModel().getRemark()); | 
|         } | 
|         if (pageWrap.getModel().getStatus() != null) { | 
|             queryWrapper.eq(YwContract::getStatus, pageWrap.getModel().getStatus()); | 
|         } | 
|         if (pageWrap.getModel().getType() != null) { | 
|             queryWrapper.eq(YwContract::getType, pageWrap.getModel().getType()); | 
|         } | 
|         if (pageWrap.getModel().getCode() != null) { | 
|             queryWrapper.eq(YwContract::getCode, pageWrap.getModel().getCode()); | 
|         } | 
|         if (pageWrap.getModel().getUserId() != null) { | 
|             queryWrapper.eq(YwContract::getUserId, pageWrap.getModel().getUserId()); | 
|         } | 
|         if (pageWrap.getModel().getSignDate() != null) { | 
|             queryWrapper.ge(YwContract::getSignDate, Utils.Date.getStart(pageWrap.getModel().getSignDate())); | 
|             queryWrapper.le(YwContract::getSignDate, Utils.Date.getEnd(pageWrap.getModel().getSignDate())); | 
|         } | 
|         if (pageWrap.getModel().getStartDate() != null) { | 
|             queryWrapper.ge(YwContract::getStartDate, Utils.Date.getStart(pageWrap.getModel().getStartDate())); | 
|             queryWrapper.le(YwContract::getStartDate, Utils.Date.getEnd(pageWrap.getModel().getStartDate())); | 
|         } | 
|         if (pageWrap.getModel().getEndDate() != null) { | 
|             queryWrapper.ge(YwContract::getEndDate, Utils.Date.getStart(pageWrap.getModel().getEndDate())); | 
|             queryWrapper.le(YwContract::getEndDate, Utils.Date.getEnd(pageWrap.getModel().getEndDate())); | 
|         } | 
|         if (pageWrap.getModel().getProjectId() != null) { | 
|             queryWrapper.eq(YwContract::getProjectId, pageWrap.getModel().getProjectId()); | 
|         } | 
|         if (pageWrap.getModel().getRoundedUp() != null) { | 
|             queryWrapper.eq(YwContract::getRoundedUp, pageWrap.getModel().getRoundedUp()); | 
|         } | 
|         if (pageWrap.getModel().getCompanyId() != null) { | 
|             queryWrapper.eq(YwContract::getCompanyId, pageWrap.getModel().getCompanyId()); | 
|         } | 
|   | 
|         if (pageWrap.getModel().getRenterId() != null) { | 
|             queryWrapper.eq(YwContract::getRenterId, pageWrap.getModel().getRenterId()); | 
|         } | 
|         if (pageWrap.getModel().getMemberId() != null) { | 
|             queryWrapper.eq(YwContract::getMemberId, pageWrap.getModel().getMemberId()); | 
|         } | 
|         if (pageWrap.getModel().getZlDeposit() != null) { | 
|             queryWrapper.eq(YwContract::getZlDeposit, pageWrap.getModel().getZlDeposit()); | 
|         } | 
|         if (pageWrap.getModel().getZlPayType() != null) { | 
|             queryWrapper.eq(YwContract::getZlPayType, pageWrap.getModel().getZlPayType()); | 
|         } | 
|         if (pageWrap.getModel().getZlFreeStartDate() != null) { | 
|             queryWrapper.ge(YwContract::getZlFreeStartDate, Utils.Date.getStart(pageWrap.getModel().getZlFreeStartDate())); | 
|             queryWrapper.le(YwContract::getZlFreeStartDate, Utils.Date.getEnd(pageWrap.getModel().getZlFreeStartDate())); | 
|         } | 
|         if (pageWrap.getModel().getZlFreeEndDate() != null) { | 
|             queryWrapper.ge(YwContract::getZlFreeEndDate, Utils.Date.getStart(pageWrap.getModel().getZlFreeEndDate())); | 
|             queryWrapper.le(YwContract::getZlFreeEndDate, Utils.Date.getEnd(pageWrap.getModel().getZlFreeEndDate())); | 
|         } | 
|         if (pageWrap.getModel().getWyDeposit() != null) { | 
|             queryWrapper.eq(YwContract::getWyDeposit, pageWrap.getModel().getWyDeposit()); | 
|         } | 
|         if (pageWrap.getModel().getWyPayType() != null) { | 
|             queryWrapper.eq(YwContract::getWyPayType, pageWrap.getModel().getWyPayType()); | 
|         } | 
|         if (pageWrap.getModel().getWyFreeStartDate() != null) { | 
|             queryWrapper.ge(YwContract::getWyFreeStartDate, Utils.Date.getStart(pageWrap.getModel().getWyFreeStartDate())); | 
|             queryWrapper.le(YwContract::getWyFreeStartDate, Utils.Date.getEnd(pageWrap.getModel().getWyFreeStartDate())); | 
|         } | 
|         if (pageWrap.getModel().getWyFreeEndDate() != null) { | 
|             queryWrapper.ge(YwContract::getWyFreeEndDate, Utils.Date.getStart(pageWrap.getModel().getWyFreeEndDate())); | 
|             queryWrapper.le(YwContract::getWyFreeEndDate, Utils.Date.getEnd(pageWrap.getModel().getWyFreeEndDate())); | 
|         } | 
|         if (pageWrap.getModel().getZlTotalFee() != null) { | 
|             queryWrapper.eq(YwContract::getZlTotalFee, pageWrap.getModel().getZlTotalFee()); | 
|         } | 
|         if (pageWrap.getModel().getWyTotalFee() != null) { | 
|             queryWrapper.eq(YwContract::getWyTotalFee, pageWrap.getModel().getWyTotalFee()); | 
|         } | 
|         if (pageWrap.getModel().getCompanyName() != null) { | 
|             queryWrapper.like(Company::getName, pageWrap.getModel().getCompanyName()); | 
|         } | 
|         queryWrapper.ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), YwContract::getStartDate, pageWrap.getModel().getQueryStartTime()) | 
|                         .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()), YwContract::getEndDate, pageWrap.getModel().getQueryEndTime()); | 
|         queryWrapper.orderByDesc(YwContract::getCreateDate ); | 
|         return PageData.from(ywContractMapper.selectJoinPage(page, YwContract.class,queryWrapper)); | 
|     } | 
|   | 
|     @Override | 
|     public long count(YwContract ywContract) { | 
|         QueryWrapper<YwContract> wrapper = new QueryWrapper<>(ywContract); | 
|         return ywContractMapper.selectCount(wrapper); | 
|     } | 
| } |