package com.yuanchu.mom.service.impl; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.deepoove.poi.XWPFTemplate; import com.deepoove.poi.config.Configure; import com.deepoove.poi.data.Pictures; import com.yuanchu.mom.dto.FeIlluminationDto; import com.yuanchu.mom.dto.FeIlluminationExportDto; import com.yuanchu.mom.dto.FePowerStableExportDto; import com.yuanchu.mom.exception.ErrorException; import com.yuanchu.mom.mapper.FeIlluminationDetectionAreaMapper; import com.yuanchu.mom.mapper.UserMapper; import com.yuanchu.mom.pojo.FeIllumination; import com.yuanchu.mom.mapper.FeIlluminationMapper; import com.yuanchu.mom.pojo.FeIlluminationDetectionArea; import com.yuanchu.mom.pojo.FeMeasuredQuantity; import com.yuanchu.mom.service.FeIlluminationService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.yuanchu.mom.utils.HackLoopTableRenderPolicy; import com.yuanchu.mom.utils.DateImageUtil; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import javax.annotation.Resource; import javax.servlet.http.HttpServletResponse; import java.io.InputStream; import java.io.OutputStream; import java.net.URLEncoder; import java.time.Instant; import java.time.LocalDateTime; import java.time.ZoneId; import java.util.HashMap; import java.util.List; /** *

* 设施和环境条件-设施和环境条件要求-照度记录表 服务实现类 *

* * @author * @since 2024-11-07 04:15:57 */ @Service public class FeIlluminationServiceImpl extends ServiceImpl implements FeIlluminationService { @Resource private FeIlluminationDetectionAreaMapper feIlluminationDetectionAreaMapper; @Resource private UserMapper userMapper; @Value("${file.path}") private String imgUrl; @Override public IPage getFeLightningProtection(Page page) { return baseMapper.getFeLightningProtection(page); } /** * 导出照度记录 * @param intensityIlluminationId * @param response */ @Override public void exportFeIllumination(Integer intensityIlluminationId, HttpServletResponse response) { FeIlluminationExportDto illuminationExportDto = baseMapper.selectFeIllumination(intensityIlluminationId); // 检测人 String testerUrl = null; if (illuminationExportDto.getTesterId() != null) { testerUrl = userMapper.selectById(illuminationExportDto.getTesterId()).getSignatureUrl(); if (StringUtils.isBlank(testerUrl)) { throw new ErrorException("找不到检测人的签名"); } } // 核查人 String checkerUrl = null; if (illuminationExportDto.getCheckerId() != null) { checkerUrl = userMapper.selectById(illuminationExportDto.getCheckerId()).getSignatureUrl(); if (StringUtils.isBlank(checkerUrl)) { throw new ErrorException("找不到核查人的签名"); } } // 查询详情 List feIlluminationDetectionAreas = feIlluminationDetectionAreaMapper.selectList(Wrappers.lambdaQuery() .eq(FeIlluminationDetectionArea::getIntensityIlluminationId, intensityIlluminationId)); // 获取路径 InputStream inputStream = this.getClass().getResourceAsStream("/static/illumination.docx"); Configure configure = Configure.builder() .bind("detectionAreaList", new HackLoopTableRenderPolicy()) .build(); String finalTesterUrl = testerUrl; String finalCheckerUrl = checkerUrl; // 判断检测日期是否为空 LocalDateTime localDateTime = null; if (illuminationExportDto.getTestDate() != null) { Instant instant = illuminationExportDto.getTestDate().toInstant(); ZoneId zoneId = ZoneId.systemDefault(); localDateTime = instant.atZone(zoneId).toLocalDateTime(); } LocalDateTime finalLocalDateTime = localDateTime; XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("illumination", illuminationExportDto); put("detectionAreaList", feIlluminationDetectionAreas); put("testerUrl", StringUtils.isNotBlank(finalTesterUrl) ? Pictures.ofLocal(imgUrl + "/" + finalTesterUrl).create() : null); put("checkerUrl", StringUtils.isNotBlank(finalCheckerUrl) ? Pictures.ofLocal(imgUrl + "/" + finalCheckerUrl).create() : null); put("testDateUrl", finalLocalDateTime != null ? Pictures.ofStream(DateImageUtil.createDateImage(finalLocalDateTime)).create() : null); }}); try { response.setContentType("application/msword"); String fileName = URLEncoder.encode( "照明记录导出", "UTF-8"); response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".docx"); OutputStream os = response.getOutputStream(); template.write(os); os.flush(); os.close(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException("导出失败"); } } }