|
@@ -0,0 +1,146 @@
|
|
|
|
+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.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
+import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
|
|
|
|
+import com.ruoyi.common.core.page.TableDataInfo;
|
|
|
|
+import com.ruoyi.common.utils.PageUtils;
|
|
|
|
+import com.ruoyi.common.utils.StringUtils;
|
|
|
|
+import com.ruoyi.gas.domain.GPatrolRecord;
|
|
|
|
+import com.ruoyi.gas.domain.bo.GPatrolRecordBo;
|
|
|
|
+import com.ruoyi.gas.domain.bo.GPatrolRecordPhotoBo;
|
|
|
|
+import com.ruoyi.gas.domain.vo.GPatrolRecordVo;
|
|
|
|
+import com.ruoyi.gas.mapper.GPatrolRecordMapper;
|
|
|
|
+import com.ruoyi.gas.service.IGPatrolRecordPhotoService;
|
|
|
|
+import com.ruoyi.gas.service.IGPatrolRecordService;
|
|
|
|
+import com.ruoyi.gas.service.IGUserService;
|
|
|
|
+import com.ruoyi.gas.service.IGWarningPileService;
|
|
|
|
+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 2023-11-15
|
|
|
|
+ */
|
|
|
|
+@Service
|
|
|
|
+public class GPatrolRecordServiceImpl extends ServicePlusImpl<GPatrolRecordMapper, GPatrolRecord, GPatrolRecordVo> implements IGPatrolRecordService {
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public GPatrolRecordVo queryById(Long id) {
|
|
|
|
+ GPatrolRecordVo voById = getVoById(id);
|
|
|
|
+ voById.setPhotoList(baseMapper.getPhoto(voById.getId()));
|
|
|
|
+ return voById;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Autowired
|
|
|
|
+ private IGUserService igUserService;
|
|
|
|
+ @Autowired
|
|
|
|
+ private IGWarningPileService igWarningPileService;
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public TableDataInfo<GPatrolRecordVo> queryPageList(GPatrolRecordBo bo) {
|
|
|
|
+ Page<GPatrolRecordVo> page = new Page<>(bo.getPageNum(), bo.getPageSize());
|
|
|
|
+ Page<GPatrolRecordVo> list = baseMapper.getList(bo, page);
|
|
|
|
+ list.getRecords().forEach(item -> {
|
|
|
|
+ item.setPhotoList(baseMapper.getPhoto(item.getId()));
|
|
|
|
+ item.setUserName(igUserService.getVoById(item.getUserId()).getName());
|
|
|
|
+ item.setWarningPileName(igWarningPileService.getVoById(item.getWarningPileId()).getName());
|
|
|
|
+ });
|
|
|
|
+ return PageUtils.buildDataInfo(list);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public List<GPatrolRecordVo> queryList(GPatrolRecordBo bo) {
|
|
|
|
+ return listVo(buildQueryWrapper(bo));
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ private LambdaQueryWrapper<GPatrolRecord> buildQueryWrapper(GPatrolRecordBo bo) {
|
|
|
|
+ Map<String, Object> params = bo.getParams();
|
|
|
|
+ LambdaQueryWrapper<GPatrolRecord> lqw = Wrappers.lambdaQuery();
|
|
|
|
+ lqw.eq(bo.getUserId() != null, GPatrolRecord::getUserId, bo.getUserId());
|
|
|
|
+ lqw.eq(bo.getWarningPileId() != null, GPatrolRecord::getWarningPileId, bo.getWarningPileId());
|
|
|
|
+ lqw.eq(bo.getCreateTime() != null, GPatrolRecord::getCreateTime, bo.getCreateTime());
|
|
|
|
+ return lqw;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Autowired
|
|
|
|
+ private IGPatrolRecordPhotoService igPatrolRecordPhotoService;
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public Boolean insertByBo(GPatrolRecordBo bo) {
|
|
|
|
+ GPatrolRecord add = BeanUtil.toBean(bo, GPatrolRecord.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++) {
|
|
|
|
+ GPatrolRecordPhotoBo photo = new GPatrolRecordPhotoBo();
|
|
|
|
+ photo.setPatrolRecordId(bo.getId());
|
|
|
|
+ photo.setPicUrl(bo.getPhotoList().get(i));
|
|
|
|
+ igPatrolRecordPhotoService.insertByBo(photo);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return flag;
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public Boolean updateByBo(GPatrolRecordBo bo) {
|
|
|
|
+ GPatrolRecord update = BeanUtil.toBean(bo, GPatrolRecord.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) {
|
|
|
|
+ igPatrolRecordPhotoService.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))) {
|
|
|
|
+ //添加照片
|
|
|
|
+ GPatrolRecordPhotoBo photo = new GPatrolRecordPhotoBo();
|
|
|
|
+ photo.setPatrolRecordId(bo.getId());
|
|
|
|
+ photo.setPicUrl(inslist.get(i));
|
|
|
|
+ igPatrolRecordPhotoService.insertByBo(photo);
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ return updateById(update);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ /**
|
|
|
|
+ * 保存前的数据校验
|
|
|
|
+ *
|
|
|
|
+ * @param entity 实体类数据
|
|
|
|
+ */
|
|
|
|
+ private void validEntityBeforeSave(GPatrolRecord entity) {
|
|
|
|
+ //TODO 做一些数据校验,如唯一约束
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ @Override
|
|
|
|
+ public Boolean deleteWithValidByIds(Collection<Long> ids, Boolean isValid) {
|
|
|
|
+ if (isValid) {
|
|
|
|
+ //TODO 做一些业务上的校验,判断是否需要校验
|
|
|
|
+ }
|
|
|
|
+ return removeByIds(ids);
|
|
|
|
+ }
|
|
|
|
+}
|