package com.yuanchu.mom.service.impl; import com.alibaba.excel.EasyExcel; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.ObjectUtils; 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.common.GetLook; import com.yuanchu.mom.dto.PersonSupervisePlanDto; import com.yuanchu.mom.dto.PersonTrainingDetailedDto; import com.yuanchu.mom.excel.PersonSupervisePlanDetailsListener; import com.yuanchu.mom.excel.PersonSupervisePlanDetailsUpload; import com.yuanchu.mom.exception.ErrorException; import com.yuanchu.mom.mapper.UserMapper; import com.yuanchu.mom.pojo.PersonSupervisePlan; import com.yuanchu.mom.mapper.PersonSupervisePlanMapper; import com.yuanchu.mom.pojo.PersonSupervisePlanDetails; import com.yuanchu.mom.pojo.PersonTraining; import com.yuanchu.mom.service.PersonSupervisePlanDetailsService; import com.yuanchu.mom.service.PersonSupervisePlanService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.yuanchu.mom.utils.HackLoopTableRenderPolicy; import com.yuanchu.mom.utils.DateImageUtil; import com.yuanchu.mom.utils.Jwt; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import org.springframework.web.multipart.MultipartFile; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.time.LocalDateTime; import java.time.format.DateTimeFormatter; import java.util.HashMap; import java.util.List; import java.util.Map; /** *

* 监督计划 - 父 服务实现类 *

* * @author 芯导软件(江苏)有限公司 * @since 2024-10-09 04:14:45 */ @Service @Transactional(rollbackFor = Exception.class) public class PersonSupervisePlanServiceImpl extends ServiceImpl implements PersonSupervisePlanService { @Autowired private PersonSupervisePlanDetailsService personSupervisePlanDetailsService; @Autowired private GetLook getLook; @Value("${file.path}") private String imgUrl; @Autowired private UserMapper userMapper; public IPage yearPlanDtoIPage(Page page, String organizationPerson) { return baseMapper.pageByPerson(page, organizationPerson); } @Override public void yearPlanDetailImport(MultipartFile file) { Map map1 = getLook.selectPowerByMethodAndUserId("selectInsOrderParameter"); // 年度计划父级新增数据 PersonSupervisePlan personSupervisePlan = new PersonSupervisePlan(); String fileName = file.getOriginalFilename().substring(0, file.getOriginalFilename().lastIndexOf(".")); personSupervisePlan.setFileName(fileName); personSupervisePlan.setOrganizationPersonId(map1.get("userId")); personSupervisePlan.setOrganizationDate(LocalDateTime.now()); baseMapper.insert(personSupervisePlan); // 年度计划详情 新增 try { PersonSupervisePlanDetailsListener personSupervisePlanDetailsListener = new PersonSupervisePlanDetailsListener(personSupervisePlanDetailsService); personSupervisePlanDetailsListener.setPlanId(personSupervisePlan.getId()); EasyExcel.read(file.getInputStream(), PersonSupervisePlanDetailsUpload.class, personSupervisePlanDetailsListener).sheet().doRead(); } catch (IOException e) { e.printStackTrace(); } } /** * 导出人员监督计划 * @param id * @param response */ @Override public void exportSuperVisePlan(Integer id, HttpServletResponse response) { // 查询详情 PersonSupervisePlan personSupervisePlan = baseMapper.selectById(id); //获取提交人的签名地址 String organizationUrl = userMapper.selectById(personSupervisePlan.getOrganizationPersonId()).getSignatureUrl(); if (StringUtils.isBlank(organizationUrl)) { throw new ErrorException("找不到检验人的签名"); } //获取批准人的签名地址 String approvalUrl = null; if (personSupervisePlan.getApprovalId() != null) { approvalUrl = userMapper.selectById(personSupervisePlan.getApprovalId()).getSignatureUrl(); if (StringUtils.isBlank(approvalUrl)) { throw new ErrorException("找不到批准人的签名"); } } // 查询详情 List detailedDtos = personSupervisePlanDetailsService.list(Wrappers.lambdaQuery() .eq(PersonSupervisePlanDetails::getPlanId, id)); int index = 1; SimpleDateFormat formatter = new SimpleDateFormat("yyyy年MM月dd日"); for (PersonSupervisePlanDetails detailedDto : detailedDtos) { detailedDto.setIndex(index); detailedDto.setSuperviseDateString(formatter.format(detailedDto.getSuperviseDate())); index++; } // 获取路径 InputStream inputStream = this.getClass().getResourceAsStream("/static/super-vise-plan.docx"); Configure configure = Configure.builder() .bind("supervisePlanDetailsList", new HackLoopTableRenderPolicy()) .build(); String finalApprovalUrl = approvalUrl; XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("supervisePlanDetailsList", detailedDtos); put("organizationUrl", StringUtils.isNotBlank(organizationUrl) ? Pictures.ofLocal(imgUrl + "/" + organizationUrl).create() : null); put("approvalUrl", StringUtils.isNotBlank(finalApprovalUrl) ? Pictures.ofLocal(imgUrl + "/" + finalApprovalUrl).create() : null); put("writeDateUrl", personSupervisePlan.getOrganizationDate() != null ? Pictures.ofStream(DateImageUtil.createDateImage(personSupervisePlan.getOrganizationDate())).create() : null); put("ratifyDateUrl", personSupervisePlan.getApprovalDate() != null ? Pictures.ofStream(DateImageUtil.createDateImage(personSupervisePlan.getApprovalDate())).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("导出失败"); } } }