| | |
| | | package com.moral.api.service.impl; |
| | | |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.moral.api.config.mybatis.wrapper.NullFilterWrapper; |
| | | import com.moral.api.entity.Sensor; |
| | | import com.moral.api.entity.User; |
| | | import com.moral.api.entity.Version; |
| | | import com.moral.api.entity.VersionSensorUnit; |
| | |
| | | import com.moral.api.mapper.VersionSensorUnitMapper; |
| | | import com.moral.api.pojo.dto.version.VersionDTO; |
| | | import com.moral.api.pojo.dto.version.VersionQueryDTO; |
| | | import com.moral.api.pojo.form.version.VersionInsertForm; |
| | | import com.moral.api.pojo.form.version.VersionQueryForm; |
| | | import com.moral.api.pojo.form.version.VersionUpdateForm; |
| | | import com.moral.api.pojo.form.version.*; |
| | | import com.moral.api.service.VersionService; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.moral.constant.Constants; |
| | |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.springframework.util.ObjectUtils; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | | import java.util.*; |
| | | |
| | | /** |
| | | * <p> |
| | |
| | | //查询版本对应的因子和单位 |
| | | List<Integer> versionsIds = new ArrayList<>(); |
| | | versions.forEach(value -> versionsIds.add(value.getId())); |
| | | List<Version> result = new ArrayList<>(); |
| | | List<Version> queryResult = new ArrayList<>(); |
| | | if (!ObjectUtils.isEmpty(versionsIds)) { |
| | | result = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds); |
| | | queryResult = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds); |
| | | } |
| | | //封装返回数据 |
| | | List<VersionDTO> dtos = new ArrayList<>(); |
| | | result.forEach(value -> dtos.add(new VersionDTO(value))); |
| | | queryResult.forEach(value -> dtos.add(new VersionDTO(value))); |
| | | dto.setVersionDTOS(dtos); |
| | | dto.setCurrent(versionsPage.getCurrent()); |
| | | dto.setPages(versionsPage.getPages()); |
| | |
| | | QueryWrapper<Version> wrapper = new QueryWrapper<>(); |
| | | wrapper.setEntity(existVersion); |
| | | Version existVersionResult = versionMapper.selectOne(wrapper); |
| | | if(!ObjectUtils.isEmpty(existVersionResult)){ |
| | | if (!ObjectUtils.isEmpty(existVersionResult)) { |
| | | dto.setCode(ResponseCodeEnum.VERSION_EXIST.getCode()); |
| | | dto.setMsg(ResponseCodeEnum.VERSION_EXIST.getMsg()); |
| | | return dto; |
| | |
| | | dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); |
| | | return dto; |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public VersionDTO delete(VersionDeleteForm form) { |
| | | //创建返回对象 |
| | | VersionDTO dto = new VersionDTO(); |
| | | //取参 |
| | | Integer id = form.getId(); |
| | | //查询要删除的版本用于记录日志 |
| | | Version oldVersion = versionMapper.selectById(id); |
| | | //执行删除 |
| | | Version deleteVersion = new Version(); |
| | | deleteVersion.setId(oldVersion.getId()); |
| | | deleteVersion.setIsDelete(Constants.DELETE); |
| | | versionMapper.updateById(deleteVersion); |
| | | //删除型号和因子单位对应表 |
| | | UpdateWrapper deleteSensorUnitWrapper = new UpdateWrapper(); |
| | | deleteSensorUnitWrapper.eq("version_id", id); |
| | | deleteSensorUnitWrapper.set("is_delete", Constants.DELETE); |
| | | versionSensorUnitMapper.update(null, deleteSensorUnitWrapper); |
| | | //封装返回结果 |
| | | dto.setCode(ResponseCodeEnum.SUCCESS.getCode()); |
| | | dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); |
| | | return dto; |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public VersionDTO updateSensorUnits(VersionSensorUnitForm form) { |
| | | //创建返回对象 |
| | | VersionDTO dto = new VersionDTO(); |
| | | //取参 |
| | | List<VersionSensorUnit> sensorUnits = form.getSensorUnits(); |
| | | Integer versionId = form.getVersionId(); |
| | | //删除之前分配的单位和因子 |
| | | UpdateWrapper deleteWrapper = new UpdateWrapper(); |
| | | deleteWrapper.eq("version_id", versionId); |
| | | deleteWrapper.set("is_delete", Constants.DELETE); |
| | | versionSensorUnitMapper.update(null, deleteWrapper); |
| | | //添加新分配的单位和因子 |
| | | for (VersionSensorUnit sensorUnit : sensorUnits) { |
| | | sensorUnit.setVersionId(versionId); |
| | | versionSensorUnitMapper.insert(sensorUnit); |
| | | } |
| | | //封装返回结果 |
| | | dto.setCode(ResponseCodeEnum.SUCCESS.getCode()); |
| | | dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); |
| | | return dto; |
| | | } |
| | | |
| | | @Override |
| | | public VersionQueryDTO queryVersionById(VersionQueryByIdForm form) { |
| | | //创建返回对象 |
| | | VersionQueryDTO dto = new VersionQueryDTO(); |
| | | //取参 |
| | | Integer id = form.getId(); |
| | | Integer size = form.getSize(); |
| | | Integer page = form.getPage(); |
| | | //查询版本对应的因子和单位 |
| | | List<Integer> versionsIds = new ArrayList<>(); |
| | | versionsIds.add(id); |
| | | List<Version> versions = new ArrayList<>(); |
| | | versions = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds); |
| | | //根据分页信息进行选择因子 |
| | | Version version = versions.get(0); |
| | | List<Sensor> querySensors = version.getSensors(); |
| | | if (!ObjectUtils.isEmpty(querySensors)) { |
| | | int startIndex = (page - 1) * size; |
| | | int endIndex = startIndex + size - 1; |
| | | List<Sensor> resultSensors = new ArrayList<>(); |
| | | |
| | | for (int i = startIndex; i <= endIndex; i++) { |
| | | if (i >= querySensors.size()) |
| | | break; |
| | | resultSensors.add(querySensors.get(i)); |
| | | } |
| | | version.setSensors(resultSensors); |
| | | } |
| | | //封装返回对象 |
| | | dto.setCode(ResponseCodeEnum.SUCCESS.getCode()); |
| | | dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg()); |
| | | if (ObjectUtils.isEmpty(querySensors)) { |
| | | dto.setTotal(0); |
| | | dto.setPages(0); |
| | | }else{ |
| | | dto.setTotal(querySensors.size()); |
| | | double querySize = (double)querySensors.size(); |
| | | double dSize = (double)size; |
| | | dto.setPages((int)Math.ceil(querySize/dSize)); |
| | | } |
| | | dto.setSize(size); |
| | | dto.setCurrent(page); |
| | | VersionDTO versionDTO = new VersionDTO(); |
| | | versionDTO.setVersion(version); |
| | | dto.setVersionDTOS(Arrays.asList(versionDTO)); |
| | | return dto; |
| | | } |
| | | |
| | | |
| | | } |