ludc
2023-06-28 f86cdf1a67342fb7aa78384702f4509f7f8988b0
Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeRuleServiceImpl.java
@@ -492,60 +492,11 @@
         vo.setLcStatusText(CodeRuleLC.getTextByValue(vo.getLcStatus()));
         if (hasSec) {
            List<CodeBasicSecVO> codeBasicSecVOS = codeBasicSecService.listCodeBasicSecByRuleOid(vo.getOid());
            // 判断是否为引用码段,如果是应用码段的话,为了适配前端组件,这里要对表进行处理一下,按照以前的参照格式进行转换
            codeBasicSecVOS.stream().peek(item->{
               //引用码段
               if(item.getSecType().equals(CodeSecTypeEnum.CODE_REFER_SEC) && StringUtils.isNotEmpty(item.getReferConfig())){
                  item.setReferConfig(referConfigTOUIUiTable(item));
               }
            });
            //查询码段
            vo.setSecVOList(codeBasicSecVOS);
         }
      }
      return vo;
   }
   /**
    * 将referconfig转换为JSON格式的UIFormReferVO
    * @param item
    * @return
    */
   private String referConfigTOUIUiTable(CodeBasicSecVO item){
      // JSON格式的参照配置转换为对象
      CodeReferConfig codeReferConfig = JSONObject.parseObject(item.getReferConfig(), CodeReferConfig.class);
      // 拷贝为以前的老对象
      UIFormReferVO uiFormReferVO = new UIFormReferVO();
      BeanUtil.copy(codeReferConfig,uiFormReferVO);
      // 表格的自定义定义
      UITableCustomDefineVO uiTableCustomDefineVO = new UITableCustomDefineVO();
      uiTableCustomDefineVO.setPage(new UITablePageVO(codeReferConfig.getLimit(),1));
      // 列表的列的信息转换
      List<UITableFieldVO> uiTableFieldVOs = new ArrayList<>();
      // 快速查询列
      List<UITableFieldVO> queryColumns = new ArrayList<>();
      codeReferConfig.getCodeShowFieldConfigs().stream().forEach(showField ->{
         UITableFieldVO uiTableFieldVO = new UITableFieldVO();
         BeanUtil.copy(showField,uiTableFieldVO);
         uiTableFieldVOs.add(uiTableFieldVO);
         if(showField.getIsQuery().equals("true")){
            queryColumns.add(uiTableFieldVO);
         }
      });
      // 显示的列
      uiTableCustomDefineVO.setCols(uiTableFieldVOs);
      // 快速查询列
      uiTableCustomDefineVO.setQueryColumns(queryColumns);
      // 筛选条件
      HashMap<String, String> whereMap = new HashMap<>();
      codeReferConfig.getCodeSrchCondConfigs().stream().forEach(srch->{
         whereMap.put(srch.getFilterValue()+"_"+srch.getFilterType(),srch.getFilterValue());
      });
      uiFormReferVO.setWhere(whereMap);
      return JSONObject.toJSONString(uiFormReferVO);
   }
}