Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeClassifyTemplateAttrServiceImpl.java
@@ -2,23 +2,30 @@
import com.alibaba.fastjson.JSONObject;
import com.alibaba.nacos.common.utils.StringUtils;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.github.yulichang.wrapper.MPJLambdaWrapper;
import com.vci.ubcs.code.constant.MdmBtmTypeConstant;
import com.vci.ubcs.code.dto.CodeClassifyTemplateAttrDTO;
import com.vci.ubcs.code.entity.CodeClassify;
import com.vci.ubcs.code.entity.CodeClassifyTemplateAttr;
import com.vci.ubcs.code.entity.CodeClassifyTemplate;
import com.vci.ubcs.code.entity.CodeSynonym;
import com.vci.ubcs.code.enumpack.CodeLevelTypeEnum;
import com.vci.ubcs.code.mapper.CodeClassifyTemplateAttrMapper;
import com.vci.ubcs.code.mapper.CodeClassifyTemplateMapper;
import com.vci.ubcs.code.service.ICodeClassifyTemplateAttrService;
import com.vci.ubcs.code.service.ICodeReferConfigService;
import com.vci.ubcs.code.service.ICodeSynonymService;
import com.vci.ubcs.code.service.ICodeTempphaseService;
import com.vci.ubcs.code.vo.CodeReferConfigVO;
import com.vci.ubcs.code.vo.pagemodel.CodeClassifyTemplateAttrVO;
import com.vci.ubcs.code.vo.pagemodel.CodeSynonymVO;
import com.vci.ubcs.code.vo.pagemodel.UIFormReferVO;
import com.vci.ubcs.code.wrapper.CodeClassifyTemplateAttrWrapper;
import com.vci.ubcs.omd.feign.IBtmTypeClient;
@@ -27,6 +34,7 @@
import com.vci.ubcs.starter.exception.VciBaseException;
import com.vci.ubcs.starter.revision.service.RevisionModelUtil;
import com.vci.ubcs.starter.util.DefaultAttrAssimtUtil;
import com.vci.ubcs.starter.util.MdmBtmTypeConstant;
import com.vci.ubcs.starter.util.PatternUtil;
import com.vci.ubcs.starter.util.UBCSCondition;
import com.vci.ubcs.starter.web.enumpck.VciFieldTypeEnum;
@@ -40,6 +48,7 @@
import org.springblade.core.log.exception.ServiceException;
import org.springblade.core.mp.support.Condition;
import org.springblade.core.mp.support.Query;
import org.springblade.core.secure.utils.AuthUtil;
import org.springblade.core.tool.api.R;
import org.springblade.core.tool.utils.Func;
import org.springframework.beans.factory.annotation.Autowired;
@@ -93,6 +102,10 @@
    */
   @Resource
   private IBtmTypeClient btmTypeClient;
   @Resource
   @Lazy
   private ICodeSynonymService codeSynonymService;
   /**
    * 查询所有的主题库分类的模板属性
@@ -203,12 +216,20 @@
    * @throws VciBaseException 拷贝属性出错的时候会抛出异常
    */
   @Override
   public  CodeClassifyTemplateAttrVO codeClassifyTemplateAttrDO2VO(CodeClassifyTemplateAttr codeClassifyTemplateAttrDO) throws VciBaseException{
   public CodeClassifyTemplateAttrVO codeClassifyTemplateAttrDO2VO(CodeClassifyTemplateAttr codeClassifyTemplateAttrDO) throws VciBaseException{
      CodeClassifyTemplateAttrVO vo = new CodeClassifyTemplateAttrVO();
      if(codeClassifyTemplateAttrDO != null){
         BeanUtilForVCI.copyPropertiesIgnoreCase(codeClassifyTemplateAttrDO,vo);
         //如果有lcstatus的类的话
         vo.setAttributeDataTypeText(VciFieldTypeEnum.getTextByValue(vo.getAttributeDataType()));
         if(Func.isNotBlank(codeClassifyTemplateAttrDO.getSysonymRuleOids())){
            vo.setSysonymRuleOidsText(
               codeSynonymService.selectNameByWrapper(
                  Wrappers.<CodeSynonym>query()
                     .lambda().in(CodeSynonym::getOid, Func.toStrList(",", codeClassifyTemplateAttrDO.getSysonymRuleOids()))
               )
            );
         }
      }
      return vo;
   }
@@ -307,7 +328,7 @@
         query.setCurrent(pageHelper.getPage());
      }
      IPage<CodeClassifyTemplateAttr> doList = baseMapper.
         selectPage(Condition.getPage(query), UBCSCondition.getQueryWrapperByMapString(conditionMap,CodeClassifyTemplateAttr.class));
         selectPage(Condition.getPage(query), UBCSCondition.getQueryWrapperByMapString(conditionMap,CodeClassifyTemplateAttr.class).orderByAsc("ordernum"));
      if (!CollectionUtils.isEmpty(doList.getRecords())) {
         dataGrid.setData(codeClassifyTemplateAttrDO2VOs(doList.getRecords()));
         dataGrid.setTotal(VciBaseUtil.getInt(String.valueOf(baseMapper.selectCount(UBCSCondition.getQueryWrapperByMapString(conditionMap,CodeClassifyTemplateAttr.class)))));
@@ -373,6 +394,12 @@
         //将DTO转换为DO
         CodeClassifyTemplateAttr codeClassifyTemplateAttrDO = new CodeClassifyTemplateAttr();
         BeanUtilForVCI.copyPropertiesIgnoreCase(codeClassifyTemplateAttrDTO,codeClassifyTemplateAttrDO);
         codeClassifyTemplateAttrDO.setCreateTime(codeClassifyTemplateAttrDO.getCreateTime()!=null?codeClassifyTemplateAttrDO.getCreateTime():new Date());
         // codeClassifyTemplateAttrDO.setCreator(String.valueOf(AuthUtil.getUser().getUserId()));
         codeClassifyTemplateAttrDO.setCreator(String.valueOf(AuthUtil.getUser().getAccount()));
         codeClassifyTemplateAttrDO.setLastModifyTime(new Date());
         // codeClassifyTemplateAttrDO.setLastModifier(String.valueOf(AuthUtil.getUser().getUserId()));
         codeClassifyTemplateAttrDO.setLastModifier(String.valueOf(AuthUtil.getUser().getAccount()));
         codeClassifyTemplateAttrDOInsert.add(codeClassifyTemplateAttrDO);
         if(StringUtils.isNotBlank(codeClassifyTemplateAttrDO.getPrefixValue())){
@@ -430,15 +457,9 @@
         if(Func.isNotEmpty(codeReferConfigVO) && codeReferConfigVO.getIsPersistence()=="true"){
            codeReferConfigService.insert(codeReferConfigVO);
         }
      }
      //执行数据保存操作
//      WebUtil.setPersistence(false);//不执行保存
      //先都删了
//      VciQueryWrapperForDO deleteAttrWrapper = new VciQueryWrapperForDO(CodeClassifyTemplateAttrDO.class);
//      deleteAttrWrapper.addQueryMap("CLASSIFYTEMPLATEOID",CLASSIFYTEMPLATEOID);
      Map<String,Object> condition = new HashMap<>();
      condition.put("CLASSIFYTEMPLATEOID",CLASSIFYTEMPLATEOID);
      List<CodeClassifyTemplateAttr> codeClassifyTemplateAttrDODelete = baseMapper.selectByMap(condition);
@@ -448,7 +469,6 @@
      for (CodeClassifyTemplateAttr codeClassifyTemplateAttrDO:codeClassifyTemplateAttrDODelete){
         oids.add(codeClassifyTemplateAttrDO.getOid());
      }
//      BatchCBO batchCBOTemplateDelete = new BatchCBO();
      if(!CollectionUtils.isEmpty(oids)){
         this.removeBatchByIds(oids);
      }
@@ -463,8 +483,6 @@
      }
