package com.ruoyi.personnel.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.core.toolkit.CollectionUtils; 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.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.deepoove.poi.XWPFTemplate; import com.deepoove.poi.config.Configure; import com.ruoyi.common.core.domain.entity.User; import com.ruoyi.common.utils.SecurityUtils; import com.ruoyi.framework.exception.ErrorException; import com.ruoyi.framework.util.HackLoopTableRenderPolicy; import com.ruoyi.performance.mapper.AuxiliaryWorkingHoursDayMapper; import com.ruoyi.performance.mapper.PerformanceShiftMapper; import com.ruoyi.performance.pojo.AuxiliaryWorkingHoursDay; import com.ruoyi.performance.pojo.PerformanceShift; import com.ruoyi.performance.service.AuxiliaryWorkingHoursDayService; import com.ruoyi.personnel.dto.PersonTrainingRecordDto; import com.ruoyi.personnel.dto.PersonTrainingRecordListDto; import com.ruoyi.personnel.dto.TrainingRecordPersonDetailedDto; import com.ruoyi.personnel.mapper.*; import com.ruoyi.personnel.pojo.*; import com.ruoyi.personnel.service.PersonTrainingDetailedService; import com.ruoyi.personnel.service.PersonTrainingRecordService; import com.ruoyi.system.mapper.UserMapper; import org.springframework.beans.factory.annotation.Autowired; 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.math.BigDecimal; import java.math.RoundingMode; import java.net.URLEncoder; import java.text.SimpleDateFormat; import java.time.*; import java.time.temporal.TemporalField; import java.time.temporal.WeekFields; import java.util.*; /** *

* 培训记录 服务实现类 *

* * @author 芯导软件(江苏)有限公司 * @since 2024-10-12 04:50:48 */ @Transactional(rollbackFor = Exception.class) @Service public class PersonTrainingRecordServiceImpl extends ServiceImpl implements PersonTrainingRecordService { @Resource private UserMapper userMapper; @Resource private PersonTrainingDetailedService personTrainingDetailedService; @Resource private PersonTrainingDetailedMapper personTrainingDetailedMapper; @Resource private AuxiliaryWorkingHoursDayMapper auxiliaryWorkingHoursDayMapper; @Resource private PerformanceShiftMapper shiftMapper; @Autowired private AuxiliaryWorkingHoursDayService auxiliaryWorkingHoursDayService; @Override public List trainingAndAssessmentRecordsPage(Integer trainingDetailedId, String userName) { return baseMapper.trainingAndAssessmentRecordsPage(trainingDetailedId, userName); } @Override public void deleteTrainingAndAssessmentRecords(String ids) { String[] split = ids.split(","); if (split.length > 0) { for (String s : split) { baseMapper.deleteById(s); } } } @Override public IPage personnelTrainingPersonnel(Page page, String userName, Integer userId, Integer departLimsId) { return baseMapper.personnelTrainingPersonnel(page, userName, userId, departLimsId); } @Override public IPage queryPersonnelDetails(Page page, Integer userId) { return baseMapper.queryPersonnelDetails(page, userId); } @Override public void claimOfTrainingAndAssessmentRecords(Boolean claimAndClaim, Integer courseId) { int userId = SecurityUtils.getUserId().intValue(); // 1、查询培训课程,取培训日期与开始日期,与当前时间比较,判断是否超出,如果超出不允许认领 Boolean doesItExceedState = doesItExceed(courseId); if (!doesItExceedState) { throw new ErrorException("当前课程状态无法认领!"); } // 2、判断是否重复 PersonTrainingRecord personTrainingRecord1 = baseMapper.selectOne(Wrappers.lambdaQuery() .eq(PersonTrainingRecord::getCourseId, courseId) .eq(PersonTrainingRecord::getUserId, userId)); if (ObjectUtils.isNotEmpty(personTrainingRecord1)) { throw new ErrorException("请勿重复认领!"); } // 3、如果未重复新增培训记录 // true 认领 if (claimAndClaim) { PersonTrainingRecord personTrainingRecord = new PersonTrainingRecord(); personTrainingRecord.setUserId(userId); personTrainingRecord.setCourseId(courseId); baseMapper.insert(personTrainingRecord); // 取消认领 } else { baseMapper.delete(Wrappers.lambdaQuery() .eq(PersonTrainingRecord::getUserId, userId) .eq(PersonTrainingRecord::getCourseId, courseId)); } } /** * 导出人员培训记录 * @param userId * @param response */ @Override public void exportTrainingRecord(Integer userId, HttpServletResponse response) { // 查询人员人信息 PersonTrainingRecordListDto trainingRecordListDto = baseMapper.selectUserTraining(userId); // 查询培训记录 List personDetailedDtos = baseMapper.selectPersonDetailedDtos(userId); // 获取路径 InputStream inputStream = this.getClass().getResourceAsStream("/static/training-record.docx"); Configure configure = Configure.builder() .bind("personnelDetailsLisat", new HackLoopTableRenderPolicy()) .build(); XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("traning", trainingRecordListDto); put("personnelDetailsLisat", personDetailedDtos); }}); 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("导出失败"); } } @Override public IPage queryPersonnelDetailsOfUserIdAndYear(Page page, Integer userId, Integer year) { return baseMapper.queryPersonnelDetailsOfUserIdAndYear(page, userId, year); } @Override public void exportTrainingRecordAddTrainingDate(Integer userId, Integer trainingDate, HttpServletResponse response) { // 查询人员人信息 PersonTrainingRecordListDto trainingRecordListDto = baseMapper.selectUserTraining(userId); // 查询培训记录 List personDetailedDtos = baseMapper.selectPersonDetailedDtosByTrainingDate(userId, trainingDate); // 获取路径 InputStream inputStream = this.getClass().getResourceAsStream("/static/training-record.docx"); Configure configure = Configure.builder() .bind("personnelDetailsLisat", new HackLoopTableRenderPolicy()) .build(); XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( new HashMap() {{ put("traning", trainingRecordListDto); put("personnelDetailsLisat", personDetailedDtos); }}); 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("导出失败"); } } @Override public void outOfFocusPreservation(PersonTrainingRecord personTrainingRecord) { int userId = SecurityUtils.getUserId().intValue(); // 培训通过了,培训课时计入到当天的辅助工时 (辅助工时 以及 核准工时都添加) baseMapper.updateById(personTrainingRecord); PersonTrainingDetailed personTrainingDetailed = personTrainingDetailedMapper.selectById(personTrainingRecord.getCourseId()); if(Objects.nonNull(personTrainingDetailed)) { Double classHour = personTrainingDetailed.getClassHour(); // 课时 String trainingDateTwo = personTrainingDetailed.getTrainingDateTwo(); // 培训日期 if(StringUtils.isEmpty(trainingDateTwo)) { throw new ErrorException("没有设置培训日期无法添加辅助工时"); } // 是否以及添加过了 List auxiliaryWorkingHoursDays = auxiliaryWorkingHoursDayMapper.selectList(new LambdaQueryWrapper() .eq(AuxiliaryWorkingHoursDay::getNameUser, personTrainingRecord.getUserId()) .eq(AuxiliaryWorkingHoursDay::getAuxiliaryProject, personTrainingDetailed.getTrainingContent()) .eq(AuxiliaryWorkingHoursDay::getCreateUser, userId) .eq(AuxiliaryWorkingHoursDay::getDateTime, trainingDateTwo + " 00:00:00")); // 如果有数据 合格就不做处理 不合格就删除 if(CollectionUtils.isNotEmpty(auxiliaryWorkingHoursDays)) { if(personTrainingRecord.getExaminationResults().equals("不合格")) { auxiliaryWorkingHoursDayMapper.delete(new LambdaQueryWrapper() .eq(AuxiliaryWorkingHoursDay::getNameUser, personTrainingRecord.getUserId()) .eq(AuxiliaryWorkingHoursDay::getAuxiliaryProject, personTrainingDetailed.getTrainingContent()) .eq(AuxiliaryWorkingHoursDay::getCreateUser, userId) .eq(AuxiliaryWorkingHoursDay::getDateTime, trainingDateTwo + " 00:00:00")); } } // 是否通过 if(personTrainingRecord.getExaminationResults().equals("合格") && CollectionUtils.isEmpty(auxiliaryWorkingHoursDays)) { // 如果是检测办的人就不用加 User user = userMapper.selectById(personTrainingRecord.getUserId()); if(user.getDepartLimsId().contains("22")) { return; } // 一节课45分钟 工时60分钟 BigDecimal minute = BigDecimal.valueOf(classHour).multiply(new BigDecimal("45")); // 具体分钟 BigDecimal divide = minute.divide(new BigDecimal("60"),4, RoundingMode.HALF_UP); // 工时 // 添加数据 AuxiliaryWorkingHoursDay a = new AuxiliaryWorkingHoursDay(); a.setNameUser(personTrainingRecord.getUserId()); // 姓名id // 项目名称 a.setRemarks(personTrainingDetailed.getTrainingContent()); // 辅助说明 a.setNumber("401"); // 编号 AuxiliaryWorkingHoursDay auxiliaryWorkingHoursDay = auxiliaryWorkingHoursDayService.selectAuxiliaryWorkingHoursByNumber("401"); a.setAuxiliaryProject(auxiliaryWorkingHoursDay.getAuxiliaryProject()); // 辅助项目名称 a.setNonproductiveTime(Double.parseDouble(divide.toString())); // 辅助工时 a.setApprovedWorkingHour(auxiliaryWorkingHoursDay.getApprovedWorkingHour()); // 核准工时 a.setAmount(Double.parseDouble(divide.toString())); // 数量 String year = trainingDateTwo.split("-")[0]; a.setYear(year); // 年 a.setCreateTime(LocalDateTime.now()); a.setUpdateTime(LocalDateTime.now()); a.setCreateUser(userId); // 创建人id a.setUpdateUser(userId); // 修改人id a.setState("已提交"); // 状态 a.setDateTime(trainingDateTwo + " 00:00:00"); // 日期 // 获取当前日期 LocalDate today = LocalDate.now(); // 获取当前日期的周次(一年中的第几周) TemporalField weekOfYear = WeekFields.of(Locale.getDefault()).weekOfYear(); int weekNumber = today.get(weekOfYear); // 获取当前日期的星期(一周中的第几天) DayOfWeek dayOfWeek = today.getDayOfWeek(); int dayOfWeekNumber = dayOfWeek.getValue(); LocalDate now = LocalDate.now(); LocalTime parse = LocalTime.parse("00:00:00"); LocalDateTime of = LocalDateTime.of(now, parse); PerformanceShift performanceShift = shiftMapper.selectOne(new LambdaQueryWrapper().eq(PerformanceShift::getWorkTime, of) .eq(PerformanceShift::getUserId, personTrainingRecord.getUserId())); if(Objects.nonNull(performanceShift)) { a.setShift(performanceShift.getShift()); // 班次 } a.setWeek(weekNumber+""); // 周次 a.setWeekDay(dayOfWeekNumber == 7 ? 0+"" : dayOfWeekNumber+""); // 星期 auxiliaryWorkingHoursDayMapper.insert(a); } } } /** * 检验该培训课程是否允许认领 * @param courseId 该课程的id * @return */ public Boolean doesItExceed(Integer courseId) { PersonTrainingDetailed personTrainingDetailed = personTrainingDetailedService.getById(courseId); // 只有状态为3可以认领 if (!personTrainingDetailed.getState().equals(3)) { return false; } SimpleDateFormat sdfWithoutTime = new SimpleDateFormat("yyyy-MM-dd"); if(Objects.isNull(personTrainingDetailed.getTrainingDateTwo()) || StringUtils.isEmpty(personTrainingDetailed.getTrainingDateTwo())) { throw new ErrorException("未配置培训日期,无法报名"); } LocalDate parse = LocalDate.parse(personTrainingDetailed.getTrainingDateTwo()); Date from = Date.from(parse.atStartOfDay(ZoneId.systemDefault()).toInstant()); String originalDateStr = sdfWithoutTime.format(from); SimpleDateFormat sdfWithTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { if(Objects.isNull(personTrainingDetailed.getOpeningTime()) || StringUtils.isEmpty(personTrainingDetailed.getOpeningTime())) { throw new ErrorException("未配置具体时间,无法报名"); } // 添加时分秒后的日期 Date addedDate = sdfWithTime.parse(originalDateStr + " " + personTrainingDetailed.getOpeningTime()); // 获取当前时间 Date currentDate = new Date(); // 日期未超出当前时间。 if (addedDate.after(currentDate) || addedDate.equals(currentDate)) { return true; // 日期已超出当前时间 } else { // 如果日期超出 更新课程状态为已结束 personTrainingDetailedService.update(Wrappers.lambdaUpdate() .eq(PersonTrainingDetailed::getId, courseId) .set(PersonTrainingDetailed::getState, 2)); return false; } } catch (Exception e) { throw new ErrorException("时间格式错误!"); } } }