package com.yuanchu.mom.service.impl; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.ObjectUtils; 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.config.ConfigureBuilder; import com.deepoove.poi.data.FilePictureRenderData; import com.yuanchu.mom.dto.InternalMeetingParticipantDto; import com.yuanchu.mom.dto.ManageMeetingDto; import com.yuanchu.mom.dto.ManageMeetingParticipantsDto; import com.yuanchu.mom.exception.ErrorException; import com.yuanchu.mom.mapper.DepartmentMapper; import com.yuanchu.mom.mapper.ManageMeetingParticipantsMapper; import com.yuanchu.mom.mapper.UserMapper; import com.yuanchu.mom.pojo.ManageMeeting; import com.yuanchu.mom.mapper.ManageMeetingMapper; import com.yuanchu.mom.pojo.ManageMeetingParticipants; import com.yuanchu.mom.pojo.ManageReviewProgram; import com.yuanchu.mom.pojo.User; import com.yuanchu.mom.service.ManageMeetingService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.yuanchu.mom.utils.HackLoopTableRenderPolicy; import org.springframework.beans.factory.annotation.Autowired; 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.sql.Wrapper; 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-11 09:33:47 */ @Service public class ManageMeetingServiceImpl extends ServiceImpl implements ManageMeetingService { @Resource private ManageMeetingParticipantsMapper manageMeetingParticipantsMapper; @Autowired private UserMapper userMapper; @Override public IPage page(Page page, String startTime, String endTime, String place) { IPage iPage = this.baseMapper.page(page, startTime, endTime, place); for (ManageMeetingDto record : iPage.getRecords()) { List manageMeetingParticipants = manageMeetingParticipantsMapper.selectList(Wrappers.lambdaQuery().eq(ManageMeetingParticipants::getMeetingId, record.getId())); String collect = manageMeetingParticipants.stream().map(manageMeetingParticipants1 -> { return manageMeetingParticipants1.getParticipants() + ""; }).collect(Collectors.joining(",")); record.setParticipant(collect); } return iPage; } @Override public void addMeeting(ManageMeetingDto dto) { this.baseMapper.insert(dto); String[] ids = dto.getParticipant().split(","); List list = new ArrayList<>(); for (String id : ids) { User user = userMapper.selectById(id); ManageMeetingParticipants participants = new ManageMeetingParticipants(); participants.setMeetingId(dto.getId()); participants.setParticipants(Integer.parseInt(id)); participants.setDepartment(user.getDepartment()); list.add(participants); } list.forEach(v -> manageMeetingParticipantsMapper.insert(v)); } @Override public int modifyMeeting(ManageMeetingDto manageMeetingDto) { this.baseMapper.updateById(manageMeetingDto); manageMeetingParticipantsMapper.delete(Wrappers.lambdaQuery().eq(ManageMeetingParticipants::getMeetingId, manageMeetingDto.getId())); String[] ids = manageMeetingDto.getParticipant().split(","); List list = new ArrayList<>(); for (String id : ids) { User user = userMapper.selectById(id); ManageMeetingParticipants participants = new ManageMeetingParticipants(); participants.setMeetingId(manageMeetingDto.getId()); participants.setParticipants(Integer.parseInt(id)); participants.setDepartment(user.getDepartment()); list.add(participants); } list.forEach(v -> manageMeetingParticipantsMapper.insert(v)); return 0; } @Override public void exportMeeting(Integer id, HttpServletResponse response) { ManageMeeting meeting = baseMapper.selectById(id); // 查询参加人员 List manageMeetingParticipants = manageMeetingParticipantsMapper.selectList(Wrappers.lambdaQuery().eq(ManageMeetingParticipants::getMeetingId, id)); List list = manageMeetingParticipants.stream().map(manageMeetingParticipants1 -> { manageMeetingParticipants1.setUserName(userMapper.selectById(manageMeetingParticipants1.getParticipants()).getName()); manageMeetingParticipants1.setDepartment(userMapper.selectUserDepartmentLimsName(manageMeetingParticipants1.getParticipants())); return manageMeetingParticipants1; }).collect(Collectors.toList()); // 创建空对象 List participants = new ArrayList<>(); // 添加参加人员 for (int i = 0; i < list.size(); i++) { // 判断有没有到11行 if (i % 2 == 0) { ManageMeetingParticipantsDto manageMeetingParticipantsDto = new ManageMeetingParticipantsDto(); manageMeetingParticipantsDto.setUserName1(list.get(i).getUserName()); manageMeetingParticipantsDto.setDepartment1(list.get(i).getDepartment()); participants.add(manageMeetingParticipantsDto); } else { participants.get((i-1)/2).setUserName2(list.get(i).getUserName()); participants.get((i-1)/2).setDepartment2(list.get(i).getDepartment()); } } InputStream inputStream = this.getClass().getResourceAsStream("/static/review-meet.docx"); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy年MM月dd日"); Configure configure = Configure.builder() .bind("meetingDetails", new HackLoopTableRenderPolicy()) .build(); XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("meeting", meeting); put("meetingTime", meeting.getMeetingTime().format(formatter)); put("meetingDetails", participants); }}); 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("导出失败"); } } }