From 0197c2fcac5fdb701ff91dcea0d98ec226bc008d Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Wed, 13 Oct 2021 15:21:08 +0800 Subject: [PATCH] 删除historySecondSpecial相关类 --- screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java | 300 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 286 insertions(+), 14 deletions(-) diff --git a/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java b/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java index c716f2e..f88fb70 100644 --- a/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java +++ b/screen-manage/src/main/java/com/moral/api/service/impl/VersionServiceImpl.java @@ -1,26 +1,30 @@ 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.User; -import com.moral.api.entity.Version; -import com.moral.api.entity.VersionSensorUnit; +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.VersionQueryForm; +import com.moral.api.pojo.form.version.*; import com.moral.api.service.VersionService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.moral.api.util.CacheUtils; 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.ArrayList; -import java.util.Date; -import java.util.List; +import java.util.*; /** * <p> @@ -37,6 +41,10 @@ VersionMapper versionMapper; @Autowired VersionSensorUnitMapper versionSensorUnitMapper; + @Autowired + SensorMapper sensorMapper; + @Autowired + OrganizationUnitAlarmMapper organizationUnitAlarmMapper; @Override public VersionQueryDTO query(VersionQueryForm form) { @@ -52,10 +60,11 @@ Date updateEndTime = form.getUpdateEndTime(); String order = form.getOrder(); String orderType = form.getOrderType(); + Integer isDelete = form.getIsDelete(); //������������������ Page<Version> queryPage = new Page<>(page, size); NullFilterWrapper<Version> wrapper = new NullFilterWrapper<>(); - wrapper.like("name",name); + wrapper.like("name", name); wrapper.between("create_time", createStartTime, createEndTime); wrapper.between("update_time", updateStartTime, updateEndTime); //������������������������ @@ -65,17 +74,280 @@ else wrapper.orderByDesc(ConvertUtils.toLine(order)); } + //������������������������ + if (!ObjectUtils.isEmpty(isDelete)) + wrapper.eq("is_delete", isDelete); + else + wrapper.eq("is_delete", Constants.NOT_DELETE); //������������ - Page<Version> versionsPage = versionMapper.selectPage(queryPage,wrapper); + Page<Version> versionsPage = versionMapper.selectPage(queryPage, wrapper); List<Version> versions = versionsPage.getRecords(); //������������������������������������ List<Integer> versionsIds = new ArrayList<>(); - versions.forEach(value->versionsIds.add(value.getId())); - if(!ObjectUtils.isEmpty(versionsIds)){ - QueryWrapper<VersionSensorUnit> sensorUnitQueryWrapper = new QueryWrapper<>(); - + versions.forEach(value -> versionsIds.add(value.getId())); + List<Version> queryResult = new ArrayList<>(); + if (!ObjectUtils.isEmpty(versionsIds)) { + queryResult = versionMapper.queryVersionsAndSensorUnitByIds(versionsIds); + } + //������������������ + List<VersionDTO> 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<Version> 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; } - return null; + //������ + 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<Version> 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<OrganizationUnitAlarm> queryWrapper = new QueryWrapper<>(); + queryWrapper.select("id"); + queryWrapper.eq("is_delete", Constants.NOT_DELETE); + queryWrapper.eq("version_id", id); + List<OrganizationUnitAlarm> 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<VersionSensorUnit> sensorUnits = form.getSensorUnits(); + Integer versionId = form.getVersionId(); + //������������������id������code + for (VersionSensorUnit sensorUnit : sensorUnits) { + Sensor sensor = sensorMapper.selectById(sensorUnit.getSensorId()); + sensorUnit.setSensorCode(sensor.getCode()); + } + //������������������������������������ + QueryWrapper<VersionSensorUnit> queryOldWrapper = new QueryWrapper<>(); + queryOldWrapper.eq("version_id", versionId); + queryOldWrapper.eq("is_delete", Constants.NOT_DELETE); + List<VersionSensorUnit> oldSensorUnits = versionSensorUnitMapper.selectList(queryOldWrapper); + //������������������������(������������������������) + List<VersionSensorUnit> insertList = new ArrayList<>(); + List<VersionSensorUnit> 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); + }); + //������������ + if (!ObjectUtils.isEmpty(deleteList)) { + UpdateWrapper deleteWrapper = new UpdateWrapper(); + List<Integer> 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<OrganizationUnitAlarm> queryOrgUnitAlarmWrapper = new QueryWrapper<>(); + queryOrgUnitAlarmWrapper.select("distinct organization_id"); + queryOrgUnitAlarmWrapper.eq("version_id", versionId); + queryOrgUnitAlarmWrapper.eq("is_delete", Constants.NOT_DELETE); + List<OrganizationUnitAlarm> organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryOrgUnitAlarmWrapper); + List<Integer> organizationIds = new ArrayList<>(); + organizationUnitAlarms.forEach(value -> organizationIds.add(value.getOrganizationId())); + for (Integer organizationId : organizationIds) { + //������������ + for (VersionSensorUnit versionSensorUnit : deleteList) { + UpdateWrapper deleteOrganizationUnitAlarmWrapper = new UpdateWrapper(); + deleteOrganizationUnitAlarmWrapper.eq("organization_id", organizationId); + deleteOrganizationUnitAlarmWrapper.eq("version_id", versionId); + deleteOrganizationUnitAlarmWrapper.eq("sensor_code", versionSensorUnit.getSensorCode()); + deleteOrganizationUnitAlarmWrapper.set("is_delete", Constants.DELETE); + 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); + } + } + //������deviceInfo������ + CacheUtils.refreshDeviceAlarmInfo(); + CacheUtils.refreshSpecialDeviceAlarmInfo(); + //������������������ + 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; + } + + @Override + public VersionQueryDTO queryByOrganizationId(Integer organizationId) { + //������������������ + VersionQueryDTO dto = new VersionQueryDTO(); + //������������id + QueryWrapper<OrganizationUnitAlarm> queryVersionIdsWrapper = new QueryWrapper<>(); + queryVersionIdsWrapper.select("DISTINCT version_id").eq("is_delete", Constants.NOT_DELETE).eq("organization_id", organizationId); + List<OrganizationUnitAlarm> organizationUnitAlarms = organizationUnitAlarmMapper.selectList(queryVersionIdsWrapper); + List<Integer> versionIds = new ArrayList<>(); + for (OrganizationUnitAlarm organizationUnitAlarm : organizationUnitAlarms) { + versionIds.add(organizationUnitAlarm.getVersionId()); + } + //������������id������������ + List<Version> versions = new ArrayList<>(); + if (!ObjectUtils.isEmpty(versionIds)) + versions = versionMapper.selectBatchIds(versionIds); + //������������������ + List<VersionDTO> 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; + } + } + -- Gitblit v1.8.0