From bedd0a1cef215538df64470df6b8d4a022189136 Mon Sep 17 00:00:00 2001
From: liusheng <337615773@qq.com>
Date: 星期三, 28 八月 2024 14:05:16 +0800
Subject: [PATCH] 代码提交

---
 smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java |  179 ++++++++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 163 insertions(+), 16 deletions(-)

diff --git a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java
index cc6b26f..d090405 100644
--- a/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java
+++ b/smartor/src/main/java/com/smartor/service/impl/ServiceSubtaskAnswerServiceImpl.java
@@ -1,13 +1,24 @@
 package com.smartor.service.impl;
 
+import com.alibaba.fastjson2.JSON;
+import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.common.utils.DateUtils;
-import com.smartor.domain.ServiceSubtaskAnswer;
+import com.ruoyi.common.utils.DtoConversionUtils;
+import com.ruoyi.common.utils.RSAPublicKeyExample;
+import com.ruoyi.common.utils.StringUtils;
+import com.smartor.domain.*;
 import com.smartor.mapper.ServiceSubtaskAnswerMapper;
+import com.smartor.mapper.ServiceSubtaskDetailMapper;
+import com.smartor.mapper.SvyTaskTemplateTargetoptionMapper;
 import com.smartor.service.IServiceSubtaskAnswerService;
+import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections4.CollectionUtils;
+import org.apache.commons.lang3.ObjectUtils;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
 
-import java.util.List;
+import java.util.*;
 
 /**
  * 浠诲姟闂嵎闂閫夐」Service涓氬姟灞傚鐞�
@@ -15,11 +26,23 @@
  * @author ruoyi
  * @date 2024-07-18
  */
+@Slf4j
 @Service
