From 5bc0e587dc5dd7ca40f4285eed966429e69535e7 Mon Sep 17 00:00:00 2001 From: zss <zss@example.com> Date: 星期三, 18 十二月 2024 10:54:49 +0800 Subject: [PATCH] 检验任务添加一个撤销的功能(如果已经提交的撤销) --- inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java | 75 +++++++++++++++++++++++++++++++++++++ 1 files changed, 75 insertions(+), 0 deletions(-) diff --git a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java index 21996f2..d185f98 100644 --- a/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java +++ b/inspect-server/src/main/java/com/yuanchu/mom/service/impl/InsOrderPlanServiceImpl.java @@ -1264,6 +1264,81 @@ return 1; } + @Override + public int cancelSubmitPlan(Integer orderStateId) { + InsOrderState orderState = insOrderStateMapper.selectById(orderStateId); + InsOrder insOrder = insOrderMapper.selectById(orderState.getInsOrderId()); + InsSample insSample = insSampleMapper.selectById(orderState.getInsSampleId()); + /*鍒犻櫎璁板綍妫�楠屼换鍔℃瘡娆$殑澶囨敞淇℃伅*/ + insOrderUserMapper.delete(Wrappers.<InsOrderUser>lambdaQuery() + .eq(InsOrderUser::getInsOrderStateId,orderState.getId()) + .eq(InsOrderUser::getNum,orderState.getNum())); + //鎾ら攢鎻愪氦 + insOrderStateMapper.update(null, Wrappers.<InsOrderState>lambdaUpdate() + .eq(InsOrderState::getInsOrderId, orderState.getInsOrderId()) + .eq(InsOrderState::getInsSampleId, orderState.getInsSampleId()) + .eq(InsOrderState::getLaboratory, orderState.getLaboratory()) + .set(InsOrderState::getInsState, 2)); + Integer userId = getLook.selectPowerByMethodAndUserId(null).get("userId"); + //LIMS绯荤粺娑堟伅鎺ㄩ�� + InformationNotification info = new InformationNotification(); + info.setCreateUser(insProductMapper.selectUserById(userId).get("name")); + info.setMessageType("2"); + info.setTheme("澶嶆牳鎾ら攢閫氱煡"); + info.setContent("鎮ㄦ湁涓�鏉℃楠屼换鍔″緟澶嶆牳宸叉挙閿�鐨勬秷鎭�,璁㈠崟鍙锋槸锛�" + insOrder.getEntrustCode() + ",鏍峰搧鍚嶇О涓猴細" + insSample.getSample()); + info.setSenderId(userId); + info.setConsigneeId(orderState.getVerifyUser()); + info.setViewStatus(false); + info.setJumpPath("b1-inspect-order-plan"); + informationNotificationService.addInformationNotification(info); + //鍒犻櫎澶嶆牳浜�--妫�楠屽崟鐩稿叧璐熻矗浜� + insSampleUserMapper.delete(Wrappers.<InsSampleUser>lambdaQuery() + .eq(InsSampleUser::getState,1) + .eq(InsSampleUser::getSonLaboratory,orderState.getLaboratory()) + .eq(InsSampleUser::getUserId,orderState.getVerifyUser()) + .eq(InsSampleUser::getInsSampleId,orderState.getInsSampleId())); + //鍒犻櫎鐢熸垚鐨勬姤鍛� + if (orderState.getLaboratory().equals("鐢佃矾璇曢獙")) { + List<InsOrderFile> insOrderFiles = insOrderFileMapper.selectList(Wrappers.<InsOrderFile>lambdaQuery() + .eq(InsOrderFile::getType, 2) + .like(InsOrderFile::getFileName,"鐢佃矾鍙傛暟.docx") + .eq(InsOrderFile::getInsOrderId, insOrder.getId()) + .eq(InsOrderFile::getInsSampleId, orderState.getInsSampleId()) + .eq(InsOrderFile::getSonLaboratory, orderState.getLaboratory())); + for (InsOrderFile insOrderFile : insOrderFiles) { + File file = new File(wordUrl + "/" + insOrderFile.getFileUrl()); + file.delete(); + insOrderFileMapper.deleteById(insOrderFile.getId()); + } + } + + /*鍒犻櫎鐢熸垚浜ч噺宸ユ椂*/ + List<InsProduct> insProducts = insProductMapper.selectList(Wrappers.<InsProduct>lambdaQuery().eq(InsProduct::getInsSampleId, insSample.getId())); + List<Integer> productIds = insProducts.stream().map(InsProduct::getId).distinct().collect(Collectors.toList()); + auxiliaryOutputWorkingHoursMapper.delete(Wrappers.<AuxiliaryOutputWorkingHours>lambdaQuery() + .eq(AuxiliaryOutputWorkingHours::getSample,insSample.getSampleCode()) + .in(AuxiliaryOutputWorkingHours::getInsProductId,productIds) + .eq(AuxiliaryOutputWorkingHours::getNum,orderState.getNum())); + + // todo 浼佷笟寰俊娑堟伅鎺ㄩ�丂zss + HashMap<String, Object> map = new HashMap<>(); + String account = userMapper.selectById(orderState.getVerifyUser()).getAccount(); + map.put("touser", account);//鎺ユ敹娑堟伅鎴愬憳鐨勮处鍙�'ZT-031292'杩欑绫诲瀷(濡傛灉鏈夊涓敤'|'鍒嗛殧) + map.put("toparty", "");//鎺ユ敹閮ㄩ棬id + map.put("totag", "");//娑堟伅鏍囩id + map.put("msgtype", "text");//娑堟伅绫诲瀷 text:鏂囨湰 + map.put("agentid", 1000517);//搴旂敤id + HashMap<String, Object> hashMap = new HashMap<>(); + hashMap.put("content", "鎮ㄦ湁涓�鏉″鏍哥殑娑堟伅宸叉挙閿�,璁㈠崟鍙锋槸锛�" + insOrder.getEntrustCode() + ",鏍峰搧鍚嶇О涓猴細" + insSample.getSample() + + ",璇峰墠寰�LIMS绯荤粺鏌ョ湅銆傝鐐瑰嚮<a href=\"https://ztwxlims.ztt.cn:7443/enter\">涓ぉ閫氫俊LIMS绯荤粺 </a>"); + map.put("text", hashMap);//娑堟伅鍐呭 + map.put("safe", 0);//鏄惁淇濆瘑娑堟伅.0鍚� + map.put("enable_id_trans", 0);//鏄惁寮�鍚痠d杞瘧.0鍚� + map.put("enable_duplicate_check", 0);//鏄惁寮�鍚噸澶嶆秷鎭鏌�.0鍚� + qywxApi.send(map); + return 0; + } + public static String getWeek(String dayStr) { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { -- Gitblit v1.9.3