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/DeviceExamineRecordContrastServiceImpl.java |  194 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 194 insertions(+), 0 deletions(-)

diff --git a/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceExamineRecordContrastServiceImpl.java b/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceExamineRecordContrastServiceImpl.java
new file mode 100644
index 0000000..27ec286
--- /dev/null
+++ b/cnas-device/src/main/java/com/ruoyi/device/service/impl/DeviceExamineRecordContrastServiceImpl.java
@@ -0,0 +1,194 @@
+package com.ruoyi.device.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+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.device.dto.DeviceExamineRecordContrastDetailsDto;
+import com.ruoyi.device.dto.DeviceExamineRecordContrastDto;
+import com.ruoyi.device.mapper.DeviceExaminePlanDetailsMapper;
+import com.ruoyi.device.mapper.DeviceExamineRecordContrastMapper;
+import com.ruoyi.device.pojo.DeviceExaminePlanDetails;
+import com.ruoyi.device.pojo.DeviceExamineRecordContrast;
+import com.ruoyi.device.pojo.DeviceExamineRecordContrastDetails;
+import com.ruoyi.device.service.DeviceExamineRecordContrastDetailsService;
+import com.ruoyi.device.service.DeviceExamineRecordContrastService;
+import com.ruoyi.framework.exception.ErrorException;
+import com.ruoyi.inspect.util.HackLoopTableRenderPolicy;
+import com.ruoyi.inspect.util.UserUtils;
+import com.ruoyi.system.mapper.UserMapper;
+import org.springframework.beans.BeanUtils;
+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.LocalDateTime;
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+
+/**
+ * <p>
+ * 璁惧鏍告煡璁板綍瀵规瘮琛� 鏈嶅姟瀹炵幇绫�
+ * </p>
+ *
+ * @author 姹熻嫃榈烽洀缃戠粶绉戞妧鏈夐檺鍏徃
+ * @since 2024-12-16 07:14:43
+ */
+@Service
+@Transactional(rollbackFor = Exception.class)
+public class DeviceExamineRecordContrastServiceImpl extends ServiceImpl<DeviceExamineRecordContrastMapper, DeviceExamineRecordContrast> implements DeviceExamineRecordContrastService {
+
+    @Resource
+    private DeviceExamineRecordContrastDetailsService deviceExamineRecordContrastDetailsService;
+    @Resource
+    private DeviceExaminePlanDetailsMapper deviceExaminePlanDetailsMapper;
+    @Resource
+    private UserMapper userMapper;
+    /**
+     * 鏌ヨ鏍告煡瀵规瘮璁板綍
+     * @return
+     */
+    @Override
+    public DeviceExamineRecordContrastDto getExamineRecordContrast(Integer planDetailsId) {
+        DeviceExamineRecordContrastDto contrastDto = baseMapper.getExamineRecordContrast(planDetailsId);
+        // 鍒ゆ柇鏄惁涓虹┖
+        if (contrastDto == null) {
+            contrastDto = new DeviceExamineRecordContrastDto();
+            // 鏌ヨ璁惧璇︽儏
+            DeviceExaminePlanDetails deviceExaminePlanDetails = deviceExaminePlanDetailsMapper.selectById(planDetailsId);
+            contrastDto.setPlanDetailsId(deviceExaminePlanDetails.getPlanDetailsId());
+
+        } else {
+            // 鏌ヨ璇︽儏
+            List<DeviceExamineRecordContrastDetails> list = deviceExamineRecordContrastDetailsService.list(Wrappers.<DeviceExamineRecordContrastDetails>lambdaQuery()
+                    .eq(DeviceExamineRecordContrastDetails::getRecordContrastId, contrastDto.getRecordContrastId()));
+            contrastDto.setRecordContrastDetailsList(list);
+        }
+
+        return contrastDto;
+    }
+
+    /**
+     * 鏂板鏍告煡瀵规瘮璁板綍
+     * @return
+     */
+    @Override
+    public boolean addExamineRecordContrast(DeviceExamineRecordContrastDto dto) {
+        if (dto.getPlanDetailsId() == null) {
+            throw new ErrorException("缂哄皯璁″垝璇︾粏淇℃伅id");
+        }
+        if (dto.getRecordContrastId() == null) {
+            Integer userId = SecurityUtils.getUserId().intValue();
+            User user = userMapper.selectById(userId);
+            dto.setCheckerUserId(userId);
+            dto.setCheckerUser(user.getName());
+
+            // 鏌ヨ瀹℃煡浜篿d
+            if (dto.getReviewUserId() != null) {
+                User reviewUser = userMapper.selectById(dto.getReviewUserId());
+                dto.setReviewUser(reviewUser.getName());
+            }
+        }
+        this.saveOrUpdate(dto);
+
+        // 鍒犻櫎鍏ㄩ儴璇︽儏
+        deviceExamineRecordContrastDetailsService.remove(Wrappers.<DeviceExamineRecordContrastDetails>lambdaQuery()
+                .eq(DeviceExamineRecordContrastDetails::getRecordContrastId, dto.getRecordContrastId()));
+        //娣诲姞璇︽儏
+        if (CollectionUtils.isNotEmpty(dto.getRecordContrastDetailsList())) {
+            for (DeviceExamineRecordContrastDetails details : dto.getRecordContrastDetailsList()) {
+                details.setRecordContrastId(dto.getRecordContrastId());
+            }
+            deviceExamineRecordContrastDetailsService.saveBatch(dto.getRecordContrastDetailsList());
+        }
+        return false;
+    }
+
+
+    /**
+     * 瀹℃牳鏍告煡瀵规瘮璁板綍
+     * @return
+     */
+    @Override
+    public boolean reviewExamineRecordContrast(DeviceExamineRecordContrastDto dto) {
+        if (dto.getPlanDetailsId() == null) {
+            throw new ErrorException("缂哄皯璁″垝璇︾粏淇℃伅id");
+        }
+        LambdaUpdateWrapper<DeviceExamineRecordContrast> wrapper = Wrappers.<DeviceExamineRecordContrast>lambdaUpdate()
+                .eq(DeviceExamineRecordContrast::getPlanDetailsId, dto.getPlanDetailsId())
+                .set(DeviceExamineRecordContrast::getReviewStatus, dto.getReviewStatus())
+                .set(DeviceExamineRecordContrast::getReviewRemark, dto.getReviewRemark())
+                .set(DeviceExamineRecordContrast::getReviewTime, LocalDateTime.now());
+        // 涓�0娓呴櫎瀹℃牳浜�
+        if (dto.getReviewStatus().equals(0)) {
+            wrapper.set(DeviceExamineRecordContrast::getReviewUserId, null)
+                    .set(DeviceExamineRecordContrast::getReviewUser, null);
+        }
+
+        this.update(wrapper);
+        return true;
+    }
+
+    /**
+     * 瀵煎嚭瀹℃牳鏍告煡瀵规瘮璁板綍
+     *
+     * @param planDetailsId 璇︽儏id
+     * @param response
+     */
+    @Override
+    public void exportReviewExamineRecordContrast(Integer planDetailsId, HttpServletResponse response) {
+        // 鏌ヨ瀵规瘮璁板綍
+        DeviceExamineRecordContrastDto deviceExamineRecordContrast = baseMapper.selectExamineRecordContrastDto(planDetailsId);
+
+        // 鏌ヨ瀵规瘮璁板綍璇︽儏
+        List<DeviceExamineRecordContrastDetails> deviceExamineRecordContrastDetailList = deviceExamineRecordContrastDetailsService.list(Wrappers.<DeviceExamineRecordContrastDetails>lambdaQuery().eq(DeviceExamineRecordContrastDetails::getRecordContrastId, deviceExamineRecordContrast.getRecordContrastId()));
+        // 璁剧疆搴忓彿
+        ArrayList<DeviceExamineRecordContrastDetailsDto> deviceExamineRecordContrastDetailsDtoList = new ArrayList<>();
+        deviceExamineRecordContrastDetailList.forEach(deviceExamineRecordContrastDetail -> {
+            DeviceExamineRecordContrastDetailsDto deviceExamineRecordContrastDetailsDto = new DeviceExamineRecordContrastDetailsDto();
+            BeanUtils.copyProperties(deviceExamineRecordContrastDetail, deviceExamineRecordContrastDetailsDto);
+            deviceExamineRecordContrastDetailsDto.setIndex(deviceExamineRecordContrastDetailList.indexOf(deviceExamineRecordContrastDetail) + 1);
+            deviceExamineRecordContrastDetailsDtoList.add(deviceExamineRecordContrastDetailsDto);
+        });
+
+        // 鑾峰彇璺緞
+        InputStream inputStream = this.getClass().getResourceAsStream("/static/word/review-examine-record-contrast.docx");
+        Configure configure = Configure.builder()
+                .bind("deviceExamineRecordContrastDetailsDtoList", new HackLoopTableRenderPolicy())
+                .build();
+        XWPFTemplate template = XWPFTemplate.compile(inputStream, configure).render(
+                new HashMap<String, Object>() {{
+                    put("deviceExamineRecordContrast", deviceExamineRecordContrast);
+                    put("deviceExamineRecordContrastDetailsDtoList", deviceExamineRecordContrastDetailsDtoList);
+                    //鑾峰彇鏍告煡浜虹殑绛惧悕鍦板潃
+                    put("checkerUserUrl", UserUtils.getFinalUserSignatureUrl(deviceExamineRecordContrast.getCheckerUserId()));
+                    //鑾峰彇瀹℃煡浜虹殑绛惧悕鍦板潃
+                    put("reviewUserUrl", UserUtils.getFinalUserSignatureUrl(deviceExamineRecordContrast.getReviewUserId()));
+                }});
+
+        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("瀵煎嚭澶辫触");
+        }
+    }
+}

--
Gitblit v1.9.3