From 4494a005613728c9dc22d018bca42ef5d3ebcf69 Mon Sep 17 00:00:00 2001
From: xiejun <xiejun@vci-tech.com>
Date: 星期二, 14 一月 2025 20:41:47 +0800
Subject: [PATCH] 产品型号集成,类型转换,人员组织加日志,申请接口引用码段值校验

---
 Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java |  150 +++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 142 insertions(+), 8 deletions(-)

diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java
index a77c636..3181924 100644
--- a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java
+++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeSynonymServiceImpl.java
@@ -16,13 +16,36 @@
  */
 package com.vci.ubcs.code.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.baomidou.mybatisplus.extension.toolkit.SqlHelper;
+import com.github.yulichang.wrapper.MPJLambdaWrapper;
+import com.vci.ubcs.code.constant.FrameWorkDefaultValueConstant;
+import com.vci.ubcs.code.entity.CodeClassifyTemplate;
+import com.vci.ubcs.code.entity.CodeClassifyTemplateAttr;
+import com.vci.ubcs.code.entity.CodeSynonym;
 import com.vci.ubcs.code.mapper.CodeSynonymMapper;
+import com.vci.ubcs.code.service.ICodeClassifyTemplateAttrService;
 import com.vci.ubcs.code.service.ICodeSynonymService;
-import com.vci.ubcs.code.vo.CodeSynonymVO;
+import com.vci.ubcs.code.vo.pagemodel.CodeClassifyTemplateAttrVO;
+import com.vci.ubcs.code.wrapper.CodeClassifyTemplateAttrWrapper;
+import com.vci.ubcs.starter.enumpack.CodeTableNameEnum;
+import com.vci.ubcs.starter.util.DefaultAttrAssimtUtil;
+import com.vci.ubcs.starter.util.MdmBtmTypeConstant;
+import com.vci.ubcs.starter.util.UBCSCondition;
+import lombok.AllArgsConstructor;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.Func;
 import org.springframework.stereotype.Service;
-import com.baomidou.mybatisplus.core.metadata.IPage;
 
-import javax.annotation.Resource;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Set;
 
 /**
  * 杩戜箟璇嶇淮鎶� 鏈嶅姟瀹炵幇绫�
@@ -31,15 +54,126 @@
  * @since 2023-04-04
  */
 @Service
