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.*;
import com.moral.api.mapper.OrganizationUnitAlarmMapper;
import com.moral.api.mapper.SensorMapper;
import com.moral.api.mapper.VersionMapper;
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.*;
import com.moral.api.service.VersionService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.moral.constant.Constants;
import com.moral.constant.ResponseCodeEnum;
import com.moral.util.ConvertUtils;
import org.apache.tomcat.websocket.WsRemoteEndpointAsync;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.util.ObjectUtils;
import java.util.*;
/**
*
* 型号表 服务实现类
*
*
* @author moral
* @since 2021-05-14
*/
@Service
public class VersionServiceImpl extends ServiceImpl implements VersionService {
@Autowired
VersionMapper versionMapper;
@Autowired
VersionSensorUnitMapper versionSensorUnitMapper;
@Autowired
SensorMapper sensorMapper;
@Autowired
OrganizationUnitAlarmMapper organizationUnitAlarmMapper;
@Override
public VersionQueryDTO query(VersionQueryForm form) {
//创建返回对象
VersionQueryDTO dto = new VersionQueryDTO();
//取参
Integer page = form.getPage();
Integer size = form.getSize();
String name = form.getName();
Date createStartTime = form.getCreateStartTime();
Date createEndTime = form.getCreateEndTime();
Date updateStartTime = form.getUpdateStartTime();
Date updateEndTime = form.getUpdateEndTime();
String order = form.getOrder();
String orderType = form.getOrderType();
Integer isDelete = form.getIsDelete();
//组装查询条件
Page queryPage = new Page<>(page, size);
NullFilterWrapper wrapper = new NullFilterWrapper<>();
wrapper.like("name", name);
wrapper.between("create_time", createStartTime, createEndTime);
wrapper.between("update_time", updateStartTime, updateEndTime);
//排序顺序条件构造
if (!ObjectUtils.isEmpty(order) && !ObjectUtils.isEmpty(orderType)) {
if (orderType.equals(Constants.ORDER_ASC))
wrapper.orderByAsc(ConvertUtils.toLine(order));
else
wrapper.orderByDesc(ConvertUtils.toLine(order));
}
//逻辑删除条件构造
if (!ObjectUtils.isEmpty(isDelete))
wrapper.eq("is_delete", isDelete);
else
wrapper.eq("is_delete", Constants.NOT_DELETE);
//查询结果
Page versionsPage = versionMapper.selectPage(queryPage, wrapper);
List versions = versionsPage.getRecords();
//查询版本对应的因子和单位
List versionsIds = new ArrayList<>();
versions.forEach(value -> versionsIds.add(value.getId()));
List queryResult = new ArrayList<>();
if (!ObjectUtils.isEmpty(versionsIds)) {
queryResult = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds);
}
//封装返回数据
List dtos = new ArrayList<>();
queryResult.forEach(value -> dtos.add(new VersionDTO(value)));
dto.setVersionDTOS(dtos);
dto.setCurrent(versionsPage.getCurrent());
dto.setPages(versionsPage.getPages());
dto.setSize(versionsPage.getSize());
dto.setTotal(versionsPage.getTotal());
dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
return dto;
}
@Override
@Transactional
public VersionDTO update(VersionUpdateForm form) {
//创建返回对象
VersionDTO dto = new VersionDTO();
//取参
Version version = form.formConvertEntity();
//查找要更新的version 用于插入日志
QueryWrapper oldVersionWrapper = new QueryWrapper<>();
Version oldVersion = new Version();
oldVersion.setId(version.getId());
oldVersion.setIsDelete(Constants.NOT_DELETE);
oldVersionWrapper.setEntity(oldVersion);
oldVersion = versionMapper.selectOne(oldVersionWrapper);
if (ObjectUtils.isEmpty(oldVersion)) {
dto.setCode(ResponseCodeEnum.VERSION_NOT_EXIST.getCode());
dto.setMsg(ResponseCodeEnum.VERSION_NOT_EXIST.getMsg());
return dto;
}
//更新
versionMapper.updateById(version);
//封装返回结果
dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
return dto;
}
@Override
@Transactional
public VersionDTO insert(VersionInsertForm form) {
//创建返回对象
VersionDTO dto = new VersionDTO();
//取参
Version version = form.formConvertEntity();
//判断型号名称是否已经存在
Version existVersion = new Version();
existVersion.setName(version.getName());
existVersion.setIsDelete(Constants.NOT_DELETE);
QueryWrapper wrapper = new QueryWrapper<>();
wrapper.setEntity(existVersion);
Version existVersionResult = versionMapper.selectOne(wrapper);
if (!ObjectUtils.isEmpty(existVersionResult)) {
dto.setCode(ResponseCodeEnum.VERSION_EXIST.getCode());
dto.setMsg(ResponseCodeEnum.VERSION_EXIST.getMsg());
return dto;
}
//插入
versionMapper.insert(version);
//封装返回结果
dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
return dto;
}
@Override
@Transactional
public VersionDTO delete(VersionDeleteForm form) {
//创建返回对象
VersionDTO dto = new VersionDTO();
//取参
Integer id = form.getId();
//查询型号是否被使用,如果被使用则无法删除
QueryWrapper queryWrapper = new QueryWrapper<>();
queryWrapper.eq("is_delete",Constants.NOT_DELETE);
queryWrapper.eq("version_id",id);
List organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryWrapper);
if(!ObjectUtils.isEmpty(organizationUnitAlarms)){
dto.setCode(ResponseCodeEnum.VERSION_USED.getCode());
dto.setMsg(ResponseCodeEnum.VERSION_USED.getMsg());
return dto;
}
//查询要删除的版本用于记录日志
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 sensorUnits = form.getSensorUnits();
Integer versionId = form.getVersionId();
//将前端传来的id转为code
for (VersionSensorUnit sensorUnit : sensorUnits) {
Sensor sensor = sensorMapper.selectById(sensorUnit.getSensorId());
sensorUnit.setSensorCode(sensor.getCode());
}
//查询之前分配的单位和因子
QueryWrapper queryOldWrapper = new QueryWrapper<>();
queryOldWrapper.eq("version_id",versionId);
queryOldWrapper.eq("is_delete",Constants.NOT_DELETE);
List oldSensorUnits = versionSensorUnitMapper.selectList(queryOldWrapper);
//判断出变动的因子(要插入和要删除的)
List insertList = new ArrayList<>();
List deleteList = new ArrayList<>();
sensorUnits.forEach(value->{
value.setVersionId(versionId);
if(!oldSensorUnits.contains(value))
insertList.add(value);
});
oldSensorUnits.forEach(value->{
if(!sensorUnits.contains(value))
deleteList.add(value);
});
//删除记录
UpdateWrapper deleteWrapper = new UpdateWrapper();
List deleteIds = new ArrayList<>();
deleteList.forEach(value->deleteIds.add(value.getId()));
deleteWrapper.in("id",deleteIds);
deleteWrapper.set("is_delete", Constants.DELETE);
versionSensorUnitMapper.update(null, deleteWrapper);
//添加记录
for (VersionSensorUnit sensorUnit : insertList) {
versionSensorUnitMapper.insert(sensorUnit);
}
//维护组织型号关系表
QueryWrapper queryOrgUnitAlarmWrapper = new QueryWrapper<>();
queryOrgUnitAlarmWrapper.select("distinct organization_id");
queryOrgUnitAlarmWrapper.eq("version_id",versionId);
queryOrgUnitAlarmWrapper.eq("is_delete",Constants.NOT_DELETE);
List organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryOrgUnitAlarmWrapper);
List organizationIds = new ArrayList<>();
organizationUnitAlarms.forEach(value->organizationIds.add(value.getOrganizationId()));
for (Integer organizationId : organizationIds) {
//删除因子
for (VersionSensorUnit versionSensorUnit : deleteList) {
UpdateWrapper deleteOrganizationUnitAlarmWrapper = new UpdateWrapper();
deleteOrganizationUnitAlarmWrapper.eq("orgniazation_id",organizationId);
deleteOrganizationUnitAlarmWrapper.eq("version_id",versionId);
deleteOrganizationUnitAlarmWrapper.eq("sensor_code",versionSensorUnit.getSensorCode());
organizationUnitAlarmMapper.update(null,deleteOrganizationUnitAlarmWrapper);
}
//新增因子
for (VersionSensorUnit versionSensorUnit : insertList) {
OrganizationUnitAlarm organizationUnitAlarm = new OrganizationUnitAlarm();
organizationUnitAlarm.setOrganizationId(organizationId);
organizationUnitAlarm.setVersionId(versionId);
organizationUnitAlarm.setSensorCode(versionSensorUnit.getSensorCode());
organizationUnitAlarm.setUnitKey(versionSensorUnit.getUnitKey());
organizationUnitAlarm.setShowUnitKey(versionSensorUnit.getUnitKey());
organizationUnitAlarmMapper.insert(organizationUnitAlarm);
}
}
//封装返回结果
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 versionsIds = new ArrayList<>();
versionsIds.add(id);
List versions = new ArrayList<>();
versions = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds);
//根据分页信息进行选择因子
Version version = versions.get(0);
List querySensors = version.getSensors();
if (!ObjectUtils.isEmpty(querySensors)) {
int startIndex = (page - 1) * size;
int endIndex = startIndex + size - 1;
List 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;
}
@Override
public VersionQueryDTO queryByOrganizationId(Integer organizationId) {
//创建返回对象
VersionQueryDTO dto = new VersionQueryDTO();
//查询型号id
QueryWrapper queryVersionIdsWrapper = new QueryWrapper<>();
queryVersionIdsWrapper.select("DISTINCT version_id").eq("is_delete",Constants.NOT_DELETE).eq("organization_id",organizationId);
List organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryVersionIdsWrapper);
List versionIds = new ArrayList<>();
for (OrganizationUnitAlarm organizationUnitAlarm : organizationUnitAlarms) {
versionIds.add(organizationUnitAlarm.getVersionId());
}
//根据型号id查询型号
List versions = new ArrayList<>();
if(!ObjectUtils.isEmpty(versionIds))
versions = versionMapper.selectBatchIds(versionIds);
//封装返回对象
List versionDTOS = new ArrayList<>();
versions.forEach(value->versionDTOS.add(new VersionDTO(value)));
dto.setCode(ResponseCodeEnum.SUCCESS.getCode());
dto.setMsg(ResponseCodeEnum.SUCCESS.getMsg());
dto.setVersionDTOS(versionDTOS);
return dto;
}
}