From e14e4217b3f53a5cad511b4331cd7c0a40a40db2 Mon Sep 17 00:00:00 2001 From: zjh <1084500556@qq.com> Date: 星期四, 19 十二月 2024 13:52:03 +0800 Subject: [PATCH] zjh202412019 --- ltkj-admin/src/main/java/com/ltkj/web/controller/system/TjSamplingController.java | 141 ++++++++++++++++------------------------------ 1 files changed, 49 insertions(+), 92 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 0f529eb..802c01d 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; @@ -69,6 +66,8 @@ private LisApiMethod lisApiMethod; @Autowired private ISysConfigService configService; + @Autowired + private SamplingServiceApi samplingService; /** * 鏌ヨ浣撴閲囨牱绠$悊鍒楄〃 @@ -217,24 +216,27 @@ LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>(); 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(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); @@ -245,25 +247,54 @@ /** * 鏍规嵁瀹㈡埛鑾峰彇閲囨牱鍒楄〃 * - * @param cusId + * @param tjNumber * @return */ @GetMapping("/getCusCyList") @ApiOperation(value = "鏍规嵁瀹㈡埛鑾峰彇閲囨牱鍒楄〃") - public AjaxResult getCusCyList(@RequestParam @ApiParam(value = "瀹㈡埛id") String cusId, + public AjaxResult getCusCyList(@RequestParam @ApiParam(value = "瀹㈡埛id") String tjNumber, @RequestParam(defaultValue = "1") @ApiParam(value = "0鏄�1鍚�") Integer isSignFor) { - if (cusId == null || StrUtil.isBlank(cusId)) + if (tjNumber == null || StrUtil.isBlank(tjNumber)) return AjaxResult.error("鍙傛暟閿欒,鏈紶鍙傛暟"); LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>(); - wrapper.eq(TjSampling::getCusId, cusId); + 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); List<TjSampling> list = tjSamplingService.list(wrapper); if (list.isEmpty()){ - logger.info("cusId鍙傛暟浼犵殑鏄�:"+cusId); + logger.info("jtNum ->{}",tjNumber); 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)); + } + } + 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())); + } + } + 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) { TjCustomer customer = customerService.getById(sampling.getCusId()); TjOrder order = orderService.getOrderByTjNum(sampling.getTjNum()); @@ -361,80 +392,6 @@ public AjaxResult confirmSampling(@RequestBody List<String> ids) { String config = configService.selectConfigByKey("sfkqdyhis"); String mergeRequest = configService.selectConfigByKey("use_lis_pacs_is_auto_merge_request"); - return confirm(ids,config,mergeRequest); - } - - /** - * 纭閲囨牱鎺ュ彛 - */ - public Boolean confirmSamplingApi(List<String> ids,String sfkqdyhis,String mergeRequest) { - AjaxResult confirm = confirm(ids, sfkqdyhis, mergeRequest); - log.info("纭閲囨牱杩斿洖 ->{}",confirm); - return confirm.get("code").toString().equals("200"); - } - - private AjaxResult confirm(List<String> ids,String config,String mergeRequest) { - if (null == ids || ids.isEmpty()) { - return AjaxResult.error("璇烽�夋嫨瑕佺‘璁ら」"); - } - List<TjSampling> tjSamplings = tjSamplingService.listByIds(ids); - if (tjSamplings.isEmpty()) - return AjaxResult.error("璇烽�夋嫨瑕佺‘璁ら」"); - String errorMsg = ""; - for (TjSampling sampling : tjSamplings) { - if (sampling.getJyxmdm() == null) - errorMsg+=sampling.getProName()+"鍦╨is绯荤粺鏈壘鍒板搴旂紪鐮佹棤娉曞彂鍑虹敵璇�"; - 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); -// } -// } - TjOrder tjOrder = orderService.getOrderByTjNum(sampling.getTjNum()); - if(null==tjOrder) return AjaxResult.error("浣撴璁板綍涓嶅瓨鍦�"); - TjCustomer tjCustomer = customerService.getById(tjOrder.getUserId()); - boolean updChild; - Boolean save; - if (null != config && config.equals("Y") && !mergeRequest.equals("Y")) { - save = lisApiMethod.save(sampling, tjOrder, tjCustomer); - }else { - save = true; - } - if (save) { - if (sampling.getIsMerge() == 1) { - LambdaQueryWrapper<TjSampling> wrapper = new LambdaQueryWrapper<>(); - wrapper.eq(TjSampling::getParentId, sampling.getId()); - List<TjSampling> list = tjSamplingService.list(wrapper); - for (TjSampling tjSampling : list) { - tjSampling.setIsSignFor("0"); - } - updChild = tjSamplingService.updateBatchById(list); - } else { - updChild = true; - } - if (!tjSamplingService.updateById(sampling) && !updChild) { -// lisApiMethod.cancel(sampling.getJyxh(), tjOrder.getCardId(), PinyinUtil.getFirstLetter(tjCustomer.getCusName(), "")); -// TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); - return AjaxResult.error("鎿嶄綔澶辫触璇烽噸璇�"); - } - } else { - return AjaxResult.error("鎿嶄綔澶辫触璇烽噸璇�"); - } - } - if (StrUtil.isNotBlank(errorMsg)) return AjaxResult.error(errorMsg); - return AjaxResult.success("鎿嶄綔鎴愬姛"); + return samplingService.confirm(ids,config,mergeRequest); } } -- Gitblit v1.8.0