-public class CodeSynonymServiceImpl implements ICodeSynonymService {
+@AllArgsConstructor
+public class CodeSynonymServiceImpl extends ServiceImpl<CodeSynonymMapper, CodeSynonym> implements ICodeSynonymService {
 
-	@Resource
-	CodeSynonymMapper codeSynonymMapper;
+	private final CodeSynonymMapper codeSynonymMapper;
 
+	private final ICodeClassifyTemplateAttrService codeClassifyTemplateAttrService;
+
+	/**
+	 * 杩戜箟璇嶇淮鎶� 鏂板
+	 * @param codeSynonym
+	 * @return
+	 */
 	@Override
-	public IPage<CodeSynonymVO> selectPlCodeSynonymPage(IPage<CodeSynonymVO> page, CodeSynonymVO plCodeSynonym) {
-		return page.setRecords(codeSynonymMapper.selectPlCodeSynonymPage(page, plCodeSynonym));
+	public boolean addSave(CodeSynonym codeSynonym) {
+		if(codeSynonym.getSynonymValue().isEmpty() || codeSynonym.getSourceValue().isEmpty()){
+			throw new ServiceException("婧愬�煎拰杩戜箟璇嶄笉鑳戒负绌�");
+		}
+		DefaultAttrAssimtUtil.addDefaultAttrAssimt(codeSynonym, MdmBtmTypeConstant.CODE_SYNONYM);
+		// 娣诲姞鏃堕粯璁や负缂栬緫涓�
+		codeSynonym.setLcStatus(FrameWorkDefaultValueConstant.FRAMEWORK_RELEASE_RELEASED);
+		return SqlHelper.retBool(codeSynonymMapper.insert(codeSynonym));
 	}
 
+	/**
+	 * 杩戜箟璇嶇淮鎶� 淇敼
+	 * @param codeSynonym
+	 * @return
+	 */
+	@Override
+	public boolean editSave(CodeSynonym codeSynonym) {
+		DefaultAttrAssimtUtil.updateDefaultAttrAssimt(codeSynonym);
+		return SqlHelper.retBool(codeSynonymMapper.updateById(codeSynonym));
+	}
+
+	/**
+	 * 杩戜箟璇嶇姸鎬佸仠鐢ㄥ惎鐢�
+	 * @param map
+	 * @return
+	 */
+	@Override
+	public boolean updateStatus(Map<String, String> map) {
+		if(Func.isEmpty(map.getOrDefault("oid",""))){
+			throw new ServiceException("蹇呬紶鍙傛暟oid涓嶈兘涓虹┖锛�");
+		}
+		if(Func.isEmpty(map.getOrDefault("lcStatus",""))){
+			throw new ServiceException("鐢熷懡鍛ㄦ湡鐘舵�佷笉鑳戒负绌猴紒");
+		}
+		LambdaUpdateWrapper<CodeSynonym> updateWrapper = Wrappers.<CodeSynonym>update()
+			.lambda().eq(CodeSynonym::getOid, map.get("oid"))
+			.set(CodeSynonym::getLcStatus, map.get("lcStatus"));
+		return SqlHelper.retBool(this.codeSynonymMapper.update(null,updateWrapper));
+	}
+
+	/**
+	 * 鍒犻櫎
+	 * @param oids
+	 * @return
+	 */
+	@Override
+	public R deleteDataByIds(String oids) {
+		if(Func.isBlank(oids)){
+			return R.fail("鏈幏鍙栫殑鍙傛暟oid");
+		}
+		List<Long> oidList = Func.toLongList(oids);
+		LambdaQueryWrapper<CodeClassifyTemplateAttr> wrapper = Wrappers.<CodeClassifyTemplateAttr>query().lambda();
+		oidList.stream().forEach(item->{
+			wrapper.or().like(CodeClassifyTemplateAttr::getSysonymRuleOids, item);
+		});
+		List<CodeClassifyTemplateAttr> voList = codeClassifyTemplateAttrService.selectByWrapper(wrapper);
+		if(!voList.isEmpty()){
+			return R.fail("鍒犻櫎鐨勮鍒欎腑瀛樺湪琚紩鐢ㄧ殑杩戜箟璇嶆煡璇㈣鍒欙紒");
+		}
+		return R.status(SqlHelper.retBool(codeSynonymMapper.deleteBatchIds(oidList)));
+	}
+
+	/**
+	 * 鏌ョ湅杩戜箟璇嶆煡璇㈣鍒欎娇鐢ㄨ寖鍥�
+	 * @param oid
+	 * @return
+	 */
+	@Override
+	public List<CodeClassifyTemplateAttrVO> listUseRangeInClsTempAttr(String oid) {
+		MPJLambdaWrapper<CodeClassifyTemplateAttr> mpjLambdaWrapper = new MPJLambdaWrapper<>(CodeClassifyTemplateAttr.class, CodeTableNameEnum.PL_CODE_CLSTEMPATTR.getText())
+			.selectAll(CodeClassifyTemplateAttr.class)
+			.selectAs(CodeClassifyTemplate::getName,CodeClassifyTemplateAttr::getClassifyTemplateOidName)
+			.leftJoin(CodeClassifyTemplate.class,CodeTableNameEnum.PL_CODE_CLSTEMPLATE.getText(),CodeClassifyTemplate::getOid,CodeClassifyTemplateAttr::getClassifyTemplateOid)
+			.like(CodeClassifyTemplateAttr::getSysonymRuleOids, oid);
+		List<CodeClassifyTemplateAttr> voList = codeClassifyTemplateAttrService.selectByWrapper(mpjLambdaWrapper);
+		return CodeClassifyTemplateAttrWrapper.build().listVO(voList);
+	}
+
+	@Override
+	public String selectNameByWrapper(LambdaQueryWrapper<CodeSynonym> wrappers) {
+		List<CodeSynonym> codeSynonymsList = codeSynonymMapper.selectList(wrappers);
+		if(codeSynonymsList.isEmpty()){
+			return "";
+		}
+		StringBuilder res = new StringBuilder();
+		codeSynonymsList.stream().forEach(item->{
+			res.append(item.getName()).append("(").append(item.getId()).append(")").append(",");
+		});
+		return res.toString().replaceAll(",$", "");
+	}
+
+	/**
+	 * 鑾峰彇杩戜箟璇嶆煡璇㈣鍒�
+	 * @return
+	 */
+	@Override
+	public Map<String, List<CodeSynonym>> getCodeSynonymByOids(Map<String, CodeClassifyTemplateAttrVO> sysonymAttrMap) {
+		if(sysonymAttrMap.isEmpty()){
+			return new HashMap<>();
+		}
+		Map<String, List<CodeSynonym>> resMap = new HashMap<>();
+		for (String key : sysonymAttrMap.keySet()) {
+			List<String> oids = Func.toStrList(sysonymAttrMap.get(key).getSysonymRuleOids());
+			List<CodeSynonym> codeSynonyms = codeSynonymMapper.selectBatchIds(oids);
+			resMap.put(key,codeSynonyms);
+		}
+		return resMap;
+	}
 
 }

--
Gitblit v1.9.3