linwe
2023-12-23 55d677758efadb6d42e6d4e595cecc2c50c20d5a
src/main/java/org/springblade/modules/house/service/impl/HouseRentalServiceImpl.java
@@ -17,22 +17,26 @@
package org.springblade.modules.house.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springblade.common.utils.SpringUtils;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.modules.grid.service.IGridService;
import org.springblade.modules.house.entity.HouseRentalEntity;
import org.springblade.modules.house.entity.HouseTenantEntity;
import org.springblade.modules.house.service.IHouseTenantService;
import org.springblade.modules.house.entity.HouseholdEntity;
import org.springblade.modules.house.excel.HouseRentalExcel;
import org.springblade.modules.house.mapper.HouseRentalMapper;
import org.springblade.modules.house.service.IHouseRentalService;
import org.springblade.modules.house.service.IHouseholdService;
import org.springblade.modules.house.vo.HouseRentalStatistics;
import org.springblade.modules.house.vo.HouseRentalTenantVO;
import org.springblade.modules.house.vo.HouseRentalVO;
import org.springblade.modules.house.mapper.HouseRentalMapper;
import org.springblade.modules.house.service.IHouseRentalService;
import org.springblade.modules.house.vo.HouseTenantVO;
import org.springblade.modules.house.excel.HouseRentalExcel;
import org.springblade.modules.house.vo.HouseholdVO;
import org.springblade.modules.system.entity.User;
import org.springblade.modules.system.service.IUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
@@ -50,7 +54,8 @@
public class HouseRentalServiceImpl extends ServiceImpl<HouseRentalMapper, HouseRentalEntity> implements IHouseRentalService {
   @Autowired
   private IHouseTenantService houseTenantService;
   private IHouseholdService iHouseholdService;
   @Autowired
   private IGridService gridService;
@@ -75,7 +80,25 @@
            houseRental.setAuditStatus(2);
         }
      }
      return page.setRecords(baseMapper.selectHouseRentalPage(page, houseRental,list));
      List<HouseRentalTenantVO> houseRentalTenantVOS = baseMapper.selectHouseRentalPage(page, houseRental, list);
      for (HouseRentalTenantVO houseRentalTenantVO : houseRentalTenantVOS) {
         if(houseRentalTenantVO.getStatus().equals(1)){
            houseRentalTenantVO.setStatus(30);
         }
         if(houseRentalTenantVO.getStatus().equals(0) && houseRentalTenantVO.getAuditStatus().equals(0)){
            houseRentalTenantVO.setStatus(0);
         }
         if(houseRentalTenantVO.getStatus().equals(0) && houseRentalTenantVO.getAuditStatus().equals(1)){
            houseRentalTenantVO.setStatus(1);
         }
         if(houseRentalTenantVO.getStatus().equals(0) && houseRentalTenantVO.getDldType().equals(3)){
            houseRentalTenantVO.setStatus(20);
         }
         if(houseRentalTenantVO.getStatus().equals(0) && houseRentalTenantVO.getDldType().equals(2)){
            houseRentalTenantVO.setStatus(10);
         }
      }
      return page.setRecords(houseRentalTenantVOS);
   }
   /**
@@ -98,28 +121,54 @@
   @Override
   @Transactional(rollbackFor = Exception.class)
   public Boolean add(HouseRentalVO houseRentalVO) {
//      // 判断添加人是否房屋业主
//      Long count = iHouseholdService.count(Wrappers.<HouseholdEntity>lambdaQuery()
//         .eq(HouseholdEntity::getHouseCode, houseRentalVO.getHouseCode())
//         .eq(HouseholdEntity::getAssociatedUserId, AuthUtil.getUserId())
//         .eq(HouseholdEntity::getRelationship, 1));
//      if (count == 0) {
//         return false;
//      }
      houseRentalVO.setCreateUser(AuthUtil.getUserId());
      houseRentalVO.setCreateTime(new Date());
      houseRentalVO.setUpdateUser(AuthUtil.getUserId());
      houseRentalVO.setUpdateTime(new Date());
      // 网格员新增默认是审核通过
      houseRentalVO.setAuditStatus(1);
      //保存自身
      boolean save = save(houseRentalVO);
      List<HouseTenantEntity> houseTenantEntities = new ArrayList<>();
      houseRentalVO.getHouseTenantVOList().forEach(e->{
         HouseTenantEntity houseTenant= new HouseTenantEntity();
         houseTenant.setHousingRentalId(houseRentalVO.getId());
         houseTenant.setName(e.getName());
         houseTenant.setPhone(e.getPhone());
         houseTenant.setIdCard(e.getIdCard());
         houseTenant.setDomicile(e.getDomicile());
         houseTenant.setWorkUnit(e.getWorkUnit());
         houseTenantEntities.add(houseTenant);
      List<String> phoneList = new ArrayList<>();
      List<HouseholdEntity> householdEntityList = new ArrayList<>();
      houseRentalVO.getHouseholdVOList().forEach(e -> {
         e.setHouseCode(houseRentalVO.getHouseCode());
         e.setHousingRentalId(houseRentalVO.getId());
         e.setRelationship(18);
         e.setResidentialStatus(1);
         e.setRoleType(2);
         householdEntityList.add(e);
         phoneList.add(e.getPhoneNumber());
      });
      boolean saveBatch = houseTenantService.saveBatch(houseTenantEntities);
      try {
         // 查询租户是否网格员身份的,给网格员设置居民角色
         IUserService bean = SpringUtils.getBean(IUserService.class);
         String str = "1717429261910528001";
         List<User> list = bean.list(Wrappers.<User>lambdaQuery()
            .in(User::getPhone, phoneList)
            .like(User::getRoleId, str));
         for (User user : list) {
            boolean contains = user.getRoleId().contains("1717429059648606209");
            if (contains) {
               continue;
            }
            user.setRoleId(user.getRoleId() + ",1717429059648606209");
         }
         bean.updateBatchById(list);
      } catch (Exception e) {
         log.error("保存用户角色为居民:", e);
      }
      boolean saveBatch = iHouseholdService.saveBatch(householdEntityList);
      return save&&saveBatch;
      return save && saveBatch;
   }
   /**
@@ -132,11 +181,11 @@
      // 先删除出租屋信息
      boolean b = removeById(id);
      // 再删除租户信息
      int i = houseTenantService.removeByHousingRentalId(id);
      if (i>0){
         return true && b;
      }
      return false;
      boolean update = iHouseholdService.update(Wrappers.<HouseholdEntity>lambdaUpdate()
         .set(HouseholdEntity::getIsDeleted, 1)
         .eq(HouseholdEntity::getHousingRentalId, id));
      // 返回
      return b;
   }
   /**
@@ -155,31 +204,30 @@
      //更新自身
      boolean update = updateById(houseRental);
      // 查询对应已存在的租户
      QueryWrapper<HouseTenantEntity> wrapper = new QueryWrapper<>();
      wrapper.eq("housing_rental_id",houseRental.getId());
      List<HouseTenantEntity> oldList = houseTenantService.list(wrapper);
      List<HouseTenantVO> list = houseRental.getHouseTenantVOList();
      QueryWrapper<HouseholdEntity> wrapper = new QueryWrapper<>();
      wrapper.eq("housing_rental_id", houseRental.getId());
      List<HouseholdEntity> oldList = iHouseholdService.list(wrapper);
      List<HouseholdVO> list = houseRental.getHouseholdVOList();
      // 申明新增,修改,删除集合
      List<HouseTenantEntity> newList = new ArrayList<>();
      List<HouseTenantEntity> addList = new ArrayList<>();
      List<HouseTenantEntity> updateList = new ArrayList<>();
      List<HouseTenantEntity> removeList = new ArrayList<>();
      List<HouseholdEntity> newList = new ArrayList<>();
      List<HouseholdEntity> addList = new ArrayList<>();
      List<HouseholdEntity> updateList = new ArrayList<>();
      List<HouseholdEntity> removeList = new ArrayList<>();
      // 找出需要新增的,否则组成新集合进行比对
      for (HouseTenantVO houseTenantVO : list) {
         houseTenantVO.setHousingRentalId(houseRental.getId());
         if (null==houseTenantVO.getId()){
            // 新增
            HouseTenantEntity houseTenant= new HouseTenantEntity();
      List<String> phoneList = new ArrayList<>();
            houseTenant.setHousingRentalId(houseRental.getId());
            houseTenant.setName(houseTenantVO.getName());
            houseTenant.setPhone(houseTenantVO.getPhone());
            houseTenant.setIdCard(houseTenantVO.getIdCard());
            houseTenant.setDomicile(houseTenantVO.getDomicile());
            houseTenant.setWorkUnit(houseTenantVO.getWorkUnit());
            addList.add(houseTenant);
         }else {
            newList.add(houseTenantVO);
      for (HouseholdEntity householdEntity : list) {
         if (null == householdEntity.getId()) {
            // 新增
            householdEntity.setHouseCode(houseRental.getHouseCode());
            householdEntity.setHousingRentalId(houseRental.getId());
            householdEntity.setRelationship(18);
            householdEntity.setResidentialStatus(1);
            householdEntity.setRoleType(2);
            addList.add(householdEntity);
            phoneList.add(householdEntity.getPhoneNumber());
         } else {
            newList.add(householdEntity);
         }
      }
      // 遍历去差集,判断是新增还是删除还是更新
@@ -192,15 +240,36 @@
      // 批量新增
      if (addList.size()>0) {
         addFlag = houseTenantService.saveBatch(addList);
         addFlag = iHouseholdService.saveBatch(addList);
      }
      // 批量修改
      if (updateList.size()>0) {
         updateFlag = houseTenantService.updateBatchById(updateList);
      if (updateList.size() > 0) {
         updateFlag = iHouseholdService.updateBatchById(updateList);
         for (HouseholdEntity householdEntity : updateList) {
            phoneList.add(householdEntity.getPhoneNumber());
         }
      }
      // 批量删除
      if (removeList.size()>0) {
         removeFlag = houseTenantService.removeBatchByIds(removeList);
      if (removeList.size() > 0) {
         removeFlag = iHouseholdService.removeBatchByIds(removeList);
      }
      try {
         // 查询租户是否网格员身份的,给网格员设置居民角色
         IUserService bean = SpringUtils.getBean(IUserService.class);
         String str = "1717429261910528001";
         List<User> list2 = bean.list(Wrappers.<User>lambdaQuery()
            .in(User::getPhone, phoneList)
            .like(User::getRoleId, str));
         for (User user : list2) {
            boolean contains = user.getRoleId().contains("1717429059648606209");
            if (contains) {
               continue;
            }
            user.setRoleId(user.getRoleId() + ",1717429059648606209");
         }
         bean.updateBatchById(list2);
      } catch (Exception e) {
         log.error("保存用户角色为居民:", e);
      }
      // 返回
      return update && addFlag && updateFlag && removeFlag;
@@ -238,8 +307,13 @@
      return updateById(houseRental);
   }
   /**
    * 导出租赁信息
    * @param houseRentalVO
    * @return
    */
   @Override
   public List<HouseRentalExcel> export(HouseRentalVO houseRentalVO) {
   public List<HouseRentalExcel> export(HouseRentalTenantVO houseRentalVO) {
      List<HouseRentalExcel> houseRentalExcels = baseMapper.export(houseRentalVO);
      return houseRentalExcels;
   }