From a7c804a7dccc5c928fe8914d54a277f31bb9bfae Mon Sep 17 00:00:00 2001 From: mitao <2763622819@qq.com> Date: 星期五, 20 十二月 2024 18:03:09 +0800 Subject: [PATCH] 设备管理接口 --- medicalWaste-system/src/main/java/com/sinata/system/service/impl/MwMonitorDeviceServiceImpl.java | 79 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 78 insertions(+), 1 deletions(-) diff --git a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/MwMonitorDeviceServiceImpl.java b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/MwMonitorDeviceServiceImpl.java index 54dac1c..77ae33b 100644 --- a/medicalWaste-system/src/main/java/com/sinata/system/service/impl/MwMonitorDeviceServiceImpl.java +++ b/medicalWaste-system/src/main/java/com/sinata/system/service/impl/MwMonitorDeviceServiceImpl.java @@ -1,10 +1,22 @@ package com.sinata.system.service.impl; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.sinata.common.entity.PageDTO; +import com.sinata.common.exception.ServiceException; +import com.sinata.common.utils.BeanUtils; import com.sinata.system.domain.MwMonitorDevice; +import com.sinata.system.domain.SysDepartment; +import com.sinata.system.domain.dto.MwMonitorDeviceDTO; +import com.sinata.system.domain.query.MwMonitorDeviceQuery; +import com.sinata.system.domain.vo.MwMonitorDeviceVO; import com.sinata.system.mapper.MwMonitorDeviceMapper; import com.sinata.system.service.MwMonitorDeviceService; -import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.sinata.system.service.SysDepartmentService; +import lombok.RequiredArgsConstructor; import org.springframework.stereotype.Service; + +import java.util.Objects; /** * <p> @@ -15,6 +27,71 @@ * @since 2024-12-02 */ @Service +@RequiredArgsConstructor public class MwMonitorDeviceServiceImpl extends ServiceImpl<MwMonitorDeviceMapper, MwMonitorDevice> implements MwMonitorDeviceService { + private final SysDepartmentService sysDepartmentService; + /** + * 监控设备分页列表 + * + * @param query + * @return + */ + @Override + public PageDTO<MwMonitorDeviceVO> pageList(MwMonitorDeviceQuery query) { + String treeCode = sysDepartmentService.getTreeCode(query.getDepartmentId()); + Page<MwMonitorDeviceVO> page = baseMapper.pageList(new Page<>(query.getPageCurr(), query.getPageSize()), query, treeCode); + return PageDTO.of(page); + } + + /** + * 监控设备详情 + * + * @param id + * @return + */ + @Override + public MwMonitorDeviceVO detail(Long id) { + MwMonitorDeviceVO mwMonitorDeviceVO = BeanUtils.copyBean(getById(id), MwMonitorDeviceVO.class); + SysDepartment department = sysDepartmentService.getById(mwMonitorDeviceVO.getDepartmentId()); + if (Objects.nonNull(department)) { + mwMonitorDeviceVO.setDepartmentName(department.getDepartmentName()); + } + return mwMonitorDeviceVO; + } + + /** + * 新增 + * + * @param dto + * @return + */ + @Override + public void add(MwMonitorDeviceDTO dto) { + MwMonitorDevice mwMonitorDevice = BeanUtils.copyBean(dto, MwMonitorDevice.class); + Long count = this.lambdaQuery().eq(MwMonitorDevice::getDeviceNumber, mwMonitorDevice.getDeviceNumber()).count(); + if (count > 0) { + throw new ServiceException("监控设备编号重复"); + } + save(mwMonitorDevice); + } + + /** + * 编辑 + * + * @param dto + * @return + */ + @Override + public void edit(MwMonitorDeviceDTO dto) { + if (Objects.isNull(dto.getId())) { + throw new ServiceException("监控设备id不能为空"); + } + Long count = this.lambdaQuery().eq(MwMonitorDevice::getDeviceNumber, dto.getDeviceNumber()).ne(MwMonitorDevice::getId, dto.getId()).count(); + if (count > 0) { + throw new ServiceException("监控设备编号重复"); + } + MwMonitorDevice mwMonitorDevice = BeanUtils.copyBean(dto, MwMonitorDevice.class); + updateById(mwMonitorDevice); + } } -- Gitblit v1.7.1