|
@@ -0,0 +1,138 @@
|
|
|
|
+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 org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
+import org.springframework.stereotype.Service;
|
|
|
|
+
|
|
|
|
+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;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public TableDataInfo<GPatrolTeamVo> queryPageList(GPatrolTeamBo bo) {
|
|
|
|
+ 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());
|
|
|
|
+ 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);
|
|
|
|
+ }
|
|
|
|
+}
|