From edd22f77d054237b32628a91f217fd18288b13d6 Mon Sep 17 00:00:00 2001
From: 赵文轩 <1652863494@qq.com>
Date: 星期三, 08 一月 2025 10:11:45 +0800
Subject: [PATCH] 泾川his补录调整

---
 ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java |  194 +++++++++++++++++++++++++-----------------------
 1 files changed, 101 insertions(+), 93 deletions(-)

diff --git a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java
index e271b30..23e430e 100644
--- a/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java
+++ b/ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java
@@ -1,9 +1,6 @@
 package com.ltkj.web.controller.system;
 
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 import java.util.stream.Collectors;
 import javax.annotation.Resource;
 import javax.servlet.ServletSecurityElement;
@@ -12,17 +9,20 @@
 
 import cn.hutool.core.bean.BeanUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.extra.pinyin.PinyinUtil;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.ltkj.common.core.redis.RedisCache;
+import com.ltkj.common.utils.IdUtils;
 import com.ltkj.framework.config.MatchUtils;
 import com.ltkj.hosp.domain.*;
 import com.ltkj.hosp.service.*;
+import com.ltkj.system.service.ISysConfigService;
 import com.ltkj.web.controller.lis.LisApiMethod;
-import com.sun.xml.internal.bind.v2.TODO;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
 import io.swagger.annotations.ApiParam;
+import lombok.extern.slf4j.Slf4j;
 import org.aspectj.weaver.AjAttribute;
 import org.springframework.beans.BeanUtils;
 import org.springframework.security.access.prepost.PreAuthorize;
@@ -43,6 +43,7 @@
  * @author ltkj_璧典匠璞�&鏉庢牸
  * @date 2023-04-11
  */
+@Slf4j
 @RestController
 @RequestMapping("/sampling/sampling")
 @Api(tags = "PC绔� 浣撴閲囨牱绠$悊")
@@ -63,6 +64,10 @@
     private ITbTransitionService tbTransitionService;
     @Autowired
     private LisApiMethod lisApiMethod;
