田源
2023-08-18 9c6eab50af6e940151d875571d266e9f045a549a
Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeClassifyTemplateAttrServiceImpl.java
@@ -7,36 +7,44 @@
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.CodeClassifyTemplateAttr;
import com.vci.ubcs.code.entity.CodeClassifyTemplate;
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.mapper.CodeOsbtmtypeattributeMapper;
import com.vci.ubcs.code.service.ICodeClassifyTemplateAttrService;
import com.vci.ubcs.code.service.ICodeReferConfigService;
import com.vci.ubcs.code.service.ICodeTempphaseService;
import com.vci.ubcs.code.vo.CodeOsbtmtypeattributeVO;
import com.vci.ubcs.code.vo.CodeReferConfigVO;
import com.vci.ubcs.code.vo.pagemodel.CodeClassifyTemplateAttrVO;
import com.vci.ubcs.code.vo.pagemodel.UIFormReferVO;
import com.vci.ubcs.code.wrapper.CodeClassifyTemplateAttrWrapper;
import com.vci.ubcs.omd.feign.IBtmTypeClient;
import com.vci.ubcs.omd.vo.BtmTypeAttributeVO;
import com.vci.ubcs.omd.vo.BtmTypeVO;
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;
import com.vci.ubcs.starter.web.pagemodel.*;
import com.vci.ubcs.starter.util.Map2MPJLambdaUtil;
import com.vci.ubcs.starter.web.pagemodel.PageHelper;
import com.vci.ubcs.starter.web.util.BeanUtilForVCI;
import com.vci.ubcs.starter.web.util.VciBaseUtil;
import com.vci.ubcs.starter.web.util.VciDateUtil;
import com.vci.ubcs.system.entity.DictBiz;
import com.vci.ubcs.system.feign.IDictBizClient;
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;
import org.springframework.cglib.beans.BeanMap;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@@ -63,25 +71,30 @@
   @Resource
   private CodeClassifyTemplateAttrMapper codeClassifyTemplateAttrMapper;
   //   @Resource
   //   CodeClstempattrMapper codeClstempattrMapper;
      //   @Resource
   //   ICodeTempphaseService codeTempphaseService;
   @Resource
   IDictBizClient iDictBizClient;
   @Resource
   CodeClassifyTemplateMapper codeClassifyTemplateMapper;
   @Resource
   CodeOsbtmtypeattributeMapper codeOsbtmtypeattributeMapper;
   private ICodeReferConfigService codeReferConfigService;
   @Resource
   @Lazy
   ICodeTempphaseService codeTempphaseService;
   /**
    * 对象的操作
    */
   @Autowired(required = false)
   private RevisionModelUtil revisionModelUtil;
   /**
    * 属性服务对象
    */
   @Resource
   private IBtmTypeClient btmTypeClient;
   /**
    * 查询所有的主题库分类的模板属性
@@ -127,7 +140,7 @@
      if(conditionMap == null){
         conditionMap = new HashMap<String, String>();
      }
      return gridCodeClassifyTemplateAttr(Map2MPJLambdaUtil.getMPJLambdaWrapperByMapString(conditionMap, CodeClassifyTemplateAttr.class),pageHelper);
      return gridCodeClassifyTemplateAttr(UBCSCondition.getMPJLambdaWrapperByMapString(conditionMap, CodeClassifyTemplateAttr.class),pageHelper);
   }
   @Override
@@ -152,7 +165,11 @@
//         conditionMap.put("classifytemplateoid", QueryOptionConstant.IN + "(" + VciBaseUtil.toInSql(templateOids.toArray(new String[0])) + ")");
//         PageHelper pageHelper = new PageHelper(-1);
//         pageHelper.addDefaultAsc("orderNum");
         List<CodeClassifyTemplateAttr> attrDOS = baseMapper.selectByClassifytemplateoid(VciBaseUtil.toInSql(templateOids.toArray(new String[0])));
//         QueryWrapper<CodeClassifyTemplateAttr> wrapper = new QueryWrapper<>();
//         wrapper.in("classifytemplateoid",templateOids);
//         wrapper.orderByAsc("orderNum");
         List<CodeClassifyTemplateAttr> attrDOS = baseMapper.selectByClassifytemplateoidRel(VciBaseUtil.toInSql(templateOids.toArray(new String[0])));
//            baseMapper.selectByClassifytemplateoid(VciBaseUtil.toInSql(templateOids.toArray(new String[0])));
         if(!CollectionUtils.isEmpty(attrDOS)){
            attrDOList.addAll(attrDOS);
@@ -285,34 +302,17 @@
         pageHelper = new PageHelper(-1);
      }
      pageHelper.addDefaultAsc("ordernum");
//      IPage iPage = new IPage();
      Query query = new Query();
      query.setAscs("ordernum");
//      query.setSize(100);
      query.setSize(pageHelper.getLimit());
      if(pageHelper.getLimit() != -1){
         query.setSize(pageHelper.getLimit());
         query.setCurrent(pageHelper.getPage());
      }
//      Condition.getPage(query)
      CodeClassifyTemplateAttr codeClstempattrVO = new CodeClassifyTemplateAttr();
//      BeanUtil.toBean(map,codeClstempattrVO);
//      BeanUtil
      BeanMap beanMap = BeanMap.create(codeClstempattrVO);
      beanMap.putAll(conditionMap);
//      Condition.getQueryWrapper(
      IPage<CodeClassifyTemplateAttr> doList = baseMapper.
         selectPage(Condition.getPage(query), Condition.getQueryWrapper(codeClstempattrVO));
         selectPage(Condition.getPage(query), UBCSCondition.getQueryWrapperByMapString(conditionMap,CodeClassifyTemplateAttr.class).orderByAsc("ordernum"));
      if (!CollectionUtils.isEmpty(doList.getRecords())) {
//         CodeClstempattrEntity codeClstempattrEntity = new CodeClstempattrEntity();
//         BeanUtils.copyProperties(conditionMap, codeClstempattrEntity);
//         List<CodeClstempattrEntity> codeClstempattrEntities = new ArrayList<>();
//         BeanUtils.copyProperties(doList,codeClstempattrEntities);
//         codeClstempattrEntities.addAll(doList);
         dataGrid.setData(codeClassifyTemplateAttrDO2VOs(doList.getRecords()));
         dataGrid.setTotal(VciBaseUtil.getInt(String.valueOf(baseMapper.selectCount(Condition.getQueryWrapper(codeClstempattrVO)))));
         dataGrid.setTotal(VciBaseUtil.getInt(String.valueOf(baseMapper.selectCount(UBCSCondition.getQueryWrapperByMapString(conditionMap,CodeClassifyTemplateAttr.class)))));
      }
      return dataGrid;
   }
@@ -328,6 +328,7 @@
      //将DTO转换为DO
      CodeClassifyTemplateAttr codeClassifyTemplateAttrDO = new CodeClassifyTemplateAttr();
      BeanUtilForVCI.copyPropertiesIgnoreCase(codeClassifyTemplateAttrDTO,codeClassifyTemplateAttrDO);
      DefaultAttrAssimtUtil.addDefaultAttrAssimt(codeClassifyTemplateAttrDO,"codeclstempattr");
      baseMapper.insert(codeClassifyTemplateAttrDO);
      return codeClassifyTemplateAttrDO2VO(codeClassifyTemplateAttrDO);
   }
@@ -360,8 +361,10 @@
         throw new VciBaseException("模板属性英文名称【{0}】重复",new String[]{ repeatIdList.stream().collect(Collectors.joining(","))});
      }
      //模板oid
      // 模板oid
      String CLASSIFYTEMPLATEOID = null;
      //
      CodeReferConfigVO codeReferConfigVO = null;
      //转换
      List<CodeClassifyTemplateAttr> codeClassifyTemplateAttrDOInsert = new ArrayList<CodeClassifyTemplateAttr>();
      List<String> prefix = new ArrayList<>();
@@ -372,6 +375,10 @@
         //将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.setLastModifyTime(new Date());
         codeClassifyTemplateAttrDO.setLastModifier(String.valueOf(AuthUtil.getUser().getUserId()));
         codeClassifyTemplateAttrDOInsert.add(codeClassifyTemplateAttrDO);
         if(StringUtils.isNotBlank(codeClassifyTemplateAttrDO.getPrefixValue())){
@@ -402,7 +409,7 @@
            throw new VciBaseException("{0}{1}属性的时间格式不符合要求",new String[]{codeClassifyTemplateAttrDO.getId(),codeClassifyTemplateAttrDO.getName()});
         }
         //如果是组合规则,里面使用的属性不能缺失,也都得显示
         String componentrule = codeClassifyTemplateAttrDTO.getComponentrule();
         String componentrule = codeClassifyTemplateAttrDTO.getComponentRule();
         boolean isContainsDynamicParameter = PatternUtil.isContainsDynamicParameter(componentrule);
         if(isContainsDynamicParameter){
            List<String> userdAttrList =  PatternUtil.getKeyListByContent(componentrule);//包含的所有${xxx}中的xxx
@@ -413,7 +420,7 @@
               }
               //要看看表单是否显示
               String unFormDisplayAttr = userdAttrList.stream().filter(s -> !VciBaseUtil.getBoolean(attrDTOMap.getOrDefault(s.toLowerCase(Locale.ROOT),
                  new CodeClassifyTemplateAttrDTO()).getFormdisplayflag())).collect(Collectors.joining(","));
                  new CodeClassifyTemplateAttrDTO()).getFormDisplayFlag())).collect(Collectors.joining(","));
               if(StringUtils.isNotBlank(unFormDisplayAttr)){
                  throw new VciBaseException("{0}属性是组合规则,但是规则里包含的属性[{1}]在当前模板中没有设置 表单显示 ",new String[]{codeClassifyTemplateAttrDO.getName(),unFormDisplayAttr});
               }
@@ -421,17 +428,17 @@
         }
         if(CLASSIFYTEMPLATEOID==null){
            CLASSIFYTEMPLATEOID = codeClassifyTemplateAttrDTO.getClassifytemplateoid();
            CLASSIFYTEMPLATEOID = codeClassifyTemplateAttrDTO.getClassifyTemplateOid();
         }
         // 参照配置是否需要持久化
         codeReferConfigVO = JSONObject.parseObject(codeClassifyTemplateAttrDTO.getReferConfig(), CodeReferConfigVO.class);
         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);
@@ -441,11 +448,9 @@
      for (CodeClassifyTemplateAttr codeClassifyTemplateAttrDO:codeClassifyTemplateAttrDODelete){
         oids.add(codeClassifyTemplateAttrDO.getOid());
      }
//      BatchCBO batchCBOTemplateDelete = new BatchCBO();
      if(!CollectionUtils.isEmpty(oids)){
         baseMapper.deleteBatchIds(oids);
         this.removeBatchByIds(oids);
      }
      //再新增
      if(!CollectionUtils.isEmpty(codeClassifyTemplateAttrDOInsert)){
         this.saveBatch(codeClassifyTemplateAttrDOInsert);
@@ -457,42 +462,34 @@
      }
//      SessionInfo sessionInfo = VciBaseUtil.getCurrentUserSessionInfo();
      //处理可输可选的字符
      if(!CollectionUtils.isEmpty(prefix)){
         for (String s : prefix) {
            DictBiz dictBiz = new DictBiz();
            dictBiz.setCode(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR);
            dictBiz.setDictKey(s);
            dictBiz.setDictValue("prefix");
            dictBiz.setDictKey("prefix");
            dictBiz.setDictValue(s);
            iDictBizClient.getCheck(dictBiz) ;
         }
//            .saveBySameNamespaceAndFlag(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR,"prefix",prefix,sessionInfo);
      }
      if(!CollectionUtils.isEmpty(suffix)){
         for (String s : suffix) {
            DictBiz dictBiz = new DictBiz();
            dictBiz.setCode(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR);
            dictBiz.setDictKey(s);
            dictBiz.setDictValue("suffix");
            dictBiz.setDictKey("suffix");
            dictBiz.setDictValue(s);
            iDictBizClient.getCheck(dictBiz) ;
         }
//         charService.saveBySameNamespaceAndFlag(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR,"suffix",suffix,sessionInfo);
      }
      if(!CollectionUtils.isEmpty(dateFormates)){
         for (String s : dateFormates) {
            DictBiz dictBiz = new DictBiz();
            dictBiz.setCode(MdmBtmTypeConstant.CODE_CLASSIFY_TEMPLATE_ATTR);
            dictBiz.setDictKey(s);
            dictBiz.setDictValue("dateFormates");
            dictBiz.setDictKey("dateFormates");
            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);
   }
@@ -505,6 +502,7 @@
      }
      return isKV;
   }
   public boolean checkKVObj(String kvString){
      boolean isKV = true;
      try {
@@ -545,7 +543,7 @@
      }
      //判断传过来的参照配置是否是json格式
      if(StringUtils.isNotBlank(codeClassifyTemplateAttrDTO.getReferbtmid())&&!checkKVObj(codeClassifyTemplateAttrDTO.getReferbtmid())){
      if(StringUtils.isNotBlank(codeClassifyTemplateAttrDTO.getReferBtmId())&&!checkKVObj(codeClassifyTemplateAttrDTO.getReferBtmId())){
         throw new VciBaseException("枚举注入数据格式错误!");
      }
@@ -635,6 +633,7 @@
   public  CodeClassifyTemplateAttrVO getObjectByOid(String oid) throws VciBaseException{
      return codeClassifyTemplateAttrDO2VO(selectByOid(oid));
   }
   /**
    * 主键查询数据对象
    * @param oid 主键
@@ -683,31 +682,16 @@
   }
   /**
    * 参照主题库分类的模板属性列表
    * @param conditionMap 查询条件
    * @param pageHelper 分页和排序
    * @return 主题库分类的模板属性显示对象列表,生效的内容
    * @throws VciBaseException 查询条件和分页出错的时候会抛出异常
    */
