package com.sinata.system.service.impl;
|
|
import cn.hutool.core.bean.copier.CopyOptions;
|
import cn.idev.excel.FastExcel;
|
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.common.utils.StringUtils;
|
import com.sinata.system.config.AutoColumnWidthEntityStrategy;
|
import com.sinata.system.config.CustomCellWriteHeightConfig;
|
import com.sinata.system.domain.MwStagingRoom;
|
import com.sinata.system.domain.dto.MwStagingRoomDTO;
|
import com.sinata.system.domain.excel.MwCheckoutRecordExcel;
|
import com.sinata.system.domain.query.CheckoutRecordQuery;
|
import com.sinata.system.domain.query.MwStagingRoomQuery;
|
import com.sinata.system.domain.query.StorageRecordQuery;
|
import com.sinata.system.domain.vo.MwCheckoutRecordVO;
|
import com.sinata.system.domain.vo.MwStagingRoomVO;
|
import com.sinata.system.domain.vo.MwStorageRecordVO;
|
import com.sinata.system.mapper.MwStagingRoomMapper;
|
import com.sinata.system.service.MwStagingRoomService;
|
import com.sinata.system.service.SysDepartmentService;
|
import com.sinata.system.utils.ImgUtils;
|
import lombok.RequiredArgsConstructor;
|
import net.coobird.thumbnailator.Thumbnails;
|
import org.apache.commons.io.FilenameUtils;
|
import org.springframework.stereotype.Service;
|
|
import javax.imageio.ImageIO;
|
import javax.servlet.http.HttpServletResponse;
|
import java.awt.image.BufferedImage;
|
import java.io.ByteArrayOutputStream;
|
import java.io.IOException;
|
import java.net.URLEncoder;
|
import java.util.List;
|
import java.util.Objects;
|
|
/**
|
* <p>
|
* 暂存间 服务实现类
|
* </p>
|
*
|
* @author mitao
|
* @since 2024-12-02
|
*/
|
@Service
|
@RequiredArgsConstructor
|
public class MwStagingRoomServiceImpl extends ServiceImpl<MwStagingRoomMapper, MwStagingRoom> implements MwStagingRoomService {
|
private final SysDepartmentService sysDepartmentService;
|
|
/**
|
* 暂存间分页列表
|
*
|
* @param query
|
* @return
|
*/
|
@Override
|
public PageDTO<MwStagingRoomVO> pageList(MwStagingRoomQuery query) {
|
String treeCode = sysDepartmentService.getTreeCodeByDepartmentId(query.getDepartmentId());
|
if (StringUtils.isBlank(treeCode)) {
|
return PageDTO.empty(0L, 0L);
|
}
|
Page<MwStagingRoomVO> page = baseMapper.pageList(new Page<>(query.getPageCurr(), query.getPageSize()), treeCode);
|
return PageDTO.of(page);
|
}
|
|
/**
|
* 新增暂存间
|
*
|
* @param dto
|
* @return
|
*/
|
@Override
|
public void add(MwStagingRoomDTO dto) {
|
MwStagingRoom mwStagingRoom = BeanUtils.copyBean(dto, MwStagingRoom.class);
|
Long count = this.lambdaQuery().eq(MwStagingRoom::getDepartmentId, mwStagingRoom.getDepartmentId()).count();
|
if (count > 0) {
|
throw new ServiceException("当前医院已存在暂存间,请勿重复添加");
|
}
|
save(mwStagingRoom);
|
}
|
|
/**
|
* 编辑暂存间
|
*
|
* @param dto
|
* @return
|
*/
|
@Override
|
public void edit(MwStagingRoomDTO dto) {
|
if (Objects.isNull(dto.getId())) {
|
throw new ServiceException("暂存间id不能为空");
|
}
|
MwStagingRoom mwStagingRoom = BeanUtils.copyBean(dto, MwStagingRoom.class);
|
updateById(mwStagingRoom);
|
}
|
|
/**
|
* 根据医院id查询暂存间
|
*
|
* @param departmentId
|
* @return
|
*/
|
@Override
|
public MwStagingRoomVO getByHospitalId(Long departmentId) {
|
MwStagingRoom one = this.lambdaQuery().eq(MwStagingRoom::getDepartmentId, departmentId).one();
|
return BeanUtils.copyBean(one, MwStagingRoomVO.class);
|
}
|
|
/**
|
* 暂存间入库记录
|
*
|
* @param query
|
* @return
|
*/
|
@Override
|
public PageDTO<MwStorageRecordVO> storageRecord(StorageRecordQuery query) {
|
String treeCode = sysDepartmentService.getTreeCodeByDepartmentId(query.getDepartmentId());
|
if (StringUtils.isBlank(treeCode)) {
|
return PageDTO.empty(0L, 0L);
|
}
|
Page<MwStorageRecordVO> page = baseMapper.storageRecordPage(new Page<>(query.getPageCurr(), query.getPageSize()), query, treeCode);
|
return PageDTO.of(page);
|
}
|
|
/**
|
* 暂存间入库记录导出
|
*
|
* @param query
|
* @param response
|
*/
|
@Override
|
public void storageRecordExport(StorageRecordQuery query, HttpServletResponse response) throws IOException {
|
String treeCode = sysDepartmentService.getTreeCodeByDepartmentId(query.getDepartmentId());
|
if (StringUtils.isBlank(treeCode)) {
|
return;
|
}
|
List<MwStorageRecordVO> list = baseMapper.storageRecordList(query, treeCode);
|
// 这里注意 有同学反应使用swagger 会导致各种问题,请直接用浏览器或者用postman
|
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
|
response.setCharacterEncoding("utf-8");
|
// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
|
String fileName = URLEncoder.encode("暂存间入库记录", "UTF-8").replaceAll("\\+", "%20");
|
response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
|
FastExcel.write(response.getOutputStream(), MwStorageRecordVO.class)
|
.registerWriteHandler(new AutoColumnWidthEntityStrategy())
|
.sheet("暂存间入库记录").doWrite(list);
|
}
|
|
/**
|
* 暂存间出库记录
|
*
|
* @param query
|
* @return
|
*/
|
@Override
|
public PageDTO<MwCheckoutRecordVO> checkoutRecord(CheckoutRecordQuery query) {
|
String treeCode = sysDepartmentService.getTreeCodeByDepartmentId(query.getDepartmentId());
|
if (StringUtils.isBlank(treeCode)) {
|
return PageDTO.empty(0L, 0L);
|
}
|
Page<MwCheckoutRecordVO> page = baseMapper.checkoutRecordPage(new Page<>(query.getPageCurr(), query.getPageSize()), query, treeCode);
|
return PageDTO.of(page);
|
}
|
|
/**
|
* 暂存间出库记录导出
|
*
|
* @param query
|
* @param response
|
*/
|
@Override
|
public void checkoutRecordExport(CheckoutRecordQuery query, HttpServletResponse response) throws IOException {
|
String treeCode = sysDepartmentService.getTreeCodeByDepartmentId(query.getDepartmentId());
|
if (StringUtils.isBlank(treeCode)) {
|
return;
|
}
|
List<MwCheckoutRecordVO> list = baseMapper.checkoutRecordList(query, treeCode);
|
CopyOptions copyOptions = new CopyOptions();
|
copyOptions.setIgnoreProperties("hospitalSignature");
|
List<MwCheckoutRecordExcel> mwCheckoutRecordExcels = BeanUtils.copyToList(list, MwCheckoutRecordExcel.class, copyOptions);
|
for (MwCheckoutRecordExcel mwCheckoutRecordExcel : mwCheckoutRecordExcels) {
|
for (MwCheckoutRecordVO mwCheckoutRecordVO : list) {
|
if (mwCheckoutRecordVO.getId().equals(mwCheckoutRecordExcel.getId())) {
|
if (StringUtils.isNotBlank(mwCheckoutRecordVO.getHospitalSignature())) {
|
try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
|
//获取文件后缀
|
String extension = FilenameUtils.getExtension(mwCheckoutRecordVO.getHospitalSignature());
|
BufferedImage originalImage = ImageIO.read(ImgUtils.getFileByHttpURL(mwCheckoutRecordVO.getHospitalSignature()));
|
Thumbnails.of(originalImage).scale(0.8).rotate(270).outputFormat(extension).toOutputStream(outputStream);
|
mwCheckoutRecordExcel.setHospitalSignature(outputStream.toByteArray());
|
} catch (IOException e) {
|
throw new RuntimeException(e);
|
}
|
|
}
|
}
|
}
|
}
|
response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
|
response.setCharacterEncoding("utf-8");
|
String fileName = URLEncoder.encode("暂存间出库记录", "UTF-8").replaceAll("\\+", "%20");
|
response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");
|
FastExcel.write(response.getOutputStream(), MwCheckoutRecordExcel.class)
|
.registerWriteHandler(new AutoColumnWidthEntityStrategy())
|
.registerWriteHandler(new CustomCellWriteHeightConfig())
|
.sheet("暂存间出库记录")
|
.doWrite(mwCheckoutRecordExcels);
|
}
|
|
@Override
|
public List<MwStagingRoomVO> queryStagingRoomList() {
|
return baseMapper.queryStagingRoomList();
|
}
|
|
/**
|
* 暂存间待处理医废分页列表
|
*
|
* @param query
|
* @return
|
*/
|
@Override
|
public PageDTO<MwStorageRecordVO> temporarilyStoredMedicalWaste(StorageRecordQuery query) {
|
return PageDTO.of(baseMapper.temporarilyStoredMedicalWaste(new Page<MwStorageRecordVO>(query.getPageCurr(), query.getPageSize()), query));
|
}
|
|
/**
|
* 根据医废查询使用列表
|
*
|
* @param id 微波设备id
|
* @return
|
*/
|
@Override
|
public List<MwStorageRecordVO> queryMedicalWasteList(Long id) {
|
return baseMapper.queryMedicalWasteList(id);
|
}
|
}
|