linwe
2023-12-01 5d5cd3ad979a0b85ab8c7034dcad1663fdcf71be
src/main/java/org/springblade/modules/place/service/impl/PlaceExtServiceImpl.java
@@ -16,9 +16,17 @@
 */
package org.springblade.modules.place.service.impl;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.modules.grid.service.IGridService;
import org.springblade.modules.house.entity.HouseTenantEntity;
import org.springblade.modules.house.vo.HouseTenantVO;
import org.springblade.modules.place.entity.PlaceEntity;
import org.springblade.modules.place.entity.PlaceExtEntity;
import org.springblade.modules.place.entity.PlacePractitionerEntity;
import org.springblade.modules.place.service.IPlacePractitionerService;
import org.springblade.modules.place.service.IPlaceService;
import org.springblade.modules.place.vo.PlaceExtVO;
import org.springblade.modules.place.mapper.PlaceExtMapper;
import org.springblade.modules.place.service.IPlaceExtService;
@@ -30,7 +38,10 @@
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import java.util.stream.Collectors;
/**
 * 场所详情表 服务实现类
@@ -44,6 +55,15 @@
   @Autowired
   private ITaskService taskService;
   @Autowired
   private IPlaceService placeService;
   @Autowired
   private IPlacePractitionerService placePractitionerService;
   @Autowired
   private IGridService gridService;
   /**
    * 自定义查询
    * @param page
@@ -52,7 +72,15 @@
    */
   @Override
   public IPage<PlaceExtVO> selectPlaceExtPage(IPage<PlaceExtVO> page, PlaceExtVO placeExt) {
      return page.setRecords(baseMapper.selectPlaceExtPage(page, placeExt));
      List<String> list = new ArrayList<>();
      if (null!=placeExt.getRoleName() && !placeExt.getRoleName().equals("")){
         if (placeExt.getRoleName().equals("网格员")){
            // 查询对应的房屋地址code
            list = gridService.getAddressCodeListByUserId(AuthUtil.getUserId());
         }
      }
      placeExt.setCreateUser(AuthUtil.getUserId());
      return page.setRecords(baseMapper.selectPlaceExtPage(page, placeExt,list));
   }
   /**
@@ -61,12 +89,65 @@
    * @return
    */
   @Override
   public boolean updatePlaceExt(PlaceExtEntity placeExt) {
   @Transactional(rollbackFor = Exception.class)
   public boolean updatePlaceExt(PlaceExtVO placeExt) {
      // 设置参数
      placeExt.setUpdateTime(new Date());
      placeExt.setUpdateUser(AuthUtil.getUserId());
      // 更新
      return updateById(placeExt);
      // 更新从业人员信息
      boolean addFlag = true;
      boolean updateFlag = true;
      boolean removeFlag = true;
      //更新自身
      boolean update = updateById(placeExt);
      // 查询对应已存在的从业人员
      QueryWrapper<PlacePractitionerEntity> wrapper = new QueryWrapper<>();
      wrapper.eq("place_id",placeExt.getPlaceId());
      List<PlacePractitionerEntity> oldList = placePractitionerService.list(wrapper);
      List<PlacePractitionerEntity> list = placeExt.getPlacePractitioner();
      // 申明新增,修改,删除集合
      List<PlacePractitionerEntity> newList = new ArrayList<>();
      List<PlacePractitionerEntity> addList = new ArrayList<>();
      List<PlacePractitionerEntity> updateList = new ArrayList<>();
      List<PlacePractitionerEntity> removeList = new ArrayList<>();
      // 找出需要新增的,否则组成新集合进行比对
      for (PlacePractitionerEntity practitionerEntity : list) {
         practitionerEntity.setPlaceId(placeExt.getPlaceId());
         if (null==practitionerEntity.getId()){
            // 新增
            PlacePractitionerEntity placePractitionerEntity= new PlacePractitionerEntity();
            placePractitionerEntity.setPlaceId(placeExt.getPlaceId());
            placePractitionerEntity.setName(practitionerEntity.getName());
            placePractitionerEntity.setTelephone(practitionerEntity.getTelephone());
            placePractitionerEntity.setTempAddress(practitionerEntity.getTempAddress());
            addList.add(placePractitionerEntity);
         }else {
            newList.add(practitionerEntity);
         }
      }
      // 遍历去差集,判断是新增还是删除还是更新
      // 取旧数据和新提交数据差集--删除
      removeList = oldList.stream().filter(vo -> !newList.stream().map(e ->
         e.getId()).collect(Collectors.toList()).contains(vo.getId())).collect(Collectors.toList());
      // 取旧数据和新提交数据交集--更新
      updateList = newList.stream().filter(vo -> oldList.stream().map(e ->
         e.getId()).collect(Collectors.toList()).contains(vo.getId())).collect(Collectors.toList());
      // 批量新增
      if (addList.size()>0) {
         addFlag = placePractitionerService.saveBatch(addList);
      }
      // 批量修改
      if (updateList.size()>0) {
         updateFlag = placePractitionerService.updateBatchById(updateList);
      }
      // 批量删除
      if (removeList.size()>0) {
         removeFlag = placePractitionerService.removeBatchByIds(removeList);
      }
      // 返回
      return update && addFlag && updateFlag && removeFlag;
   }
   /**
@@ -80,16 +161,65 @@
      boolean flag = false;
      // 设置更新时间
      placeExt.setConfirmTime(new Date());
      placeExt.setConfirmUserId(AuthUtil.getUserId());
      // 更新数据
      boolean b = updateById(placeExt);
      if (b) {
         PlaceExtEntity entity = getById(placeExt.getId());
         // 更新任务表状态
         TaskEntity taskEntity = new TaskEntity();
         taskEntity.setId(placeExt.getTaskId());
         taskEntity.setId(entity.getTaskId());
         taskEntity.setStatus(placeExt.getConfirmFlag());
         flag = taskService.updateById(taskEntity);
      }
      // 返回
      return flag;
   }
   /**
    * 场所详情表 新增
    * @param placeExt
    * @return
    */
   @Override
   public boolean savePlaceExt(PlaceExtEntity placeExt) {
      PlaceEntity placeEntity = placeService.getById(placeExt.getPlaceId());
      TaskEntity taskEntity = new TaskEntity();
      taskEntity.setId(placeExt.getTaskId());
      taskEntity.setStatus(placeExt.getConfirmFlag());
      taskEntity.setType(1);
      taskEntity.setFrequency(1);
      taskEntity.setName(placeEntity.getPlaceName() + "信息完善");
      // 新增任务
      boolean save = taskService.save(taskEntity);
      if (save){
         placeExt.setTaskId(taskEntity.getId());
         placeExt.setConfirmFlag(1);
         placeExt.setCreateTime(new Date());
         placeExt.setUpdateTime(new Date());
         placeExt.setCreateUser(AuthUtil.getUserId());
         placeExt.setUpdateUser(AuthUtil.getUserId());
         // 新增场所详情
         save(placeExt);
      }
      return false;
   }
   /**
    * 场所详情表 自定义详情
    * @param placeExt
    * @return
    */
   @Override
   public PlaceExtVO getDetail(PlaceExtVO placeExt) {
      PlaceExtVO detail = baseMapper.getDetail(placeExt);
      if (null!=detail) {
         // 查询从业人员信息
         QueryWrapper<PlacePractitionerEntity> queryWrapper = new QueryWrapper<>();
         queryWrapper.eq("place_id", placeExt.getPlaceId());
         detail.setPlacePractitioner(placePractitionerService.list(queryWrapper));
      }
      // 返回
      return detail;
   }
}