//   @Override
//   public DataGrid<CodeClassifyTemplateAttrVO> refDataGridCodeClassifyTemplateAttr(Map<String, String> conditionMap, PageHelper pageHelper) throws VciBaseException{
//      if(conditionMap == null){
//         conditionMap = new HashMap<String, String>();
//      }
//      return gridCodeClassifyTemplateAttr(conditionMap,pageHelper);
//   }
   /**
    * 查询这个模板,业务类型下的所有未选择的属性
    * @param baseQueryObject
    * @return
    */
   @Override
   public DataGrid<CodeOsbtmtypeattributeVO> codeClassifyTemplateAttrByBtm(BaseQueryObject baseQueryObject){
   public DataGrid<BtmTypeAttributeVO> codeClassifyTemplateAttrByBtm(BaseQueryObject baseQueryObject){
      if(baseQueryObject.getConditionMap() == null){
         baseQueryObject.setConditionMap(new HashMap<>());
      }
      DataGrid<CodeOsbtmtypeattributeVO> dataGrid=new DataGrid<CodeOsbtmtypeattributeVO>();
      DataGrid<BtmTypeAttributeVO> dataGrid=new DataGrid<BtmTypeAttributeVO>();
      //模板oid
      String templateAttrOid = baseQueryObject.getConditionMap().get("oid");
      String name = baseQueryObject.getConditionMap().getOrDefault("name","");
@@ -722,53 +706,35 @@
      //查询模板对象
      CodeClassifyTemplate codeClassifyTemplateDO = codeClassifyTemplateMapper.selectById(templateAttrOid);
      //这个业务类型下的所有属性
      List<CodeOsbtmtypeattributeVO> boAttrs = (List<CodeOsbtmtypeattributeVO>) codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId());// this.btmService.listAttributeByBtmId(codeClassifyTemplateDO.getBtmTypeId());
//      codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId());
//      BeanUtils.copyProperties(codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId()),boAttrs);
      //把默认的属性也添加到boAttrs
      if(boAttrs == null){
         boAttrs = new ArrayList<>();
      // 没有模板对象不执行逻辑
      if(Objects.isNull(codeClassifyTemplateDO)){
         dataGrid.setData(new ArrayList<>());
         dataGrid.setTotal(0);
         return dataGrid;
      }
      if(!false){
//         List<CodeOsbtmtypeattributeVO> finalBoAttrs = boAttrs;
//         attributeService.getDefaultAttributeVOs().stream().forEach(attr-> {
//            CodeOsbtmtypeattributeVO attributeVO = new CodeOsbtmtypeattributeVO();
//            BeanUtil.convert(attr, attributeVO);
//            if ("id".equalsIgnoreCase(attributeVO.getId())) {
//               attributeVO.setName("企业编码");
//            }
//            if ("name".equalsIgnoreCase(attributeVO.getId())) {
//               attributeVO.setName("集团码");
//            }
//            attributeVO.setAttrDataType(attr.getAttributeDataType());
//            attributeVO.setAttributeLength(attr.getAttrLength());
//            attributeVO.setReferBtmTypeId(attr.getBtmTypeId());
//            attributeVO.setReferBtmTypeName(attr.getBtmTypeName());
//            finalBoAttrs.add(attributeVO);
//         });
//         boAttrs = finalBoAttrs;
         Object o = null;
      //这个业务类型下的所有属性
      R<BtmTypeVO> btmTypeVOR = btmTypeClient.getAllAttributeByBtmId(codeClassifyTemplateDO.getBtmTypeId());
      if(!btmTypeVOR.isSuccess()){
         throw new ServiceException("业务类型feign调用错误!");
      }
      //这个模板下已经有的属性
//      VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(CodeClassifyTemplateAttrDO.class);
//      queryWrapper.addQueryMap("CLASSIFYTEMPLATEOID",templateAttrOid);
      // VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(CodeClassifyTemplateAttrDO.class);
      // queryWrapper.addQueryMap("CLASSIFYTEMPLATEOID",templateAttrOid);
      Map<String,Object> condition = new HashMap<>(1);
      condition.put("CLASSIFYTEMPLATEOID",templateAttrOid);
      List<CodeClassifyTemplateAttr> codeClassifyTemplateAttrDOList = baseMapper.selectByMap(condition);
      List<String> btmOids = new ArrayList<String>();
      List<String> btmIds = new ArrayList<String>();
      for (CodeClassifyTemplateAttr codeClassifyTemplateAttrDO:codeClassifyTemplateAttrDOList){
         btmOids.add(codeClassifyTemplateAttrDO.getId());
         btmIds.add(codeClassifyTemplateAttrDO.getId());
      }
      //过滤掉已经存在的属性
      List<CodeOsbtmtypeattributeVO> boAttrss = new ArrayList<CodeOsbtmtypeattributeVO>();
      for (CodeOsbtmtypeattributeVO osBtmTypeAttributeVO:boAttrs){
         if(!btmOids.contains(osBtmTypeAttributeVO.getId())){
      List<BtmTypeAttributeVO> boAttrss = new ArrayList<BtmTypeAttributeVO>();
      for (BtmTypeAttributeVO osBtmTypeAttributeVO:btmTypeVOR.getData().getAttributes()){
         if(!btmIds.contains(osBtmTypeAttributeVO.getId())){
            //看看是不是有模糊查询
            boolean inSearch = true;
            if(StringUtils.isNotBlank(name) && !osBtmTypeAttributeVO.getName().contains(name.replace("*",""))){
@@ -778,10 +744,16 @@
               inSearch = false;
            }
            if(inSearch) {
               if(!VciFieldTypeEnum.VTDouble.equals(osBtmTypeAttributeVO.getAttrDataType())){
                  osBtmTypeAttributeVO.setPrecisionLength(null);
                  osBtmTypeAttributeVO.setScaleLength(null);
               }
               boAttrss.add(osBtmTypeAttributeVO);
            }
         }
      }
      // 按照id升序排序
      boAttrss = boAttrss.stream().sorted(Comparator.comparing(BtmTypeAttributeVO::getId)).collect(Collectors.toList());
      dataGrid.setData(boAttrss);
      dataGrid.setTotal(boAttrss.size());
      return dataGrid;
@@ -793,8 +765,8 @@
    * @return
    */
   @Override
   public DataGrid<CodeOsbtmtypeattributeVO> codeClassifyTemplateAttrByBtmHave(BaseQueryObject baseQueryObject){
      DataGrid<CodeOsbtmtypeattributeVO> dataGrid=new DataGrid<CodeOsbtmtypeattributeVO>();
   public DataGrid<BtmTypeAttributeVO> codeClassifyTemplateAttrByBtmHave(BaseQueryObject baseQueryObject){
      DataGrid<BtmTypeAttributeVO> dataGrid=new DataGrid<BtmTypeAttributeVO>();
      //模板oid
      String templateAttrOid = baseQueryObject.getConditionMap().get("oid");
@@ -809,20 +781,13 @@
      CodeClassifyTemplate codeClassifyTemplateDO = codeClassifyTemplateMapper.selectById(templateAttrOid);
      //这个业务类型下的所有属性
      List<CodeOsbtmtypeattributeVO> boAttrs = (List<CodeOsbtmtypeattributeVO>) codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId());//this.btmService.listAttributeByBtmIdHasDefault(codeClassifyTemplateDO.getBtmTypeId());
//      codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId());
//      BeanUtils.copyProperties(codeOsbtmtypeattributeMapper.selectById(codeClassifyTemplateDO.getBtmTypeId()),boAttrs);
      // TODO 已完善
      List<BtmTypeAttributeVO> boAttrs =  (List<BtmTypeAttributeVO>) btmTypeClient.getAllAttributeByBtmId(codeClassifyTemplateDO.getBtmTypeId());
      //这个模板下已经有的属性
      //把默认的属性也添加到boAttrs
      if(boAttrs == null){
         boAttrs = new ArrayList<>();
      }
//      VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(CodeClassifyTemplateAttrDO.class);
//      queryWrapper.addQueryMap("CLASSIFYTEMPLATEOID",templateAttrOid);
//      Map<String,Object> condition = new HashMap<>(1);
//      condition.put("CLASSIFYTEMPLATEOID",templateAttrOid);
      QueryWrapper<CodeClassifyTemplateAttr> wrapper=new QueryWrapper<>();
      wrapper.eq("CLASSIFYTEMPLATEOID",templateAttrOid);
@@ -833,9 +798,9 @@
      }
      //过滤掉除了自身的别的属性
      List<CodeOsbtmtypeattributeVO> boAttrss = new ArrayList<CodeOsbtmtypeattributeVO>();
      List<BtmTypeAttributeVO> boAttrss = new ArrayList<BtmTypeAttributeVO>();
      for (CodeOsbtmtypeattributeVO osBtmTypeAttributeVO:boAttrs){
      for (BtmTypeAttributeVO osBtmTypeAttributeVO:boAttrs){
         if(btmOids.contains(osBtmTypeAttributeVO.getId())){
            boAttrss.add(osBtmTypeAttributeVO);
         }