zhaowenxuan
2025-04-03 378fd68db9a3a0f70bc1df6a6b05d332a8e522d4
ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java
@@ -1,35 +1,28 @@
package com.ltkj.web.controller.system;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.text.SimpleDateFormat;
import java.util.*;
import java.util.stream.Collectors;
import javax.annotation.Resource;
import javax.servlet.ServletSecurityElement;
import javax.servlet.http.HttpServletResponse;
import javax.swing.plaf.basic.BasicScrollPaneUI;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
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.his.HisApiMethod;
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 org.aspectj.weaver.AjAttribute;
import org.springframework.beans.BeanUtils;
import org.springframework.security.access.prepost.PreAuthorize;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.transaction.interceptor.TransactionAspectSupport;
import org.springframework.web.bind.annotation.*;
import com.ltkj.common.annotation.Log;
import com.ltkj.common.core.controller.BaseController;
@@ -44,6 +37,7 @@
 * @author ltkj_赵佳豪&李格
 * @date 2023-04-11
 */
@Slf4j
@RestController
@RequestMapping("/sampling/sampling")
@Api(tags = "PC端 体检采样管理")
@@ -65,7 +59,17 @@
    @Autowired
    private LisApiMethod lisApiMethod;
    @Autowired
    private IdUtils idUtils;
    private ISysConfigService configService;
    @Autowired
    private SamplingServiceApi samplingService;
    @Autowired
    private HisApiMethod hisApiMethod;
    @Autowired
    private LtkjJianchajianyanTreeService treeService;
    @Autowired
    private TbLisSqService tbLisSqService;
    @Autowired
    private LtkjJfxmgljyxmzdService jfxmgljyxmzdService;
    /**
     * 查询体检采样管理列表
@@ -193,7 +197,7 @@
     * 获取采样客户列表
     *
     * @param isSignFor
     * @param tjNum
     * @param tjNumber
     * @param name
     * @param pageNum
     * @param pageSize
@@ -204,8 +208,9 @@
    @GetMapping("/getCusList")
    @ApiOperation(value = "获取采样客户列表")
    public AjaxResult getCusList(@RequestParam(defaultValue = "1") @ApiParam(value = "0是1否") Integer isSignFor,
                                 @RequestParam(required = false) @ApiParam(value = "体检号") String tjNum,
                                 @RequestParam(required = false) @ApiParam(value = "体检号") String tjNumber,
                                 @RequestParam(required = false) @ApiParam(value = "客户姓名") String name,
                                 @RequestParam(required = false) @ApiParam(value = "单位") String dw,
                                 @ApiParam(value = "页码数(默认1)") @RequestParam(defaultValue = "1") Integer pageNum,
                                 @ApiParam(value = "显示条数(默认10)") @RequestParam(defaultValue = "10") Integer pageSize,
                                 @ApiParam(value = "开始时间") @RequestParam(required = false) String beginTime,
@@ -213,25 +218,41 @@
        Page<TjSampling> samplingPage = new Page<>(pageNum, pageSize);
        LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>();
        wrapper.eq(TjSampling::getIsSignFor, isSignFor);
        if (null != tjNum && StrUtil.isNotBlank(tjNum))
            wrapper.eq(TjSampling::getTjNum, tjNum);
        if (null != tjNumber && StrUtil.isNotBlank(tjNumber))
            wrapper.like(TjSampling::getTjNum, tjNumber);
        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);
        if (StrUtil.isNotBlank(dw)){
            LambdaQueryWrapper<TjOrder> wqq=new LambdaQueryWrapper<>();
            wqq.like(TjOrder::getFirmId,dw);
            wqq.select(TjOrder::getTjNumber);
            List<TjOrder> orderList = orderService.list(wqq);
            if(null !=orderList && !orderList.isEmpty()){
                List<String> list = orderList.stream().map(TjOrder::getTjNumber).collect(Collectors.toList());
                wrapper.in(TjSampling::getTjNum, list);
            }
        }
        wrapper.groupBy(TjSampling::getTjNum);
        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){
                TjOrder order = orderService.getOrderByTjNum(tjSampling.getTjNum());
                customer.setCompName(order.getFirmName());
                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);
@@ -242,80 +263,144 @@
    /**
     * 根据客户获取采样列表
     *
     * @param cusId
     * @param tjNumber
     * @return
     */
    @GetMapping("/getCusCyList")
    @ApiOperation(value = "根据客户获取采样列表")
    public AjaxResult getCusCyList(@RequestParam @ApiParam(value = "客户id") String cusId) {
        if (cusId == null || StrUtil.isBlank(cusId))
    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).or().eq(TjSampling::getIsMerge,1);
        String config = configService.selectConfigByKey("sfkqdyhis");
        if (config.equals("Y")){
//            LambdaQueryWrapper<TjSampling> wrapper6 = new LambdaQueryWrapper<>();
//            wrapper6.eq(TjSampling::getTjNum, tjNumber);
//            wrapper6.eq(TjSampling::getIsSignFor,isSignFor);
//            wrapper6.and(i -> i.isNull(TjSampling::getParentId).or().eq(TjSampling::getIsMerge,1));
//            wrapper6.isNull(TjSampling::getJyxh);
//            List<TjSampling> list1 = tjSamplingService.list(wrapper6);
//            if (!list1.isEmpty()){
            if (true){
                LambdaQueryWrapper<TjOrder> wrapper1 = new LambdaQueryWrapper<>();
                wrapper1.eq(TjOrder::getTjNumber,tjNumber);
                TjOrder tjOrder = orderService.getOne(wrapper1);
                hisApiMethod.Getlabreginfoinfo(tjOrder.getCardId(),new SimpleDateFormat("yyyy-MM-dd").format(tjOrder.getCreateTime()));
            LambdaQueryWrapper<TbLisSq> wrapper2 = new LambdaQueryWrapper<>();
            wrapper2.eq(TbLisSq::getCardId,tjOrder.getCardId());
            List<TbLisSq> list = tbLisSqService.list(wrapper2);
            for (TbLisSq lisSq : list) {
                if (!lisSq.getSqdbh().contains("jk"))
                    continue;
                String jyxmdm = lisSq.getJyxmdm();
                LambdaQueryWrapper<TjProject> wrapper4 = new LambdaQueryWrapper<>();
                wrapper4.eq(TjProject::getLisXmbm,jyxmdm);
                TjProject project = projectService.getOne(wrapper4);
                if (project != null){
                    LambdaUpdateWrapper<TjSampling> wrapper5 = new LambdaUpdateWrapper<>();
                    String jyxh = "";
                    if (StrUtil.isNotBlank(lisSq.getJyxhHb()))
                        jyxh = lisSq.getJyxhHb();
                    else jyxh = lisSq.getJyxh();
                    wrapper5.set(TjSampling::getJyxh,jyxh);
                    wrapper5.set(TjSampling::getJyxmdm,lisSq.getJyxmdm());
                    wrapper5.eq(TjSampling::getProId,project.getProParentId());
                    wrapper5.eq(TjSampling::getTjNum,tjNumber);
                    tjSamplingService.update(wrapper5);
                }
            }
//                JSONArray array = hisApiMethod.Getlabreginfoinfo(tjOrder.getCardId());
//                if (array != null && !array.isEmpty()){
//                    for (Object o : array) {
//                        JSONObject jsonObject = (JSONObject) o;
//                        String sqdh = jsonObject.getStr("sqdh");
//                        String jyxh = jsonObject.getStr("jyxh");
//                        LambdaQueryWrapper<LtkjJianchajianyanTree> wrapper2 = new LambdaQueryWrapper<>();
//                        wrapper2.eq(LtkjJianchajianyanTree::getCardId,tjOrder.getCardId());
//                        wrapper2.eq(LtkjJianchajianyanTree::getType,"检验");
//                        wrapper2.eq(LtkjJianchajianyanTree::getSqdh,sqdh);
//                        List<LtkjJianchajianyanTree> list = treeService.list(wrapper2);
//                        List<String> hisXms = list.stream().map(LtkjJianchajianyanTree::getHisXmdm).collect(Collectors.toList());
//                        LambdaQueryWrapper<TjProject> wrapper3 = new LambdaQueryWrapper<>();
//                        wrapper3.in(TjProject::getHisXmbm,hisXms);
//                        wrapper3.ne(TjProject::getProParentId,0);
//                        wrapper3.groupBy(TjProject::getProParentId);
//                        List<Long> proParentIds = projectService.list(wrapper3).stream().map(TjProject::getProParentId).collect(Collectors.toList());
//                        LambdaQueryWrapper<TjProject> wrapper4 = new LambdaQueryWrapper<>();
//                        wrapper4.in(TjProject::getProId,proParentIds);
//                        List<Long> proIds = projectService.list(wrapper4).stream().map(TjProject::getProId).collect(Collectors.toList());
//                        LambdaUpdateWrapper<TjSampling> wrapper5 = new LambdaUpdateWrapper<>();
//                        wrapper5.set(TjSampling::getJyxh,jyxh);
//                        wrapper5.in(TjSampling::getProId,proIds);
//                        wrapper5.eq(TjSampling::getTjNum,tjNumber);
//                        tjSamplingService.update(wrapper5);
//                    }
//                }
            }
        }