+    @Autowired
+    private ISysConfigService configService;
+    @Autowired
+    private SamplingServiceApi samplingService;
 
     /**
      * 鏌ヨ浣撴閲囨牱绠$悊鍒楄〃
@@ -188,6 +193,7 @@
 
     /**
      * 鑾峰彇閲囨牱瀹㈡埛鍒楄〃
+     *
      * @param isSignFor
      * @param tjNum
      * @param name
@@ -205,94 +211,126 @@
                                  @ApiParam(value = "椤电爜鏁�(榛樿1)") @RequestParam(defaultValue = "1") Integer pageNum,
                                  @ApiParam(value = "鏄剧ず鏉℃暟(榛樿10)") @RequestParam(defaultValue = "10") Integer pageSize,
                                  @ApiParam(value = "寮�濮嬫椂闂�") @RequestParam(required = false) String beginTime,
-                                 @ApiParam(value = "缁撴潫鏃堕棿") @RequestParam(required = false) String endTime){
+                                 @ApiParam(value = "缁撴潫鏃堕棿") @RequestParam(required = false) String endTime) {
         Page<TjSampling> samplingPage = new Page<>(pageNum, pageSize);
         LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>();
-        wrapper.eq(TjSampling::getIsSignFor,isSignFor);
+        wrapper.eq(TjSampling::getIsSignFor, isSignFor);
         if (null != tjNum && StrUtil.isNotBlank(tjNum))
-            wrapper.eq(TjSampling::getTjNum,tjNum);
+            wrapper.like(TjSampling::getTjNum, tjNum);
         if (null != name && StrUtil.isNotBlank(name))
-            wrapper.eq(TjSampling::getCusName,name);
+            wrapper.like(TjSampling::getCusName, name);
         if (null != beginTime && null != endTime && StrUtil.isNotBlank(beginTime) && StrUtil.isNotBlank(endTime))
             wrapper.between(TjSampling::getApplicationTime, beginTime, endTime);
         wrapper.groupBy(TjSampling::getCusId);
+        wrapper.orderByDesc(TjSampling::getCreateTime);
 //        wrapper.last("LIMIT " + (pageNum - 1) * pageSize + "," + pageSize);
         Page<TjSampling> page = tjSamplingService.page(samplingPage, wrapper);
         List<TjSampling> list = page.getRecords();
         ArrayList<TjCustomer> tjCustomers = new ArrayList<>();
         for (TjSampling tjSampling : list) {
             TjCustomer customer = customerService.getById(tjSampling.getCusId());
-            customer.setCusName(MatchUtils.hideCusName(customer.getCusName()));
-            customer.setCusPhone(MatchUtils.hidePhoneNum(customer.getCusPhone()));
-            customer.setCusIdcard(MatchUtils.hideIdCardNum(customer.getCusIdcard()));
-            customer.setTjNumber(tjSampling.getTjNum());
-            customer.setApplicationTime(tjSampling.getApplicationTime());
-            tjCustomers.add(customer);
+            if(null !=customer){
+                customer.setCusName(customer.getCusName());
+                customer.setCusPhone(MatchUtils.hidePhoneNum(customer.getCusPhone()));
+                customer.setCusIdcard(MatchUtils.hideIdCardNum(customer.getCusIdcard()));
+                customer.setTjNumber(tjSampling.getTjNum());
+                customer.setApplicationTime(tjSampling.getApplicationTime());
+                tjCustomers.add(customer);
+            }
         }
         HashMap<String, Object> hashMap = new HashMap<>();
-        hashMap.put("list",tjCustomers);
-        hashMap.put("total",page.getTotal());
+        hashMap.put("list", tjCustomers);
+        hashMap.put("total", page.getTotal());
         return AjaxResult.success(hashMap);
     }
 
     /**
      * 鏍规嵁瀹㈡埛鑾峰彇閲囨牱鍒楄〃
-     * @param cusId
+     *
+     * @param tjNumber
      * @return
      */
     @GetMapping("/getCusCyList")
     @ApiOperation(value = "鏍规嵁瀹㈡埛鑾峰彇閲囨牱鍒楄〃")
