From 391eec3114a17e68652434c6eae610799d80290e Mon Sep 17 00:00:00 2001
From: ludc <ludc@vci-tech.com>
Date: 星期四, 16 一月 2025 11:13:43 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsPortalVIServiceImpl.java |  173 ++++++++++++++++++++++++++++++++-------------------------
 1 files changed, 97 insertions(+), 76 deletions(-)

diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsPortalVIServiceImpl.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsPortalVIServiceImpl.java
index 36e1356..df39636 100644
--- a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsPortalVIServiceImpl.java
+++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsPortalVIServiceImpl.java
@@ -11,7 +11,9 @@
 import com.vci.corba.portal.PortalService.GetPagePortalVIArrayByPageInfoResult;
 import com.vci.corba.portal.data.PortalVI;
 import com.vci.dto.*;
-import com.vci.model.*;
+import com.vci.enumpck.UI.ItemTypeEnum;
+import com.vci.model.PRMDO;
+import com.vci.model.PRMItemDO;
 import com.vci.pagemodel.*;
 import com.vci.po.PortalVIPO;
 import com.vci.po.QTDPO;
@@ -25,17 +27,14 @@
 import com.vci.starter.web.pagemodel.DataGrid;
 import com.vci.starter.web.util.LocalFileUtil;
 import com.vci.starter.web.util.VciBaseUtil;
-import com.vci.starter.word.bo.WordMergeStartTableDataBO;
-import com.vci.starter.word.util.WordUtil;
-import com.vci.web.enumpck.ItemTypeEnum;
 import com.vci.web.enumpck.PortalVIType;
 import com.vci.web.enumpck.PortalVITypeFlag;
-import com.vci.web.other.BtmQTExportData;
 import com.vci.web.service.OsAttributeServiceI;
 import com.vci.web.service.OsPortalVIServiceI;
 import com.vci.web.service.OsQuereyTemplateServiceI;
 import com.vci.web.util.PlatformClientUtil;
 import com.vci.web.util.UITools;
+import com.vci.web.util.WebUtil;
 import org.apache.commons.io.IOUtils;
 import org.apache.commons.lang3.StringUtils;
 import org.slf4j.Logger;
@@ -44,16 +43,17 @@
 import org.springframework.context.annotation.Lazy;
 import org.springframework.stereotype.Service;
 import org.springframework.util.CollectionUtils;
-import org.springframework.web.multipart.MultipartFile;
 
-import java.io.*;
+import java.io.File;
+import java.io.FileInputStream;
+import java.io.FileOutputStream;
+import java.io.IOException;
 import java.util.*;
-import java.util.concurrent.atomic.AtomicInteger;
 import java.util.function.Function;
 import java.util.stream.Collectors;
 
 /*
-  * 閾炬帴绫诲瀷鏈嶅姟
+ * 琛ㄥ崟/琛ㄦ牸鏈嶅姟
  * @author xiej
  * @date 2024-08-14
 */