//        if (config.equals("Y"))
//            wrapper.eq(TjSampling::getJyxh,"");
        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()){
            logger.info("cusId参数传的是:"+cusId);
            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()));
            sampling.setCusName(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);
    }
    @PostMapping("/mergeCaiYang")
    @ApiOperation(value = "采样登记合并项目接口")
    @Transactional
    public AjaxResult mergeCaiYang(@RequestBody List<String> ids) {
        if (null != ids && !ids.isEmpty()) {
            if(ids.size()==1)return AjaxResult.error("请选择至少两条项目进行合并!");
            int i = tjSamplingService.panduanshifoukeyihebing(ids);
            if (i > 1) {
                return AjaxResult.error("标本类型不一致,不可合并");
            }
            int pdsfczhbxm = tjSamplingService.pdsfczhbxm(ids);
            if (pdsfczhbxm == ids.size()) return AjaxResult.error("多个合并项目不可再继续合并!");
            if (pdsfczhbxm > 1) return AjaxResult.error("最多允许选择一个合并过的项目!");
            if (pdsfczhbxm == 0) {
                TjSampling tjSampling = tjSamplingService.getById(ids.get(0));
                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);
                sampling.setJyxh(idUtils.generateLisID());
                if (tjSamplingService.save(sampling)) {
                    if (tjSamplingService.updateHeBingXm(ids, sampling.getId())) {
                        return AjaxResult.success("合并项目成功!");
                    }
                }
                return AjaxResult.error("操作失败!");
            } else {
                TjSampling tjSampling = tjSamplingService.getTjSamplingByHb(ids);
                List<TjSampling> samplingList = tjSamplingService.getTjSamplingListByHb(ids);
                if (null != tjSampling && null != samplingList && !samplingList.isEmpty()) {
                    List<String> stringList = samplingList.stream().map(TjSampling::getId).collect(Collectors.toList());
                    Map<String, Object> map = tjSamplingService.hebingCaiYangInFo(stringList);
                    String proId = map.get("proId").toString();
                    String proName = map.get("proName").toString();
                    tjSampling.setProId(proId);
                    tjSampling.setProName(proName);
                    if (tjSamplingService.updateById(tjSampling)) {
                        if (tjSamplingService.updateHeBingXm(stringList, tjSampling.getParentId())) {
                            return AjaxResult.success("合并项目成功!");
                        }
                    }
                }
                return AjaxResult.error("操作失败!");
            }
        }
        return AjaxResult.error("请选择你要合并的项目!!!");
        String lis_tmh_prefix = configService.selectConfigByKey("make_lis_tmh_prefix");
        return tjSamplingService.mergeCaiYangTran(ids,lis_tmh_prefix);
    }
@@ -398,38 +483,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.confirmApi(ids,config,mergeRequest);
    }
}