123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151 |
- package com.ruoyi.gas.service.impl;
- import cn.hutool.core.bean.BeanUtil;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.baomidou.mybatisplus.core.toolkit.Wrappers;
- import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
- import com.ruoyi.common.core.page.PagePlus;
- import com.ruoyi.common.core.page.TableDataInfo;
- import com.ruoyi.common.utils.PageUtils;
- import com.ruoyi.common.utils.StringUtils;
- import com.ruoyi.gas.domain.GPatrolTeam;
- import com.ruoyi.gas.domain.bo.GPatrolTeamBo;
- import com.ruoyi.gas.domain.bo.GPatrolTeamPhotoBo;
- import com.ruoyi.gas.domain.vo.GPatrolTeamVo;
- import com.ruoyi.gas.mapper.GPatrolTeamMapper;
- import com.ruoyi.gas.service.IGPatrolTeamPhotoService;
- import com.ruoyi.gas.service.IGPatrolTeamService;
- import com.ruoyi.gas.service.IGUserService;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.stereotype.Service;
- import org.springframework.util.ObjectUtils;
- import java.util.Arrays;
- import java.util.Collection;
- import java.util.List;
- import java.util.Map;
- import java.util.stream.Collectors;
- /**
- * 巡检车队Service业务层处理
- *
- * @author ruoyi
- * @date 2024-05-09
- */
- @Service
- public class GPatrolTeamServiceImpl extends ServicePlusImpl<GPatrolTeamMapper, GPatrolTeam, GPatrolTeamVo> implements IGPatrolTeamService {
- @Override
- public GPatrolTeamVo queryById(Long id) {
- GPatrolTeamVo voById = getVoById(id);
- voById.setPhotoList(baseMapper.getPhoto(id));
- voById.setCreateByName(baseMapper.getName(voById.getCreateBy()));
- return voById;
- }
- @Autowired
- private IGUserService gUserService;
- @Override
- public TableDataInfo<GPatrolTeamVo> queryPageList(GPatrolTeamBo bo) {
- String ranks = bo.getRanks();
- if (StringUtils.isNotEmpty(ranks)) {
- bo.setUids(gUserService.getByRanks(ranks));
- }
- PagePlus<GPatrolTeam, GPatrolTeamVo> result = pageVo(PageUtils.buildPagePlus(), buildQueryWrapper(bo));
- result.getRecordsVo().forEach(item -> {
- item.setPhotoList(baseMapper.getPhoto(item.getId()));
- item.setCreateByName(baseMapper.getName(item.getCreateBy()));
- });
- return PageUtils.buildDataInfo(result);
- }
- @Override
- public List<GPatrolTeamVo> queryList(GPatrolTeamBo bo) {
- return listVo(buildQueryWrapper(bo));
- }
- private LambdaQueryWrapper<GPatrolTeam> buildQueryWrapper(GPatrolTeamBo bo) {
- Map<String, Object> params = bo.getParams();
- LambdaQueryWrapper<GPatrolTeam> lqw = Wrappers.lambdaQuery();
- lqw.eq(StringUtils.isNotBlank(bo.getTeam()), GPatrolTeam::getTeam, bo.getTeam());
- lqw.eq(StringUtils.isNotBlank(bo.getUploadLocation()), GPatrolTeam::getUploadLocation, bo.getUploadLocation());
- lqw.eq(StringUtils.isNotBlank(bo.getIsNormalInspection()), GPatrolTeam::getIsNormalInspection, bo.getIsNormalInspection());
- lqw.in(StringUtils.isNotEmpty(bo.getRanks()), GPatrolTeam::getCreateBy, !ObjectUtils.isEmpty(bo.getUids()) && bo.getUids().size() > 0 ? bo.getUids() : Arrays.asList(0L));
- lqw.eq(StringUtils.isNotBlank(bo.getCreateBy()), GPatrolTeam::getCreateBy, bo.getCreateBy());
- lqw.orderByDesc(GPatrolTeam::getCreateTime);
- return lqw;
- }
- @Autowired
- private IGPatrolTeamPhotoService service;
- @Override
- public Boolean insertByBo(GPatrolTeamBo bo) {
- GPatrolTeam add = BeanUtil.toBean(bo, GPatrolTeam.class);
- validEntityBeforeSave(add);
- boolean flag = save(add);
- if (flag) {
- bo.setId(add.getId());
- //添加照片
- List<String> piclist = bo.getPhotoList();
- if (piclist != null) {
- for (int i = 0; i < bo.getPhotoList().size(); i++) {
- GPatrolTeamPhotoBo photo = new GPatrolTeamPhotoBo();
- photo.setParentId(bo.getId());
- photo.setPicUrl(bo.getPhotoList().get(i));
- service.insertByBo(photo);
- }
- }
- }
- return flag;
- }
- @Override
- public Boolean updateByBo(GPatrolTeamBo bo) {
- GPatrolTeam update = BeanUtil.toBean(bo, GPatrolTeam.class);
- validEntityBeforeSave(update);
- List<String> piclist = bo.getPhotoList();
- if (piclist != null) {
- //原有的照片
- List<String> photolist = baseMapper.getPhoto(bo.getId());
- //原有的照片不在新传的照片里
- List<String> dellist = photolist.stream().filter(i -> !piclist.contains(i)).collect(Collectors.toList());
- //删除照片
- if (dellist.size() > 0) {
- service.deleteByUrl(bo.getId(), dellist);
- }
- //新传的照片不在原有的照片里
- List<String> inslist = piclist.stream().filter(i -> !photolist.contains(i)).collect(Collectors.toList());
- if (inslist.size() > 0) {
- for (int i = 0; i < inslist.size(); i++) {
- if (StringUtils.isNotEmpty(inslist.get(i))) {
- //添加照片
- GPatrolTeamPhotoBo photo = new GPatrolTeamPhotoBo();
- photo.setParentId(bo.getId());
- photo.setPicUrl(inslist.get(i));
- service.insertByBo(photo);
- }
- }
- }
- }
- return updateById(update);
- }
- /**
- * 保存前的数据校验
- *
- * @param entity 实体类数据
- */
- private void validEntityBeforeSave(GPatrolTeam entity) {
- //TODO 做一些数据校验,如唯一约束
- }
- @Override
- public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
- if (isValid) {
- //TODO 做一些业务上的校验,判断是否需要校验
- }
- return removeByIds(ids);
- }
- }
|