@@ -125,10 +125,10 @@
         }
         DataGrid<PortalVIVO> dataGrid = new DataGrid<>();
         try {
-            GetPagePortalVIArrayByPageInfoResult pagePortalVIArrayByPageInfoResult= platformClientUtil.getPortalService().getPagePortalVIArrayByPageInfo(typeName,viName,viType,viTypeFlag,pageIndex,pageSize);
+            GetPagePortalVIArrayByPageInfoResult pagePortalVIArrayByPageInfoResult = platformClientUtil.getPortalService().getPagePortalVIArrayByPageInfo(typeName,viName,viType,viTypeFlag,pageIndex,pageSize);
             if(pagePortalVIArrayByPageInfoResult.total>0) {
                 PortalVI[] portalVIS = pagePortalVIArrayByPageInfoResult.returnValue;
-                List<PortalVIVO> portalVIVOS=  portalVIDOO2VOS(Arrays.asList(portalVIS));
+                List<PortalVIVO> portalVIVOS = portalVIDOO2VOS(Arrays.asList(portalVIS));
                 dataGrid.setData(portalVIVOS);
                 dataGrid.setTotal(pagePortalVIArrayByPageInfoResult.total);
             }else{
@@ -149,7 +149,7 @@
      */
     @Override
     public BaseResult addSave(PortalVIDTO portalVIDTO) throws VciBaseException {
-        return  savePortalVIDTO(portalVIDTO,false);
+        return savePortalVIDTO(portalVIDTO,false);
     }
 
     /**
@@ -166,12 +166,12 @@
         if(PortalVIType.Table.getName()==viType){
             lableName=PortalVIType.Table.getLabel();
         }
-        PortalVIVO portalVIVO=new PortalVIVO();
-        PortalVI portalVI=  platformClientUtil.getPortalService().getPortalVIById(id);
+        PortalVIVO portalVIVO = null;
+        PortalVI portalVI = platformClientUtil.getPortalService().getPortalVIById(id);
         if(portalVI==null||StringUtils.isBlank(portalVI.id)){
             throw new VciBaseException("鏍规嵁涓婚敭鏈煡璇㈠埌鏁版嵁");
         }
-        portalVIVO=portalVIDOO2VO(portalVI);
+        portalVIVO = portalVIDOO2VO(portalVI);
         return portalVIVO;
     }
 
@@ -211,7 +211,13 @@
                 if (formFlag) {
                     throw new Throwable(viewName + "鏁版嵁宸茬粡琚玌I缁勪欢寮曠敤锛岃閲嶆柊閫夋嫨瑕佸垹闄ょ殑瀵硅薄!");
                 }
-                UITools.getService().deletePortalVIByID(id);
+                PortalVI portalVI = new PortalVI();
+                portalVI.id = portalVIDTO.getId();
+                portalVI.viName = portalVIDTO.getViName();
+                portalVI.viType = portalVIDTO.getViType();
+                portalVI.typeName = portalVIDTO.getTypeName();
+                portalVI.typeFlag = portalVIDTO.getTypeFlag();
+                platformClientUtil.getPortalService().deletePortalVI(portalVI);
             }
         }catch (Throwable e){
             String exceptionMessage = "鍒犻櫎琛ㄥ崟鏃跺嚭鐜伴敊璇紝鍘熷洜锛�" + VciBaseUtil.getExceptionMessage(e);
@@ -224,20 +230,26 @@
     @Override
     public boolean delete(String ids) throws PLException {
         VciBaseUtil.alertNotNull(ids,"涓婚敭");
-         List<String> idsList=  VciBaseUtil.str2List(ids);
-        List<PortalVI> PortalVIList= new ArrayList<>();
-        DeletePortalVIDTOList portalVIDTOList=new DeletePortalVIDTOList();
+        List<String> idsList =  VciBaseUtil.str2List(ids);
+        List<PortalVIDTO> portalVIDTOList = new ArrayList<>();
+        DeletePortalVIDTOList deletePortalVIDTOList=new DeletePortalVIDTOList();
         idsList.stream().forEach(id->{
             PortalVI portalVI= null;
             try {
                 portalVI = platformClientUtil.getPortalService().getPortalVIById(id);
-                PortalVIList.add(portalVI);
+                PortalVIDTO portalVIDTO = new PortalVIDTO();
+                portalVIDTO.setId(portalVI.id);
+                portalVIDTO.setTypeFlag(portalVI.typeFlag);
+                portalVIDTO.setTypeName(portalVI.typeName);
+                portalVIDTO.setViName(portalVI.viName);
+                portalVIDTO.setViType(portalVI.viType);
+                portalVIDTOList.add(portalVIDTO);
             } catch (PLException e) {
                 e.printStackTrace();
             }
         });
-        portalVIDTOList.setPortalVIDTOList(portalVIO2DTOS(PortalVIList));
-        return delete(portalVIDTOList);
+        deletePortalVIDTOList.setPortalVIDTOList(portalVIDTOList);
+        return delete(deletePortalVIDTOList);
     }
 
     /**
@@ -248,7 +260,7 @@
      */
     @Override
     public boolean clone(ClonePortalVIDTOList clonePortalVIDTOList) throws VciBaseException {
-        if(clonePortalVIDTOList==null||CollectionUtils.isEmpty(clonePortalVIDTOList.getClonePortalVIDTOList())){
+        if(clonePortalVIDTOList == null || CollectionUtils.isEmpty(clonePortalVIDTOList.getClonePortalVIDTOList())){
             throw  new VciBaseException("璇烽�夋嫨瑕佸厠闅嗙殑瀵硅薄!");
         }
         try {
@@ -573,6 +585,7 @@
         }
         return BaseResult.success("瀵煎叆鎴愬姛");
     }
+
     private String readLines(String filePath){
         StringBuffer sb=new StringBuffer();
         FileInputStream prmFile=null;
@@ -590,6 +603,7 @@
         }
         return sb.toString();
     }
+
     /**
      * 鎷疯礉鏁版嵁鍒皐ord妯℃澘涓�
      * @param fileName 瑕佸啓鍏ョ殑鏁版嵁
@@ -620,6 +634,7 @@
         }
         return filePath;
     }
+
     public List<PortalVIDTO> listByIds(Collection idList){
         List<PortalVIDTO> portalVIVOList=new ArrayList<>();
         if(CollectionUtils.isEmpty(idList)){
@@ -637,42 +652,42 @@
         portalVIVOList=  portalVIO2DTOS(portalVIList);
         return portalVIVOList;
     }
-    private BaseResult savePortalVIDTO(PortalVIDTO portalVIDTO,boolean isEdit)  {
 
+    private BaseResult savePortalVIDTO(PortalVIDTO portalVIDTO,boolean isEdit)  {
         boolean _isBtm=false;
         boolean flag = false;
         String labelName=PortalVIType.Form.getName();
         try {
-            VciBaseUtil.alertNotNull(portalVIDTO.getViName(),"鍚嶇О");
+            VciBaseUtil.alertNotNull(
+                    portalVIDTO.getViName(),"鍚嶇О"
+                    /*,portalVIDTO.getPrm().getFormQtName(),"缁戝畾琛ㄥ崟"*/);
             if(portalVIDTO.getPrm()==null||portalVIDTO.getPrm().getPrmItemList()==null||portalVIDTO.getPrm().getPrmItemList().size()==0){
                 throw  new Throwable(labelName+"锛屾湭璁剧疆");
             }
             if(PortalVIType.Table.getIntVal()==portalVIDTO.getViType()){//濡傛灉鏄〃鏍肩殑鐨勬牎楠�
                 labelName=PortalVIType.Table.getName();
-                PRMItemDTO prmItemDTO=  portalVIDTO.getPrm().getPrmItemList().get(0);
+                PRMItemDTO prmItemDTO = portalVIDTO.getPrm().getPrmItemList().get(0);
                 //姣忛〉鏄剧ず鏍¢獙
                 String rtnContent = isCorrectPageNums(prmItemDTO.getItemPageSize());
                 if (StringUtils.isNotBlank(rtnContent)) {
                    throw new VciBaseException(rtnContent);
                 }
-            }else{
-
             }
             labelName= PortalVIType.getByIntVal(portalVIDTO.getViType()).getLabel();
             if(!_isBtm){
-                PortalVI[] portalVIS=  platformClientUtil.getPortalService().getPortalVIArrayByTypeName(portalVIDTO.getTypeName());
+                PortalVI[] portalVIS = platformClientUtil.getPortalService().getPortalVIArrayByTypeName(portalVIDTO.getTypeName());
                 for (int i = 0; i < portalVIS.length; i++) {
-                    PortalVI portalVI=  portalVIS[i];
-                   String viName= portalVI.viName;
+                    PortalVI portalVI = portalVIS[i];
+                   String viName = portalVI.viName;
                    if(isEdit){//濡傛灉涓轰慨鏀�
                        try {
-                           PortalVI oldPortalVI= platformClientUtil.getPortalService().getPortalVIById(portalVIDTO.getId());
-                           flag=platformClientUtil.getPortalService().judgeUpdateButton(oldPortalVI.typeFlag, oldPortalVI.viName, oldPortalVI.typeName);
+                           PortalVI oldPortalVI = platformClientUtil.getPortalService().getPortalVIById(portalVIDTO.getId());
+                           flag = platformClientUtil.getPortalService().judgeUpdateButton(oldPortalVI.typeFlag, oldPortalVI.viName, oldPortalVI.typeName);
                            if (flag && (StringUtils.isNotBlank(portalVIDTO.getViName()))&&(!oldPortalVI.viName.equals(portalVIDTO.getViName()))) {
                                throw  new Throwable("璇�"+labelName+"宸茬粡琚紩鐢紝涓嶈兘淇敼鍚嶇О!");
                            }
                        } catch (PLException e) {
-                           throw  new Throwable("鏌ヨ鍘熸湁琛ㄥ崟鍑虹幇寮傚父:"+e.getMessage());
+                           throw new Throwable("鏌ヨ鍘熸湁琛ㄥ崟鍑虹幇寮傚父:"+e.getMessage());
                        }
                        if (!portalVI.id.equals(portalVIDTO.getId())) {
                            if (portalVI.viName.equals(portalVIDTO.getViName())) {
@@ -689,7 +704,7 @@
             }else{
                 flag=platformClientUtil.getPortalService().judgeUpdateButton(portalVIDTO.getTypeFlag(), portalVIDTO.getViName(), portalVIDTO.getTypeName());
             }
-            PortalVI pvi=portalVIDTOO2VI(portalVIDTO);
+            PortalVI pvi = portalVIDTOO2VI(portalVIDTO);
             if (!isEdit) {
                 flag= platformClientUtil.getPortalService().savePortalVI(pvi);
             } else {
@@ -708,6 +723,7 @@
         }
         return  BaseResult.success("淇濆瓨"+labelName+"鎴愬姛!");
     }
+
     @Override
     public Map<String, PortalVIVO> selectAllPortalVIMap() throws VciBaseException {
         return null;
@@ -759,7 +775,6 @@
         return "";
     }
 
-
     /**
      * 鏋氫妇鐨勬暟鎹璞¤浆鎹负鏄剧ず瀵硅薄
      *
@@ -775,6 +790,7 @@
         });
         return portalVIVOS;
     }
+
     /**
      * 琛ㄥ崟鐨勬暟鎹璞¤浆鎹负鏄剧ず瀵硅薄
      * @param portalVIDTOS 琛ㄥ崟鐨勫璞�
@@ -789,6 +805,7 @@
         });
         return portalVIS;
     }
+
     /**
      * 琛ㄥ崟鐨勬暟鎹璞¤浆鎹负鏄剧ず瀵硅薄
      * @param PortalVIS 琛ㄥ崟鐨勫璞�
@@ -796,7 +813,7 @@
      */
     @Override
     public List<PortalVIDTO> portalVIO2DTOS(Collection<PortalVI> PortalVIS) {
-        List<PortalVIDTO>PortalVIDTOS  = new ArrayList<>();
+        List<PortalVIDTO> PortalVIDTOS = new ArrayList<>();
         Optional.ofNullable(PortalVIS).orElseGet(()->new ArrayList<>()).stream().forEach(PortalVI -> {
             PortalVIDTO PPortalVIDTO = portalVIO2DTO(PortalVI);
             PortalVIDTOS.add(PPortalVIDTO);
@@ -804,22 +821,20 @@
         return PortalVIDTOS;
     }
 
-
-
     /**
      * 琛ㄥ崟鐨勬暟鎹璞¤浆鎹负鏄剧ず瀵硅薄
      * @param portalVIDTO
      * @return
      */
     @Override
-    public  PortalVI portalVIDTOO2VI(PortalVIDTO portalVIDTO) {
-        PortalVI portalVI=new PortalVI();
-        portalVI.id=portalVIDTO.getId();
-        portalVI.typeFlag= portalVIDTO.getTypeFlag();
-        portalVI.typeName=portalVIDTO.getTypeName();
-        portalVI.viName=portalVIDTO.getViName();
-        portalVI.viType=portalVIDTO.getViType();
-        short viType =portalVIDTO.getViType();
+    public PortalVI portalVIDTOO2VI(PortalVIDTO portalVIDTO) {
+        PortalVI portalVI = new PortalVI();
+        portalVI.id = StringUtils.isNotBlank(portalVIDTO.getId()) ? portalVIDTO.getId() : WebUtil.getPk();
+        portalVI.typeFlag = portalVIDTO.getTypeFlag();
+        portalVI.typeName = portalVIDTO.getTypeName();
+        portalVI.viName = portalVIDTO.getViName();
+        portalVI.viType = portalVIDTO.getViType();
+        short viType = portalVIDTO.getViType();
         PRMDO prmdo = prmDOO2VIS(portalVIDTO.getPrm(),viType);
         try {
             portalVI.prm=UITools.getPRMText(prmdo);
@@ -828,6 +843,7 @@
         }
         return portalVI;
     }
+
     /**
      * 琛ㄥ崟鐨勬暟鎹璞¤浆鎹负鏄剧ず瀵硅薄
      * @param portalVI
@@ -846,6 +862,7 @@
         portalVIDTO.setPrm(prmDOO2DTOS(prmdo,viType));
         return portalVIDTO;
     }
+
     /**
      * 琛ㄥ崟鏁版嵁瀵硅薄杞崲
      * @param prmdto
@@ -876,7 +893,7 @@
 
     @Override
     public  PortalVIVO portalVIDOO2VO(PortalVI portalVI) {
-        PortalVIVO portalVIVO=new PortalVIVO();
+        PortalVIVO portalVIVO = new PortalVIVO();
         portalVIVO.setId(portalVI.id);
         portalVIVO.setTypeFlagText(PortalVITypeFlag.getByIntVal(portalVI.typeFlag).getLabel());
         portalVIVO.setTypeFlag(portalVI.typeFlag);
@@ -885,7 +902,7 @@
         portalVIVO.setViType(portalVI.viType);
         portalVIVO.setViTypeText(PortalVIType.getByIntVal(portalVI.viType).getLabel());
 
-        String  prm= portalVI.prm;
+        String prm = portalVI.prm;
         if(StringUtils.isNotBlank(prm)) {
             PRMDO prmdo = UITools.getPRM(prm);
             portalVIVO.setPrm(prmDOO2VOS(prmdo, portalVI.viType));
@@ -957,7 +974,7 @@
         prmItemDO.setItemHrefConf(prmItemDO.getItemHrefConf());//瓒呴摼鎺ラ厤缃�
         prmItemDO.setItemTips(prmItemDTO.getItemTips());
         prmItemDO.setItemTrim(prmItemDTO.getItemTrim());
-        prmItemDO.setItemDateFormat(prmItemDTO.getItemDateFormat());
+        //prmItemDO.setItemDateFormat(prmItemDTO.getItemDateFormat());
         prmItemDO.setItemCtrlDisplyCondition(prmItemDTO.getItemCtrlDisplyCondition());////鎺у埗鏄剧ず鏉′欢
         prmItemDO.setItemEditableProgram(prmItemDTO.getItemEditableProgram());
         prmItemDO.setItemEditCondition(prmItemDTO.getItemEditCondition());
@@ -1166,10 +1183,12 @@
         List<String> allKeyList= getRefFormVIName(prmItemDO.getItemInObj());
         List<String> itemOutFieldList =VciBaseUtil.str2List(prmItemDO.getItemOutFields());
         List<String> itemKeyFieldList =VciBaseUtil.str2List(prmItemDO.getItemKeyFields());
-        List<String> itemSelectoutFieldList= allKeyList.stream().filter(s ->!itemOutFieldList.stream().map(s1 -> s1).collect(Collectors.toList()).contains(s) ).collect(Collectors.toList());
-        prmItemVO.setItemSelectoutFieldList(itemSelectoutFieldList);//寰呴�夋嫨鐨勫睘鎬у瓧娈�
+        List<String> itemSelectOutFieldList= allKeyList.stream()
+                .filter(s -> !itemOutFieldList.contains(s))
+                .collect(Collectors.toList());
+        prmItemVO.setItemSelectOutFieldList(itemSelectOutFieldList);//寰呴�夋嫨鐨勫睘鎬у瓧娈�
         prmItemVO.setItemOutFieldList(itemOutFieldList);//闇�瑕佷娇鐢ㄧ殑闆嗗悎
-      //  List<String> itemSearchFieldList= itemOutFieldList.stream().filter(s ->!CollectionUtils.isEmpty(itemKeyFieldList).stream().map(s1 -> s1).collect(Collectors.toList()).contains(s) ).collect(Collectors.toList());
+        // List<String> itemSearchFieldList= itemOutFieldList.stream().filter(s ->!CollectionUtils.isEmpty(itemKeyFieldList).stream().map(s1 -> s1).collect(Collectors.toList()).contains(s) ).collect(Collectors.toList());
         List<String> itemSearchFieldList=new ArrayList<>();
         if(!CollectionUtils.isEmpty(itemKeyFieldList)){
             itemSearchFieldList= itemOutFieldList.stream().filter(s ->!itemKeyFieldList.contains(s)).collect(Collectors.toList());
@@ -1190,8 +1209,8 @@
         List<String> allKeyList= getRefFormVIName(prmItemDO.getItemInObj());
         List<String> itemOutFieldList =VciBaseUtil.str2List(prmItemDO.getItemOutFields());
         List<String> itemKeyFieldList =VciBaseUtil.str2List(prmItemDO.getItemKeyFields());
-        List<String> itemSelectoutFieldList= allKeyList.stream().filter(s ->!itemOutFieldList.stream().map(s1 -> s1).collect(Collectors.toList()).contains(s) ).collect(Collectors.toList());
-        prmItemDTO.setItemSelectoutFieldList(itemSelectoutFieldList);//寰呴�夋嫨鐨勫睘鎬у瓧娈�
+        List<String> itemSelectOutFieldList= allKeyList.stream().filter(s ->!itemOutFieldList.stream().map(s1 -> s1).collect(Collectors.toList()).contains(s) ).collect(Collectors.toList());
+        prmItemDTO.setItemSelectoutFieldList(itemSelectOutFieldList);//寰呴�夋嫨鐨勫睘鎬у瓧娈�
         prmItemDTO.setItemOutFieldList(itemOutFieldList);//闇�瑕佷娇鐢ㄧ殑闆嗗悎
         List<String> itemSearchFieldList=new ArrayList<>();
         if(!CollectionUtils.isEmpty(itemKeyFieldList)){
@@ -1207,28 +1226,29 @@
      * @param prmItemDO
      */
     private void initTableConfigDTOO2DOData(PRMItemDO prmItemDO,PRMItemDTO prmItemDTO){
-
-        prmItemDO.setItemOutFields(VciBaseUtil.array2String(prmItemDTO.getItemOutFieldList().toArray(new String[]{})));//闇�瑕佷娇鐢ㄧ殑瀛楁
-        prmItemDO.setItemKeyFields(CollectionUtils.isEmpty(prmItemDTO.getItemKeyFieldList())?"":VciBaseUtil.array2String(prmItemDTO.getItemKeyFieldList().toArray(new String[]{})));//闇�瑕佹悳绱㈢殑瀛楁
-       List<String> newItemFieldWidthList=prmItemDTO.getItemFieldWidthList().stream().map(KeyValue::getValue).distinct().collect(Collectors.toList());
-       prmItemDO.setItemFieldWidth(VciBaseUtil.array2String(newItemFieldWidthList.toArray(new String[]{}),":"));//瀛楁瀹藉害
-       List<ItemSeniorQueryBO> itemSeniorQueryBOS=  prmItemDTO.getItemSeniorQueryBOS();
-       List<String> itemSeniorQueryColsList=new ArrayList<>();
-       List<String> itemSeniorQueryColsCountsList=new ArrayList<>();
-       List<String> itemQuerySqlList=new ArrayList<>();
-       itemSeniorQueryBOS.stream().forEach(itemSeniorQueryBO -> {
-           String itemSeniorQueryCols= itemSeniorQueryBO.getItemSeniorQueryCols();
-           String itemSeniorQueryColsCounts=itemSeniorQueryBO.getItemSeniorQueryColsCounts();
-           String itemQuerySql=itemSeniorQueryBO.getItemQuerySql();
+        prmItemDO.setItemOutFields(VciBaseUtil.array2String(prmItemDTO.getItemOutFieldList().toArray(new String[]{})));
+        //闇�瑕佷娇鐢ㄧ殑瀛楁prmItemDO.setItemKeyFields(CollectionUtils.isEmpty(prmItemDTO.getItemKeyFieldList())?"":VciBaseUtil.array2String(prmItemDTO.getItemKeyFieldList().toArray(new String[]{})));//闇�瑕佹悳绱㈢殑瀛楁
+        // TODO: 2024/12/5 Ludc 杩欏効鍘婚噸鐢ㄧ殑涓嶅锛孠eyValue::getValue鏄瀹藉害鍘婚噸浜�
+        List<String> newItemFieldWidthList = prmItemDTO.getItemFieldWidthList().stream().distinct().map(KeyValue::getValue).collect(Collectors.toList());
+        // TODO: 2024/12/5 Ludc 鍒嗛殧绗﹁鍜屽钩鍙扮粺涓�鐢�,鑰屼笉鏄敤:
+        prmItemDO.setItemFieldWidth(VciBaseUtil.array2String(newItemFieldWidthList.toArray(new String[]{}),","));//瀛楁瀹藉害
+        List<ItemSeniorQueryBO> itemSeniorQueryBOS = prmItemDTO.getItemSeniorQueryBOS();
+        List<String> itemSeniorQueryColsList = new ArrayList<>();
+        List<String> itemSeniorQueryColsCountsList=new ArrayList<>();
+        List<String> itemQuerySqlList = new ArrayList<>();
+        itemSeniorQueryBOS.stream().forEach(itemSeniorQueryBO -> {
+           String itemSeniorQueryCols = itemSeniorQueryBO.getItemSeniorQueryCols();
+           String itemSeniorQueryColsCounts = itemSeniorQueryBO.getItemSeniorQueryColsCounts();
+           String itemQuerySql = itemSeniorQueryBO.getItemQuerySql();
            if(StringUtils.isNotBlank(itemSeniorQueryCols)) {
                itemSeniorQueryColsList.add(itemSeniorQueryCols);
            }
-            if(StringUtils.isNotBlank(itemSeniorQueryColsCounts)) {
-                itemSeniorQueryColsCountsList.add(itemSeniorQueryColsCounts);
-            }
-            if(StringUtils.isNotBlank(itemQuerySql)){
-                itemQuerySqlList.add(itemQuerySql);
-            }
+           if(StringUtils.isNotBlank(itemSeniorQueryColsCounts)) {
+               itemSeniorQueryColsCountsList.add(itemSeniorQueryColsCounts);
+           }
+           if(StringUtils.isNotBlank(itemQuerySql)){
+               itemQuerySqlList.add(itemQuerySql);
+           }
         });
         prmItemDO.setItemSeniorQueryCols(VciBaseUtil.array2String(itemSeniorQueryColsList.toArray(new String[]{})));
         prmItemDO.setItemSeniorQueryColsCounts(VciBaseUtil.array2String(itemSeniorQueryColsCountsList.toArray(new String[]{})));
@@ -1241,8 +1261,8 @@
      */
     private List<KeyValue>  initItemFieldWidthList(String itemOutFields,String itemFieldWidth){
         List<KeyValue> keyValueList=new ArrayList<>();
-        List<String>itemOutFieldList=   VciBaseUtil.str2List(itemOutFields);
-        List<String>itemFieldWidthList=  VciBaseUtil.str2List(itemFieldWidth,",");
+        List<String>itemOutFieldList = VciBaseUtil.str2List(itemOutFields);
+        List<String>itemFieldWidthList =VciBaseUtil.str2List(itemFieldWidth,",");
         if(itemOutFieldList.size()>0) {
             for (int i = 0; i < itemOutFieldList.size(); i++) {
                 KeyValue keyValue = new KeyValue();
@@ -1290,6 +1310,7 @@
         }
         return itemSeniorQueryBOList;
     }
+
     private List<String> getRefFormVIName(String refFormOid){
         List<String> keyList=new ArrayList<>();
         try {

--
Gitblit v1.9.3