-    public AjaxResult getCusCyList(@RequestParam @ApiParam(value = "瀹㈡埛id") String cusId){
-        if (cusId == null || StrUtil.isBlank(cusId))
-            return AjaxResult.error("鍙傛暟閿欒");
+    public AjaxResult getCusCyList(@RequestParam @ApiParam(value = "瀹㈡埛id") String tjNumber,
+                                   @RequestParam(defaultValue = "1") @ApiParam(value = "0鏄�1鍚�") Integer isSignFor) {
+        if (tjNumber == null || StrUtil.isBlank(tjNumber))
+            return AjaxResult.error("鍙傛暟閿欒,鏈紶鍙傛暟");
         LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>();
-        wrapper.eq(TjSampling::getCusId,cusId);
-        wrapper.isNull(TjSampling::getParentId);
+        wrapper.eq(TjSampling::getTjNum, tjNumber);
+        wrapper.eq(TjSampling::getIsSignFor,isSignFor);
+        wrapper.and(i -> i.isNull(TjSampling::getParentId).or().eq(TjSampling::getIsMerge,1));
+//        wrapper.eq(TjSampling::getIsPay,1);
+//        if (isSignFor == 1)
+//            wrapper.eq(TjSampling::getIsApply,0);
+        wrapper.orderByDesc(TjSampling::getIsMerge);
         List<TjSampling> list = tjSamplingService.list(wrapper);
-        if (list.isEmpty())
-            return AjaxResult.error("鍙傛暟閿欒");
+        if (list.isEmpty()){
+            logger.info("jtNum ->{}",tjNumber);
+//            return AjaxResult.error("鏈煡璇㈠埌鏁版嵁锛屼汉鍛樻湭缂磋垂鎴栨病鏈夋湭閲囨牱椤圭洰");
+            return AjaxResult.error("鍙傛暟閿欒,鏈煡璇㈠埌鏁版嵁");
+        }
+//        for (TjSampling sampling : list) {
+//            TjCustomer customer = customerService.getById(sampling.getCusId());
+//            TjOrder order = orderService.getOrderByTjNum(sampling.getTjNum());
+//            if(null !=order)sampling.setCardId(order.getCardId());
+//            sampling.setCustomer(customer);
+//        }
+
+        if (list.size() >= 2) {
+            // 杩涜鍚堝苟
+            List<String> stringList = list.stream().map(TjSampling::getId).collect(Collectors.toList());
+            log.info("鎻愬彇id ->{}",stringList);
+            for (String s : stringList) {
+                if (tjSamplingService.isMergeItem(s) != 0) {
+                    list.removeIf(item -> Objects.equals(item.getId(), s));
+                }
+            }
+            String lis_tmh_prefix = configService.selectConfigByKey("make_lis_tmh_prefix");
+            Map<String, List<TjSampling>> map = list.stream().filter(i->StrUtil.isNotBlank(i.getSpecimenTypeCode())).collect(Collectors.groupingBy(item -> item.getSpecimenTypeCode()));
+            for (Map.Entry<String, List<TjSampling>> entry : map.entrySet()) {
+                List<TjSampling> entryValue = entry.getValue();
+                tjSamplingService.mergeCaiYangTran(entryValue.stream().map(TjSampling::getId).collect(Collectors.toList()),lis_tmh_prefix);
+            }
+        }
+        wrapper = new LambdaQueryWrapper<>();
+        wrapper.eq(TjSampling::getTjNum, tjNumber);
+        wrapper.eq(TjSampling::getIsSignFor,isSignFor);
+        wrapper.and(i -> i.isNull(TjSampling::getParentId).or().eq(TjSampling::getIsMerge,1));
+//        wrapper.orderByDesc(TjSampling::getIsMerge);
+        wrapper.orderByAsc(TjSampling::getSpecimenTypeCode,TjSampling::getIsMerge);
+        list = tjSamplingService.list(wrapper);
         for (TjSampling sampling : list) {
-            sampling.setCusName(MatchUtils.hideCusName(sampling.getCusName()));
+            TjCustomer customer = customerService.getById(sampling.getCusId());
+            TjOrder order = orderService.getOrderByTjNum(sampling.getTjNum());
+            if(null !=order)sampling.setCardId(order.getCardId());
+            sampling.setCustomer(customer);
         }
         return AjaxResult.success(list);
     }
 
-    @GetMapping("/mergeCaiYang")
+    @PostMapping("/mergeCaiYang")
     @ApiOperation(value = "閲囨牱鐧昏鍚堝苟椤圭洰鎺ュ彛")
-    public AjaxResult mergeCaiYang(@RequestParam List<String> ids){
-        if(null !=ids && !ids.isEmpty()){
-            int i = tjSamplingService.panduanshifoukeyihebing(ids);
-            if(i>1){
-                return AjaxResult.error("鏍囨湰绫诲瀷涓嶄竴鑷�,涓嶅彲鍚堝苟");
-            }
-
-            TjSampling tjSampling = tjSamplingService.getById(ids.get(0));
-
-
-            //todo  鍔犱竴鏉″垽鏂槸鍚﹀瓨鍦ㄥ悎骞堕」鐩殑鏌ヨsql
-            //todo  鍒ゆ柇浼犲叆鐨勯」鐩槸鍚﹀瓨鍦ㄥ悎骞堕」鐩�  涓嶅瓨鍦ㄨ蛋鍘熼�昏緫  瀛樺湪璧癳lse
-
-
-            Map<String,Object> map= tjSamplingService.hebingCaiYangInFo(ids);
-            TjSampling sampling=new TjSampling();
-            String proId = map.get("proId").toString();
-            String proName = map.get("proName").toString();
-            BeanUtil.copyProperties(tjSampling,sampling,new String[]{"id"});
-            sampling.setProId(proId);
-            sampling.setProName(proName);
-            sampling.setIsMerge(1);
-            if (tjSamplingService.save(sampling)) {
-                for (String id : ids) {
-                    TjSampling service = tjSamplingService.getById(id);
-                    service.setParentId(sampling.getId());
-                    service.setIsMerge(1);
-                    tjSamplingService.updateById(service);
-                }
-                return AjaxResult.success("鍚堝苟椤圭洰鎴愬姛!");
-            }
-        }
-        return AjaxResult.error("璇烽�夋嫨浣犺鍚堝苟鐨勯」鐩�!!!");
+    public AjaxResult mergeCaiYang(@RequestBody List<String> ids) {
+        String lis_tmh_prefix = configService.selectConfigByKey("make_lis_tmh_prefix");
+        return tjSamplingService.mergeCaiYangTran(ids,lis_tmh_prefix);
     }
+
+
+    @PostMapping("/chexiaoCaiYang")
+    @ApiOperation(value = "鎾ら攢閲囨牱鐧昏鍚堝苟椤圭洰鎺ュ彛")
+    @Transactional
+    public AjaxResult chexiaoCaiYang(@RequestBody List<String> ids) {
+        if (null != ids && !ids.isEmpty()) {
+            int pdsfczhbxm = tjSamplingService.pdsfczhbxm(ids);
+            if (pdsfczhbxm != ids.size()) return AjaxResult.error("瀛樺湪鏈悎骞剁殑椤圭洰涓嶅彲鎾ら攢!!!");
+            tjSamplingService.deletedTjSamplingListByHb(ids);
+            tjSamplingService.updateHeBingXm(ids);
+            return AjaxResult.success("鎾ら攢鎴愬姛!!!");
+        }
+        return AjaxResult.error("璇烽�夋嫨浣犺鎾ら攢鐨勯」鐩�!!!");
+    }
+
 
     /**
      * 瀵煎嚭浣撴閲囨牱绠$悊鍒楄〃
@@ -358,38 +396,8 @@
     @ApiOperation(value = "纭閲囨牱鎺ュ彛")
     @Transactional
     public AjaxResult confirmSampling(@RequestBody List<String> ids) {
-        if (null == ids || ids.size() == 0) {
-            return AjaxResult.error("璇烽�夋嫨瑕佺‘璁ら」");
-        }
-        for (String id : ids) {
-            TjSampling sampling = tjSamplingService.getById(id);
-            if (null != sampling) {
-                sampling.setIsSignFor("0");
-                LambdaQueryWrapper<TjProject> wq = new LambdaQueryWrapper<>();
-                wq.eq(TjProject::getProParentId, sampling.getProId());
-                List<TjProject> projectList = projectService.list(wq);
-                List<String> collect = new ArrayList<>();
-                for (TjProject project : projectList) {
-                    Long proId = project.getProId();
-                    collect.add(String.valueOf(proId));
-                }
-                LambdaQueryWrapper<TjSampling> wq1 = new LambdaQueryWrapper<>();
-                wq1.eq(TjSampling::getTjNum, sampling.getTjNum());
-                wq1.in(TjSampling::getProId, collect);
-                List<TjSampling> samplingList = tjSamplingService.list(wq1);
-                if (null != samplingList && samplingList.size() > 0) {
-                    for (TjSampling tjSampling : samplingList) {
-                        tjSampling.setIsSignFor("0");
-                        tjSamplingService.updateById(tjSampling);
-                    }
-                }
-            }
-            if (!tjSamplingService.updateById(sampling)) {
-                TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
-                return AjaxResult.error("鎿嶄綔澶辫触,璇烽噸璇�");
-            }
-        }
-
-        return AjaxResult.success("鎿嶄綔鎴愬姛");
+        String config = configService.selectConfigByKey("sfkqdyhis");
+        String mergeRequest = configService.selectConfigByKey("use_lis_pacs_is_auto_merge_request");
+        return samplingService.confirm(ids,config,mergeRequest);
     }
 }

--
Gitblit v1.8.0