package com.ruoyi.require.service.impl; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; import com.baomidou.mybatisplus.core.toolkit.StringUtils; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.deepoove.poi.XWPFTemplate; import com.deepoove.poi.config.Configure; import com.deepoove.poi.data.Pictures; import com.ruoyi.common.utils.QueryWrappers; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.inspect.util.HackLoopTableRenderPolicy; import com.ruoyi.require.dto.FeTempHumDateDto; import com.ruoyi.require.dto.FeTempHumRecordDto; import com.ruoyi.require.mapper.FeTempHumDateMapper; import com.ruoyi.require.pojo.FeTempHumDate; import com.ruoyi.require.pojo.FeTempHumRecord; import com.ruoyi.require.service.FeTempHumDateService; import com.ruoyi.require.service.FeTempHumRecordService; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; import javax.servlet.http.HttpServletResponse; import java.io.InputStream; import java.io.OutputStream; import java.net.URLEncoder; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; /** *

* 设施和环境条件-设施和环境条件要求-温湿度 区域 -父 服务实现类 *

* * @author * @since 2024-11-09 11:02:18 */ @Service public class FeTempHumDateServiceImpl extends ServiceImpl implements FeTempHumDateService { @Resource private FeTempHumRecordService feTempHumRecordService; @Value("${file.path}") private String imgUrl; @Override public IPage getFeTempHumDate(Page page, FeTempHumDateDto feTempHumDateDto) { return baseMapper.getFeTempHumDate(page, QueryWrappers.queryWrappers(feTempHumDateDto)); } @Override public void exportTemperatureAndHumidityRecords(Integer dateId, HttpServletResponse response) { FeTempHumDate feTempHumDate = baseMapper.selectById(dateId); // 获取年度月度时间 String[] month = feTempHumDate.getMonthDate().split("-"); IPage list = feTempHumRecordService.getFeTempHumRecordPage(new Page<>(1, -1), dateId); List feTempHumRecordDtos = list.getRecords(); // 按照天数分组 Map> groupMap = feTempHumRecordDtos.stream().peek(feTempHumRecordDto -> { feTempHumRecordDto.setMonthDay(feTempHumRecordDto.getRecordDate().getDayOfMonth()); }) .collect(Collectors.groupingBy(FeTempHumRecordDto::getMonthDay)); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("HH:mm"); // 遍历31获取31个对象 List recordDtoList = new ArrayList<>(); for (int i = 1; i <= 31; i++) { FeTempHumRecordDto recordDto = new FeTempHumRecordDto(); recordDto.setMonth(i); recordDtoList.add(recordDto); // 获取当前月的 List recordDtos = groupMap.get(i); if (CollectionUtils.isNotEmpty(recordDtos)) { // 复制对象 BeanUtils.copyProperties(recordDtos.get(0), recordDto, "month"); recordDto.setMorningTestTimeStr(recordDto.getMorningTestTime() == null ? null : recordDto.getMorningTestTime().format(formatter)); recordDto.setAfternoonTimeStr(recordDto.getAfternoonTime() == null ? null : recordDto.getAfternoonTime().format(formatter)); recordDto.setMorningRecorderUrlRender(StringUtils.isNotBlank(recordDto.getMorningRecorderUrl()) ? Pictures.ofLocal(imgUrl + "/" + recordDto.getMorningRecorderUrl()).create() : null); recordDto.setAfternoonRecorderUrlRender(StringUtils.isNotBlank(recordDto.getAfternoonRecorderUrl()) ? Pictures.ofLocal(imgUrl + "/" + recordDto.getAfternoonRecorderUrl()).create() : null); } } // 获取路径 InputStream inputStream = this.getClass().getResourceAsStream("/static/temp_hum_date.docx"); Configure configure = Configure.builder() .bind("recordList", new HackLoopTableRenderPolicy()) .build(); HashMap map = new HashMap<>(); map.put("testAreaName", feTempHumDate.getTestAreaName()); map.put("experimentalYear", month[0]); map.put("experimentalMonth", month[1]); map.put("subjoin", feTempHumDate.getSubjoin()); XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("feTempHum", map); put("recordList", recordDtoList); }}); 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(); inputStream.close(); } catch (Exception e) { e.printStackTrace(); throw new RuntimeException("导出失败"); } } /** * 温湿度确认 * @param feTempHumDate */ @Override @Transactional(rollbackFor = Exception.class) public void affirmFeTempHumDate(FeTempHumDate feTempHumDate) { // 温湿度确认 this.update(Wrappers.lambdaUpdate() .eq(FeTempHumDate::getDateId, feTempHumDate.getDateId()) .set(FeTempHumDate::getRegistrarUserId, feTempHumDate.getRegistrarUserId())); } }