//      SessionInfo sessionInfo = VciBaseUtil.getCurrentUserSessionInfo();
      //处理可输可选的字符
      if(!CollectionUtils.isEmpty(prefix)){
         for (String s : prefix) {
@@ -474,7 +492,6 @@
            dictBiz.setDictValue(s);
            iDictBizClient.getCheck(dictBiz) ;
         }
//            .saveBySameNamespaceAndFlag(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR,"prefix",prefix,sessionInfo);
      }
      if(!CollectionUtils.isEmpty(suffix)){
         for (String s : suffix) {
@@ -484,7 +501,6 @@
            dictBiz.setDictValue(s);
            iDictBizClient.getCheck(dictBiz) ;
         }
//         charService.saveBySameNamespaceAndFlag(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR,"suffix",suffix,sessionInfo);
      }
      if(!CollectionUtils.isEmpty(dateFormates)){
         for (String s : dateFormates) {
@@ -494,11 +510,7 @@
            dictBiz.setDictValue(s);
            iDictBizClient.getCheck(dictBiz) ;
         }
//         charService.saveBySameNamespaceAndFlag(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR,"dateFormates",dateFormates,sessionInfo);
      }
//      WebUtil.setPersistence(true);//执行保存
//      boService.persistenceBatch(batchCBOTemplateDelete);//一起执行保存
      return codeClassifyTemplateAttrDO2VOs(codeClassifyTemplateAttrDOInsert);
   }
@@ -753,6 +765,10 @@
               inSearch = false;
            }
            if(inSearch) {
               if(!VciFieldTypeEnum.VTDouble.equals(osBtmTypeAttributeVO.getAttrDataType())){
                  osBtmTypeAttributeVO.setPrecisionLength(null);
                  osBtmTypeAttributeVO.setScaleLength(null);
               }
               boAttrss.add(osBtmTypeAttributeVO);
            }
         }
@@ -873,4 +889,14 @@
      return R.success("操作成功!");
   }
   /**
    * 使用查询封装器来查询
    * @param wrapper 查询封装器
    * @return 数据对象
    */
   @Override
   public List<CodeClassifyTemplateAttr> selectByWrapper(Wrapper wrapper) {
      return codeClassifyTemplateAttrMapper.selectList(wrapper);
   }
}