-public class ServiceSubtaskAnswerServiceImpl implements IServiceSubtaskAnswerService
-{
+public class ServiceSubtaskAnswerServiceImpl implements IServiceSubtaskAnswerService {
     @Autowired
     private ServiceSubtaskAnswerMapper serviceSubtaskAnswerMapper;
+
+    @Autowired
+    private RedisCache redisCache;
+
+    @Autowired
+    private ServiceSubtaskDetailMapper serviceSubtaskDetailMapper;
+
+    @Autowired
+    private SvyTaskTemplateTargetoptionMapper svyTaskTemplateTargetoptionMapper;
+
+    @Value("${pri_key}")
+    private String pri_key;
 
     /**
      * 鏌ヨ浠诲姟闂嵎闂閫夐」
@@ -28,8 +51,7 @@
      * @return 浠诲姟闂嵎闂閫夐」
      */
     @Override
-    public ServiceSubtaskAnswer selectServiceSubtaskAnswerById(Long id)
-    {
+    public ServiceSubtaskAnswer selectServiceSubtaskAnswerById(Long id) {
         return serviceSubtaskAnswerMapper.selectServiceSubtaskAnswerById(id);
     }
 
@@ -40,8 +62,7 @@
      * @return 浠诲姟闂嵎闂閫夐」
      */
     @Override
-    public List<ServiceSubtaskAnswer> selectServiceSubtaskAnswerList(ServiceSubtaskAnswer serviceSubtaskAnswer)
-    {
+    public List<ServiceSubtaskAnswer> selectServiceSubtaskAnswerList(ServiceSubtaskAnswer serviceSubtaskAnswer) {
         return serviceSubtaskAnswerMapper.selectServiceSubtaskAnswerList(serviceSubtaskAnswer);
     }
 
@@ -52,8 +73,7 @@
      * @return 缁撴灉
      */
     @Override
-    public int insertServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer)
-    {
+    public int insertServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) {
         serviceSubtaskAnswer.setCreateTime(DateUtils.getNowDate());
         return serviceSubtaskAnswerMapper.insertServiceSubtaskAnswer(serviceSubtaskAnswer);
     }
@@ -65,8 +85,7 @@
      * @return 缁撴灉
      */
     @Override
-    public int updateServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer)
-    {
+    public int updateServiceSubtaskAnswer(ServiceSubtaskAnswer serviceSubtaskAnswer) {
         serviceSubtaskAnswer.setUpdateTime(DateUtils.getNowDate());
         return serviceSubtaskAnswerMapper.updateServiceSubtaskAnswer(serviceSubtaskAnswer);
     }
@@ -78,8 +97,7 @@
      * @return 缁撴灉
      */
     @Override
-    public int deleteServiceSubtaskAnswerByIds(Long[] ids)
-    {
+    public int deleteServiceSubtaskAnswerByIds(Long[] ids) {
         return serviceSubtaskAnswerMapper.deleteServiceSubtaskAnswerByIds(ids);
     }
 
@@ -90,8 +108,137 @@
      * @return 缁撴灉
      */
     @Override
-    public int deleteServiceSubtaskAnswerById(Long id)
-    {
+    public int deleteServiceSubtaskAnswerById(Long id) {
         return serviceSubtaskAnswerMapper.deleteServiceSubtaskAnswerById(id);
     }
+
+    @Override
+    public Integer saveQuestionAnswer(ServiceSubTaskAnswerReq serviceSubTaskAnswerReq) {
+        Set<String> allKeys = redisCache.getAllKeys();
+        if (ObjectUtils.isNotEmpty(serviceSubTaskAnswerReq)) {
+            //闇�瑕佺珛鍗虫墽琛�
+            RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+            Long tid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskAnswerReq.getParam1(), pri_key));
+            Long pid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskAnswerReq.getParam2(), pri_key));
+            allKeys = new HashSet<>();
+            allKeys.add(pid + "-" + tid + "-WJscriptCache");
+        }
+
+        Long nextScriptno = null;
+        for (String key : allKeys) {
+            String[] split = key.split("-");
+            if (key.contains("-WJscriptCache")) {
+                List<SvyTaskTemplateScriptVO> cacheList = redisCache.getCacheList(key);
+                for (int i = 0; i < cacheList.size(); i++) {
+                    if (i == 0) {
+                        // 璇存槑鏄涓�棰�
+                        //灏嗙涓�棰樼殑淇℃伅鏀惧埌琛ㄤ腑
+                        nextScriptno = setWJInfo(cacheList.get(0), Long.valueOf(split[1]), Long.valueOf(split[0]));
+                    } else {
+                        for (SvyTaskTemplateScriptVO svyTaskTemplateScriptVO : cacheList) {
+                            if (svyTaskTemplateScriptVO.getId() == nextScriptno) {
+                                //灏嗙涓�棰樼殑淇℃伅鏀惧埌琛ㄤ腑
+                                setWJInfo(svyTaskTemplateScriptVO, Long.valueOf(split[1]), Long.valueOf(split[0]));
+                                nextScriptno = Long.valueOf(cacheList.get(0).getNextScriptno());
+                            }
+
+                        }
+                    }
+                }
+            }
+            //灏嗚key鍜寁alue浠巖edis涓紝鍒犻櫎
+            redisCache.deleteObject(key);
+        }
+        return 1;
+    }
+
+    /**
+     * 灏嗛棶棰樹繚瀛樺埌缂撳瓨涓�
+     *
+     * @param serviceSubTaskCacheReq
+     * @return
+     */
+    @Override
+    public Integer saveQuestionCache(ServiceSubTaskCacheReq serviceSubTaskCacheReq) {
+        RSAPublicKeyExample rsaPublicKeyExample = new RSAPublicKeyExample();
+        Long tid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskCacheReq.getParam1(), pri_key));
+        Long pid = Long.valueOf(rsaPublicKeyExample.decryptedData(serviceSubTaskCacheReq.getParam2(), pri_key));
+        //闂嵎
+        redisCache.setCacheObject(pid + "-" + tid + "-WJscriptCache", serviceSubTaskCacheReq.getSvyTaskTemplateScriptVOList());
+        return 1;
+    }
+
+    @Override
+    public List<ServiceSubtaskDetailVO> selectPatQuestionResult(ServiceSubTaskQueryReq serviceSubTaskQueryReq) {
+        log.error("selectPatQuesTionResult鐨勫叆鍙備负锛歿}", serviceSubTaskQueryReq);
+        List<ServiceSubtaskDetailVO> serviceSubtaskDetailVOList = new ArrayList<>();
+        ServiceSubtaskDetail serviceSubtaskDetail = new ServiceSubtaskDetail();
+        serviceSubtaskDetail.setTaskid(serviceSubTaskQueryReq.getTaskid());
+        serviceSubtaskDetail.setPatid(serviceSubTaskQueryReq.getPatId());
+        serviceSubtaskDetail.setScriptid(serviceSubTaskQueryReq.getScriptid());
+        List<ServiceSubtaskDetail> serviceSubtaskDetails = serviceSubtaskDetailMapper.selectServiceSubtaskDetailList(serviceSubtaskDetail);
+        for (ServiceSubtaskDetail serviceSubtaskDetail1 : serviceSubtaskDetails) {
+            ServiceSubtaskDetailVO serviceSubtaskDetailVO = DtoConversionUtils.sourceToTarget(serviceSubtaskDetail1, ServiceSubtaskDetailVO.class);
+            SvyTaskTemplateTargetoption svyTaskTemplateTargetoption = new SvyTaskTemplateTargetoption();
+            svyTaskTemplateTargetoption.setScriptid(serviceSubtaskDetailVO.getScriptid());
+            svyTaskTemplateTargetoption.setTaskid(serviceSubtaskDetailVO.getTaskid());
+            List<SvyTaskTemplateTargetoption> svyTaskTemplateTargetoptions = svyTaskTemplateTargetoptionMapper.selectSvyTaskTemplateTargetoptionList(svyTaskTemplateTargetoption);
+            serviceSubtaskDetailVO.setSvyTaskTemplateTargetoptions(svyTaskTemplateTargetoptions);
+            serviceSubtaskDetailVOList.add(serviceSubtaskDetailVO);
+        }
+        return serviceSubtaskDetailVOList;
+    }
+
+    private Long setWJInfo(SvyTaskTemplateScriptVO svyTaskTemplateScriptVO, Long taskid, Long patid) {
+        //涓嬮璺宠浆
+        Long nextScriptNo = null;
+
+        ServiceSubtaskDetailVO serviceSubtaskDetailVO = new ServiceSubtaskDetailVO();
+        List<ServiceSubtaskOptionAnswer> answerList = new ArrayList<>();
+        if (svyTaskTemplateScriptVO.getScriptType().equals("1") || svyTaskTemplateScriptVO.getScriptType().equals("2")) {
+            //1銆�2涓哄崟閫夋垨澶氶��
+            for (SvyTaskTemplateTargetoption svyTaskTemplateTargetoption : svyTaskTemplateScriptVO.getSvyTaskTemplateTargetoptions()) {
+                //灏嗛棶棰橀�夐」璁板綍涓嬫潵
+                if (StringUtils.isEmpty(serviceSubtaskDetailVO.getTargetvalue())) {
+                    serviceSubtaskDetailVO.setTargetvalue(svyTaskTemplateTargetoption.getTargetvalue());
+                } else {
+                    serviceSubtaskDetailVO.setTargetvalue(serviceSubtaskDetailVO.getTargetvalue() + "  " + svyTaskTemplateTargetoption.getTargetvalue());
+                }
+
+                if (svyTaskTemplateTargetoption.getIsUserOperation() == true) {
+                    //灏嗛�変腑鐨勭粨鏋滄斁鍒癮srtext涓�
+                    if (StringUtils.isEmpty(serviceSubtaskDetailVO.getAsrtext())) {
+                        serviceSubtaskDetailVO.setAsrtext(svyTaskTemplateTargetoption.getTargetvalue());
+                    } else {
+                        //濡傛灉鏄閫夛紝绛旀闇�瑕佺敤 & 杩涜鎷兼帴
+                        serviceSubtaskDetailVO.setAsrtext(serviceSubtaskDetailVO.getAnswerps() + "&" + svyTaskTemplateTargetoption.getTargetvalue());
+                    }
+                    if (svyTaskTemplateScriptVO.getScriptType().equals("1") && svyTaskTemplateScriptVO.getBranchFlag().equals("1")) {
+                        //鏄崟閫夛紝骞朵笖鏄湁鍒嗘敮鐨�
+                        nextScriptNo = svyTaskTemplateTargetoption.getNextQuestion();
+                    } else {
+                        nextScriptNo = svyTaskTemplateScriptVO.getNextScriptno();
+                    }
+                }
+            }
+            serviceSubtaskDetailVO.setSvyTaskTemplateTargetoptions(svyTaskTemplateScriptVO.getSvyTaskTemplateTargetoptions());
+        } else {
+            //闈炲崟澶氶��
+            if (CollectionUtils.isNotEmpty(svyTaskTemplateScriptVO.getSvyTaskTemplateTargetoptions())) {
+                serviceSubtaskDetailVO.setAsrtext(svyTaskTemplateScriptVO.getScriptResult());
+                nextScriptNo = svyTaskTemplateScriptVO.getNextScriptno();
+            }
+        }
+        serviceSubtaskDetailVO.setTaskid(Long.valueOf(taskid));
+        serviceSubtaskDetailVO.setPatid(Long.valueOf(patid));
+        serviceSubtaskDetailVO.setScriptid(svyTaskTemplateScriptVO.getId());
+        serviceSubtaskDetailVO.setValueType(svyTaskTemplateScriptVO.getScriptType());
+        serviceSubtaskDetailVO.setAsrtext(JSON.toJSONString(answerList));
+        serviceSubtaskDetailVO.setComment(null);
+        serviceSubtaskDetailVO.setCreateTime(new Date());
+        serviceSubtaskDetailVO.setUpdateTime(new Date());
+        ServiceSubtaskDetail serviceSubtaskDetail = DtoConversionUtils.sourceToTarget(serviceSubtaskDetailVO, ServiceSubtaskDetail.class);
+        serviceSubtaskDetailMapper.insertServiceSubtaskDetail(serviceSubtaskDetail);
+        return nextScriptNo;
+    }
 }

--
Gitblit v1.9.3