From 4f3a98f19143865cdc1de4791e8a95d96bd40c65 Mon Sep 17 00:00:00 2001 From: maven <2163098428@qq.com> Date: 星期五, 01 八月 2025 13:27:59 +0800 Subject: [PATCH] yys 密码已重置 --- cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceCalibrationPlanServiceImpl.java | 357 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 357 insertions(+), 0 deletions(-) diff --git a/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceCalibrationPlanServiceImpl.java b/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceCalibrationPlanServiceImpl.java new file mode 100644 index 0000000..acf6965 --- /dev/null +++ b/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceCalibrationPlanServiceImpl.java @@ -0,0 +1,357 @@ +package com.ruoyi.device.service.impl; + +import com.alibaba.excel.EasyExcel; +import com.alibaba.excel.context.AnalysisContext; +import com.alibaba.excel.event.AnalysisEventListener; +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.ruoyi.common.constant.MenuJumpPathConstants; +import com.ruoyi.common.core.domain.entity.InformationNotification; +import com.ruoyi.common.core.domain.entity.User; +import com.ruoyi.common.utils.QueryWrappers; +import com.ruoyi.common.utils.SecurityUtils; +import com.ruoyi.common.utils.WxCpUtils; +import com.ruoyi.device.dto.DeviceCalibrationPlanDetailDto; +import com.ruoyi.device.dto.DeviceCalibrationPlanDto; +import com.ruoyi.device.excel.upload.DeviceCalibrationPlanDetailUpload; +import com.ruoyi.device.mapper.DeviceCalibrationPlanDetailMapper; +import com.ruoyi.device.mapper.DeviceCalibrationPlanMapper; +import com.ruoyi.device.pojo.DeviceCalibrationPlan; +import com.ruoyi.device.pojo.DeviceCalibrationPlanDetail; +import com.ruoyi.device.service.DeviceCalibrationPlanDetailService; +import com.ruoyi.device.service.DeviceCalibrationPlanService; +import com.ruoyi.inspect.util.HackLoopTableRenderPolicy; +import com.ruoyi.inspect.util.UserUtils; +import com.ruoyi.system.mapper.UserMapper; +import com.ruoyi.system.service.InformationNotificationService; +import org.springframework.beans.BeanUtils; +import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.web.multipart.MultipartFile; + +import javax.annotation.Resource; +import javax.servlet.http.HttpServletResponse; +import java.io.IOException; +import java.io.InputStream; +import java.io.OutputStream; +import java.net.URLEncoder; +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.time.format.DateTimeFormatter; +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; + +/** + * <p> + * 璁惧鏍″噯璁″垝涓昏〃 鏈嶅姟瀹炵幇绫� + * </p> + * + * @author 姹熻嫃榈烽洀缃戠粶绉戞妧鏈夐檺鍏徃 + * @since 2024-12-16 03:58:17 + */ +@Service +@Transactional(rollbackFor = Exception.class) +public class DeviceCalibrationPlanServiceImpl extends ServiceImpl<DeviceCalibrationPlanMapper, DeviceCalibrationPlan> implements DeviceCalibrationPlanService { + + @Resource + private DeviceCalibrationPlanDetailMapper deviceCalibrationPlanDetailMapper; + @Resource + private DeviceCalibrationPlanDetailService deviceCalibrationPlanDetailService; + @Resource + private ThreadPoolTaskExecutor threadPoolTaskExecutor; + @Resource + private InformationNotificationService informationNotificationService; + @Resource + private UserMapper userMapper; + + + /** + * 鏂板璁惧鏍″噯璁″垝 + * @param calibrationPlanDto + * @return + */ + @Override + public boolean addDeviceCalibrationPlan(DeviceCalibrationPlanDto calibrationPlanDto) { + // 褰撳墠鐧诲綍鐢ㄦ埛 + Integer userId = SecurityUtils.getUserId().intValue(); + // 缂栧埗鏃ユ湡 + calibrationPlanDto.setWriteUserId(userId); + calibrationPlanDto.setWriteTime(LocalDateTime.now()); + baseMapper.insert(calibrationPlanDto); + + // 娣诲姞璇︽儏 + if (CollectionUtils.isNotEmpty(calibrationPlanDto.getCalibrationPlanDetailList())) { + for (DeviceCalibrationPlanDetail calibrationPlanDetail : calibrationPlanDto.getCalibrationPlanDetailList()) { + calibrationPlanDetail.setPlanId(calibrationPlanDto.getPlanId()); + } + deviceCalibrationPlanDetailService.saveBatch(calibrationPlanDto.getCalibrationPlanDetailList()); + } + + return true; + } + + /** + * 瀵煎叆璁惧鏍″噯璁″垝 + * @param file + * @return + */ + @Override + public boolean importDeviceCalibrationPlan(MultipartFile file, String planYear) { + // 褰撳墠鐧诲綍鐢ㄦ埛 + Integer userId = SecurityUtils.getUserId().intValue(); + // 鏂囦欢鍚嶇О + String fileName = file.getOriginalFilename().substring(0, file.getOriginalFilename().lastIndexOf(".")); + DeviceCalibrationPlan calibrationPlan = new DeviceCalibrationPlan(); + calibrationPlan.setPlanName(fileName); + calibrationPlan.setPlanYear(planYear); + calibrationPlan.setWriteUserId(userId); + calibrationPlan.setWriteTime(LocalDateTime.now()); + baseMapper.insert(calibrationPlan); + + List<DeviceCalibrationPlanDetail> detailsUploadList = new ArrayList<>(); + // 瀵煎叆闄勪欢鍐呭 + try { + // excel瑙f瀽 + EasyExcel.read(file.getInputStream(), DeviceCalibrationPlanDetailUpload.class, new AnalysisEventListener<DeviceCalibrationPlanDetailUpload>() { + @Override + public void invoke(DeviceCalibrationPlanDetailUpload detailsUpload, AnalysisContext analysisContext) { + // 鍒ゆ柇鏄惁涓虹┖ + if (StringUtils.isNotBlank(detailsUpload.getDeviceName()) && + StringUtils.isNotBlank(detailsUpload.getDeviceNumber())) { + // 瀵硅薄澶嶅埗 + DeviceCalibrationPlanDetail calibrationPlanDetail = new DeviceCalibrationPlanDetail(); + BeanUtils.copyProperties(detailsUpload, calibrationPlanDetail); + // 鏍煎紡璇濇渶杩戞瀹氭椂闂村拰鏈勾璁″垝鏍″噯鏃堕棿 + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy.MM.dd"); + calibrationPlanDetail.setLastDate(LocalDate.parse(detailsUpload.getLastDate(), formatter)); + calibrationPlanDetail.setPlanDate(LocalDate.parse(detailsUpload.getLastDate(), formatter)); + + calibrationPlanDetail.setPlanId(calibrationPlan.getPlanId()); + detailsUploadList.add(calibrationPlanDetail); + } + } + + @Override + public void doAfterAllAnalysed(AnalysisContext analysisContext) { + + } + }).sheet().doRead(); + deviceCalibrationPlanDetailService.saveBatch(detailsUploadList); + + } catch (IOException e) { + throw new RuntimeException(e); + } + return true; + } + + /** + * 鎻愪氦鎵瑰噯 + * @param deviceCalibrationPlan + * @return + */ + @Override + public boolean submiatRatifyDeviceCalibrationPlan(DeviceCalibrationPlan deviceCalibrationPlan) { + baseMapper.update(null, Wrappers.<DeviceCalibrationPlan>lambdaUpdate() + .eq(DeviceCalibrationPlan::getPlanId, deviceCalibrationPlan.getPlanId()) + .set(DeviceCalibrationPlan::getRatifyUserId, deviceCalibrationPlan.getRatifyUserId()) + .set(DeviceCalibrationPlan::getRatifyRemark, null) + .set(DeviceCalibrationPlan::getRatifyStatus, null) + .set(DeviceCalibrationPlan::getRatifyTime, null) + ); + + DeviceCalibrationPlan calibrationPlan = baseMapper.selectById(deviceCalibrationPlan.getPlanId()); + + // 鍙戦�佹秷鎭� + Integer userId = SecurityUtils.getUserId().intValue(); + User user = userMapper.selectById(userId); + // 娑堟伅鍙戦�� + InformationNotification info = new InformationNotification(); + // 鍙戦�佷汉 + info.setCreateUser(user.getName()); + info.setMessageType("6"); + info.setTheme("CNAS璁惧鏍″噯璁″垝鎵瑰噯閫氱煡"); + info.setContent(calibrationPlan.getPlanName() + "鐨勮澶囨牎鍑嗚鍒掑緟鎵瑰噯"); + info.setSenderId(userId); + // 鎺ユ敹浜� + info.setConsigneeId(deviceCalibrationPlan.getRatifyUserId()); + info.setJumpPath(MenuJumpPathConstants.DEVICE); + informationNotificationService.addInformationNotification(info); + + // 鍙戦�佷紒涓氬井淇¢�氱煡 + threadPoolTaskExecutor.execute(() -> { + // 鏌ヨ鎺ユ敹浜� + User personnel = userMapper.selectById(deviceCalibrationPlan.getPlanId()); + + String message = ""; + message += "CNAS璁惧鏍″噯璁″垝鎵瑰噯閫氱煡"; + message += "\n璇峰幓璧勬簮绠$悊-璁惧涓�灞傜洰褰�-璁惧鏍″噯璁″垝濉啓"; + message += "\n" + calibrationPlan.getPlanName() + "鐨勬牎鍑嗚鍒掑緟鎵瑰噯"; + //鍙戦�佷紒涓氬井淇℃秷鎭�氱煡 + try { + WxCpUtils.inform(personnel.getAccount(), message, null); + } catch (Exception e) { + throw new RuntimeException(e); + } + }); + return true; + } + + /** + * 璁惧鏍″噯璁″垝鎵瑰噯 + * @param deviceCalibrationPlan + * @return + */ + @Override + public boolean ratifyDeviceCalibrationPlan(DeviceCalibrationPlan deviceCalibrationPlan) { + baseMapper.update(null, Wrappers.<DeviceCalibrationPlan>lambdaUpdate() + .eq(DeviceCalibrationPlan::getPlanId, deviceCalibrationPlan.getPlanId()) + .set(DeviceCalibrationPlan::getRatifyRemark, deviceCalibrationPlan.getRatifyRemark()) + .set(DeviceCalibrationPlan::getRatifyStatus, deviceCalibrationPlan.getRatifyStatus()) + .set(DeviceCalibrationPlan::getRatifyTime, LocalDateTime.now()) + ); + return true; + } + + /** + * 璁惧鏍″噯璁″垝鍒楄〃 + * @param page + * @param deviceCalibrationPlan + * @return + */ + @Override + public IPage<DeviceCalibrationPlanDto> pageDeviceCalibrationPlan(Page page, DeviceCalibrationPlan deviceCalibrationPlan) { + return baseMapper.pageDeviceCalibrationPlan(page, QueryWrappers.queryWrappers(deviceCalibrationPlan)); + } + + /** + * 璁惧鏍″噯璁″垝璇︽儏鍒楄〃 + * @param page + * @param deviceCalibrationPlanDetails + * @return + */ + @Override + public IPage<DeviceCalibrationPlanDetail> pageDeviceCalibrationPlanDetail(Page page, DeviceCalibrationPlanDetail deviceCalibrationPlanDetails) { + if (deviceCalibrationPlanDetails.getPlanId() == null) { + return new Page(); + } + return deviceCalibrationPlanDetailMapper.pageDeviceCalibrationPlanDetail(page, QueryWrappers.queryWrappers(deviceCalibrationPlanDetails)); + } + + /** + * 瀵煎嚭璁惧鏍″噯璁″垝 + * @param deviceCalibrationPlanId + * @param response + */ + @Override + public void exportDeviceCalibrationPlanDetail(Integer deviceCalibrationPlanId, HttpServletResponse response) { + // 鏌ヨ璁惧鏍″噯璁″垝 + DeviceCalibrationPlan deviceCalibrationPlan = baseMapper.selectById(deviceCalibrationPlanId); + DeviceCalibrationPlanDto deviceCalibrationPlanDto = new DeviceCalibrationPlanDto(); + BeanUtils.copyProperties(deviceCalibrationPlan, deviceCalibrationPlanDto); + // 璁剧疆缂栧埗鍜屾壒鍑嗘椂闂存牸寮� + DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd"); + deviceCalibrationPlanDto.setWriteTimeStr(deviceCalibrationPlan.getWriteTime() == null ? null : deviceCalibrationPlan.getWriteTime().format(formatter)); + deviceCalibrationPlanDto.setRatifyTimeStr(deviceCalibrationPlan.getRatifyTime() == null ? null : deviceCalibrationPlan.getRatifyTime().format(formatter)); + + // 鏌ヨ璁惧鏍″噯璁″垝璇︽儏 + List<DeviceCalibrationPlanDetail> deviceCalibrationPlanDetailList = deviceCalibrationPlanDetailMapper.selectList(Wrappers.<DeviceCalibrationPlanDetail>lambdaQuery() + .eq(DeviceCalibrationPlanDetail::getPlanId, deviceCalibrationPlanId) + .orderByAsc(DeviceCalibrationPlanDetail::getPlanDate)); + // 璁剧疆搴忓彿 鍜� 鏃堕棿 + ArrayList<DeviceCalibrationPlanDetailDto> deviceCalibrationPlanDetailDtoList = new ArrayList<>(); + deviceCalibrationPlanDetailList.forEach(deviceCalibrationPlanDetail -> { + DeviceCalibrationPlanDetailDto deviceCalibrationPlanDetailDto = new DeviceCalibrationPlanDetailDto(); + BeanUtils.copyProperties(deviceCalibrationPlanDetail, deviceCalibrationPlanDetailDto); + deviceCalibrationPlanDetailDto.setIndex(deviceCalibrationPlanDetailList.indexOf(deviceCalibrationPlanDetail) + 1); + deviceCalibrationPlanDetailDto.setLastDateStr(deviceCalibrationPlanDetail.getLastDate() == null ? null : deviceCalibrationPlanDetail.getLastDate().format(formatter)); + deviceCalibrationPlanDetailDto.setPlanDateStr(deviceCalibrationPlanDetail.getPlanDate() == null ? null : deviceCalibrationPlanDetail.getPlanDate().format(formatter)); + deviceCalibrationPlanDetailDtoList.add(deviceCalibrationPlanDetailDto); + }); + + // 鑾峰彇璺緞 + InputStream inputStream = this.getClass().getResourceAsStream("/static/word/device-calibration-plan.docx"); + Configure configure = Configure.builder() + .bind("deviceCalibrationPlanDetailDtoList", new HackLoopTableRenderPolicy()) + .build(); + XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render( + new HashMap<String, Object>() {{ + put("deviceCalibrationPlan", deviceCalibrationPlanDto); + put("deviceCalibrationPlanDetailDtoList", deviceCalibrationPlanDetailDtoList); + //鑾峰彇缂栧埗浜虹殑绛惧悕鍦板潃 + put("organizationUrl", UserUtils.getFinalUserSignatureUrl(deviceCalibrationPlan.getRatifyUserId())); + //鑾峰彇鎵瑰噯浜虹殑绛惧悕鍦板潃 + put("approvedUrl", UserUtils.getFinalUserSignatureUrl(deviceCalibrationPlan.getWriteUserId())); + }}); + + 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 calibrationPlanDto + * @return + */ + @Override + public boolean updateDeviceCalibrationPlan(DeviceCalibrationPlanDto calibrationPlanDto) { + // 褰撳墠鐧诲綍鐢ㄦ埛 + Integer userId = SecurityUtils.getUserId().intValue(); + // 缂栧埗鏃ユ湡 + calibrationPlanDto.setWriteUserId(userId); + calibrationPlanDto.setWriteTime(LocalDateTime.now()); + baseMapper.updateById(calibrationPlanDto); + + // 鍒犻櫎鍘熸湰鐨勮鎯� + deviceCalibrationPlanDetailService.remove(Wrappers.<DeviceCalibrationPlanDetail>lambdaQuery().eq(DeviceCalibrationPlanDetail::getPlanId, calibrationPlanDto.getPlanId())); + + // 娣诲姞璇︽儏 + if (CollectionUtils.isNotEmpty(calibrationPlanDto.getCalibrationPlanDetailList())) { + for (DeviceCalibrationPlanDetail calibrationPlanDetail : calibrationPlanDto.getCalibrationPlanDetailList()) { + calibrationPlanDetail.setPlanId(calibrationPlanDto.getPlanId()); + } + deviceCalibrationPlanDetailService.saveBatch(calibrationPlanDto.getCalibrationPlanDetailList()); + } + return true; + } + + /** + * 鏌ヨ璁惧鏍″噯璇︽儏 + * @param planId + * @return + */ + @Override + public DeviceCalibrationPlanDto getDeviceCalibrationPlan(Integer planId) { + DeviceCalibrationPlan calibrationPlan = baseMapper.selectById(planId); + DeviceCalibrationPlanDto deviceCalibrationPlanDto = new DeviceCalibrationPlanDto(); + BeanUtils.copyProperties(calibrationPlan, deviceCalibrationPlanDto); + // 鏌ヨ璇︽儏 + List<DeviceCalibrationPlanDetail> list = deviceCalibrationPlanDetailService.list(Wrappers.<DeviceCalibrationPlanDetail>lambdaQuery() + .eq(DeviceCalibrationPlanDetail::getPlanId, planId) + .orderByAsc(DeviceCalibrationPlanDetail::getPlanDate)); + + deviceCalibrationPlanDto.setCalibrationPlanDetailList(list); + return deviceCalibrationPlanDto; + } + +} -- Gitblit v1.9.3