From aed7f0e9be4e88a4ed632f9ca7aca05fa1e7f6b8 Mon Sep 17 00:00:00 2001 From: ludc Date: 星期四, 12 九月 2024 17:44:21 +0800 Subject: [PATCH] UI上下文导出树查询和导出接口 --- Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java | 442 +++++++++++++++++++++++++++++++++++++++++------------- 1 files changed, 335 insertions(+), 107 deletions(-) diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java index 7cff12c..d85f3ef 100644 --- a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java +++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java @@ -1,5 +1,6 @@ package com.vci.web.service.impl; +import com.alibaba.fastjson.JSON; import com.vci.common.utility.ObjectUtility; import com.vci.corba.common.PLException; import com.vci.corba.framework.data.RoleRightInfo; @@ -9,22 +10,21 @@ import com.vci.dto.RoleRightDTO; import com.vci.dto.UIAuthorDTO; import com.vci.model.PLDefination; -import com.vci.pagemodel.PLDefinationVO; -import com.vci.pagemodel.PLTabButtonVO; -import com.vci.pagemodel.PLUILayoutCloneVO; -import com.vci.pagemodel.RoleRightVO; +import com.vci.pagemodel.*; +import com.vci.starter.poi.bo.WriteExcelData; +import com.vci.starter.poi.bo.WriteExcelOption; +import com.vci.starter.poi.util.ExcelUtil; import com.vci.starter.web.exception.VciBaseException; import com.vci.starter.web.pagemodel.*; import com.vci.starter.web.pagemodel.BaseQueryObject; import com.vci.starter.web.pagemodel.BaseResult; import com.vci.starter.web.pagemodel.DataGrid; import com.vci.starter.web.pagemodel.SessionInfo; -import com.vci.starter.web.util.VciBaseUtil; -import com.vci.starter.web.util.VciDateUtil; -import com.vci.starter.web.util.WebThreadLocalUtil; +import com.vci.starter.web.util.*; import com.vci.web.service.OsBtmServiceI; import com.vci.web.service.UIManagerServiceI; import com.vci.web.util.*; +import com.vci.web.util.BeanUtil; import org.apache.commons.lang3.StringUtils; import com.vci.web.util.Func; import com.vci.web.util.PlatformClientUtil; @@ -37,10 +37,9 @@ import org.springframework.stereotype.Service; import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; -import javax.servlet.http.HttpServletResponse; -import javax.swing.*; -import java.io.IOException; +import java.io.File; import java.util.*; +import java.util.concurrent.atomic.AtomicInteger; import java.util.stream.Collectors; import java.util.regex.Pattern; @@ -58,16 +57,12 @@ @Resource private PlatformClientUtil platformClientUtil; - /** - * 瑙掕壊 - */ - @Resource - private SmRoleQueryServiceI smRoleQueryServiceI; /*** * 鏄惁鏄鐞嗗憳 */ @Autowired RightControlUtil rightControlUtil; + /** * 涓氬姟绫诲瀷 */ @@ -318,13 +313,133 @@ } /** + * 鏍规嵁鍕鹃�夌殑鏉′欢鑾峰彇闇�瑕佸鍑虹殑ui涓婁笅鏂囨爲 + * @param expDatas + * @return + */ + @Override + public Tree getExpContextTree(List<String> expDatas) { + VciBaseUtil.alertNotNull(expDatas,"瀵煎嚭鏌ヨ鍒楄〃"); + Tree tree = new Tree(); + String newObjectID36 = ObjectUtility.getNewObjectID36(); + tree.setOid(newObjectID36); + tree.setText("鍖哄煙"); + tree.setLevel(0); + List<Tree> treeList = new ArrayList<>(); + expDatas.stream().forEach(oid->{ + try { + PLUILayout pluiLayout = platformClientUtil.getUIService().getPLUILayoutById(oid); + if(Func.isNotEmpty(pluiLayout) && Func.isNotBlank(pluiLayout.plOId)){ + Tree tree1 = new Tree(); + tree1.setText(pluiLayout.plName); + tree1.setOid(pluiLayout.plOId); + tree1.setLevel(1); + tree1.setParentId(newObjectID36); + //鏌ヨ + PLTabPage[] plTabPages = platformClientUtil.getUIService().getPLTabPagesByPageDefinationOId(pluiLayout.plOId); + List<Tree> treeChildrens = new ArrayList<>(); + Arrays.stream(plTabPages).forEach(item->{ + Tree tree2 = new Tree(); + tree2.setLeaf(true); + tree2.setOid(item.plOId); + tree2.setText(item.plName); + tree2.setLevel(2); + tree2.setParentId(item.plContextOId); + treeChildrens.add(tree2); + }); + tree1.setChildren(treeChildrens); + treeList.add(tree1); + } + } catch (PLException e) { + e.printStackTrace(); + } + }); + + tree.setChildren(treeList); + return tree; + } + + /** * 瀵煎嚭ui涓婁笅鏂�(鍕鹃�夌殑瑕佸鍑虹殑鎺у埗鍖虹殑鏁版嵁) * oids * @return */ @Override - public void expUIContextData(String[] oids, HttpServletResponse response) throws PLException, IOException { + public String expUIContextData(Map<String,String> expConditionMap) throws PLException { + if(Func.isEmpty(expConditionMap)){ + throw new PLException("500",new String[]{"璇峰嬀閫夎瀵煎嚭鐨刄I涓婁笅鏂囨暟鎹�!"}); + } + //鐣岄潰娌′紶鍚嶇О锛屼娇鐢ㄩ粯璁ゅ鍑哄悕绉� + String exportFileName = "UI涓婁笅鏂囧鍑篲" + Func.format(new Date(),"yyyy-MM-dd HHmmss.sss"); + //璁剧疆鍒楀悕 + List<String> columns = Arrays.asList( + "鎵�灞炰笟鍔$被鍨�","鍚嶇О", "UI涓婁笅鏂�", "瀵艰埅鍖�", "鎺у埗鍖�","鎿嶄綔鍖�", + "椤电搴忓彿","鍖哄煙缂栫爜","鍖哄煙鍚嶇О","鏄惁鍚敤","鏄剧ず琛ㄨ揪寮�", "UI瑙f瀽绫�", + "鎵╁睍灞炴��", "鎻忚堪","椤甸潰璁捐淇℃伅","椤甸潰涓嬮厤缃殑鎸夐挳" + ); + //鍐檈xcel + String excelPath = LocalFileUtil.getDefaultTempFolder() + File.separator + exportFileName + ".xls"; + try { + new File(excelPath).createNewFile(); + } catch (Throwable e) { + throw new VciBaseException(LangBaseUtil.getErrorMsg(e), new String[]{excelPath}, e); + } + //璁剧疆鍒� + List<WriteExcelData> excelDataList = new ArrayList<>(); + //璁剧疆鍒楀ご + for (int index = 0; index < columns.size(); index++) { + excelDataList.add(new WriteExcelData(0,index, columns.get(index))); + } + AtomicInteger row = new AtomicInteger(1); + expConditionMap.entrySet().stream().forEach(item->{ + //key瀛樻斁鐨剈i涓婁笅鏂囩殑id + try { + PLUILayout pluiLayout = platformClientUtil.getUIService().getPLUILayoutById(item.getKey()); + //value涓瓨鏀剧殑澶氫釜浠ラ�楀彿闂撮殧鐨勯〉绛緄d,閫氳繃杩欎釜id鏌ヨ鍑哄叾涓嬬殑椤甸潰璁捐鍜屾寜閽厤缃� + List<String> plTabPageOIds = Arrays.asList(item.getValue().split(",")); + if(Func.isNotEmpty(pluiLayout) && Func.isNotBlank(pluiLayout.plOId) && Func.isNotEmpty(plTabPageOIds)){ + PLTabPage[] plTabPages = platformClientUtil.getUIService().getPLTabPagesByPageDefinationOId(pluiLayout.plOId); + List<PLTabPage> filterTabPages = Arrays.stream(plTabPages).filter(plTabPage -> plTabPageOIds.contains(plTabPage.plOId)).collect(Collectors.toList()); + filterTabPages.stream().forEach(tabPage->{ + excelDataList.add(new WriteExcelData(row.get(),0, pluiLayout.plRelatedType)); + excelDataList.add(new WriteExcelData(row.get(),1, pluiLayout.plName)); + excelDataList.add(new WriteExcelData(row.get(),2, pluiLayout.plCode)); + excelDataList.add(new WriteExcelData(row.get(),3, pluiLayout.plIsShowForm)); + excelDataList.add(new WriteExcelData(row.get(),4, pluiLayout.plIsShowNavigator)); + excelDataList.add(new WriteExcelData(row.get(),5, pluiLayout.plIsShowTab)); + excelDataList.add(new WriteExcelData(row.get(),6, tabPage.plSeq)); + excelDataList.add(new WriteExcelData(row.get(),7, tabPage.plLabel)); + excelDataList.add(new WriteExcelData(row.get(),8, tabPage.plName)); + excelDataList.add(new WriteExcelData(row.get(),9, tabPage.plIsOpen)); + excelDataList.add(new WriteExcelData(row.get(),10, tabPage.plOpenExpression)); + excelDataList.add(new WriteExcelData(row.get(),11, tabPage.plUIParser)); + excelDataList.add(new WriteExcelData(row.get(),12, tabPage.plExtAttr)); + excelDataList.add(new WriteExcelData(row.get(),13, tabPage.plDesc)); + try { + PLPageDefination[] plPageDefinations = platformClientUtil.getUIService().getPLPageDefinationsByPageContextOId(tabPage.plOId); + if(Func.isNotEmpty(plPageDefinations)){ + excelDataList.add(new WriteExcelData(row.get(),14, JSON.toJSONString(plPageDefinations))); + List<PLTabButtonVO> tabButtonsTotal = new ArrayList<>(); + Arrays.stream(plPageDefinations).forEach(plPageDefination->{ + List<PLTabButtonVO> tabButtons = this.getTabButtons(plPageDefination.plOId); + tabButtonsTotal.addAll(tabButtons); + }); + excelDataList.add(new WriteExcelData(row.get(),15, JSON.toJSONString(tabButtonsTotal))); + } + } catch (PLException e) { + e.printStackTrace(); + } + row.getAndIncrement(); + }); + } + } catch (PLException e) { + e.printStackTrace(); + } + }); + WriteExcelOption excelOption = new WriteExcelOption(excelDataList); + ExcelUtil.writeDataToFile(excelPath, excelOption); + return excelPath; } /** @@ -334,6 +449,10 @@ */ @Override public BaseResult impUIContextData(MultipartFile file) { + + + + return null; } @@ -441,6 +560,13 @@ PLDefinationVO plDefinationVO = new PLDefinationVO(); PLDefination plDefination = UITools.getPLDefination(item.plDefination); BeanUtil.copy(plDefination,plDefinationVO); + plDefinationVO.setDescription(item.desc); + plDefinationVO.setSeq(String.valueOf(item.seq)); + plDefinationVO.setTabPageOId(item.plTabPageOId); + plDefinationVO.setId(item.plOId); + plDefinationVO.setName(item.name); + plDefinationVO.setType(item.plType); + plDefinationVO.setTemplateType(String.valueOf(plDefination.getTemplateType())); plDefinationVOList.add(plDefinationVO); } catch (Throwable e) { e.printStackTrace(); @@ -465,14 +591,14 @@ pd.plTabPageOId = pdVO.getTabPageOId(); pd.plOId = ObjectUtility.getNewObjectID36(); //涓嶈兘涓虹┖灞炴�ф鏌� - if(!this.baseInfoIsOk(pd,false)){ + /*if(!this.baseInfoIsOk(pd,false)){ return false; - } + }*/ pd.name = pdVO.getName().trim(); pd.seq = Short.valueOf(pdVO.getSeq().trim()); pd.desc = pdVO.getDescription(); - pd.plType = Short.parseShort(pdVO.getTemplateType()); + pd.plType = (short) pdVO.getType(); d.setName(pdVO.getName().trim()); d.setUiParser(pdVO.getUiParser().trim()); @@ -483,15 +609,15 @@ newPLDefinationIsOk(pdVO, false); // 妫�鏌ュ悇涓被鍨嬩笅鐨勬暟鎹槸鍚﹁緭鍏ユ垨鏈夋晥,涓�鍏�6绉嶇被鍨嬫寜绫诲瀷妫�楠� - short plType = pd.plType; - switch (plType){ + String templateType = pdVO.getTemplateType(); + switch (templateType){ //Table(琛ㄦ牸) - case 1: + case "1": //From(琛ㄥ崟) - case 4: + case "4": TableComptCheckInput tci = new TableComptCheckInput( pdVO.getSearchTarger() - ,pdVO.getBtmType() + ,pdVO.getShowType() ,pdVO.getLinkType() ,pdVO.getTemplateId() ,pdVO.getQueryTemplateName() @@ -502,7 +628,7 @@ d = tci.getNewPLDefination(d); break; //Custom(鑷畾涔夋ā鏉�) - case 2: + case "2": //鍙鏌ユ帶鍒惰矾寰勪笉鑳戒负绌�,鏈夐棶棰樹細鐩存帴鎶ラ敊 CustomComptCheckInput ccci = new CustomComptCheckInput(pdVO.getControlPath()); if(!ccci.checkInputIsOk()){ @@ -511,10 +637,10 @@ d = ccci.getNewPLDefination(d); break; //TreeTable(鏍戣〃) - case 3: + case "3": TreeTableComptCheckInput ttcci = new TreeTableComptCheckInput( pdVO.getSearchTarger() - ,pdVO.getBtmType() + ,pdVO.getShowType() ,pdVO.getLinkType() ,pdVO.getTemplateId() ,pdVO.getQueryTemplateName() @@ -527,9 +653,9 @@ d = ttcci.getNewPLDefination(d); break; //Tree(鏍�) - case 5: + case "5": TreeComptCheckInput tcci = new TreeComptCheckInput( - pdVO.getBtmType(), + pdVO.getShowType(), pdVO.getLinkType(), pdVO.getQueryTemplateName(), pdVO.getShowExpressionRoot(), @@ -544,10 +670,10 @@ d = tcci.getNewPLDefination(d); break; //UILayout(UI瀹氫箟) - case 6: + case "6": UILayoutComptCheckInput ulci = new UILayoutComptCheckInput( pdVO.getSearchTarger(), - pdVO.getBtmType(), + pdVO.getShowType(), pdVO.getUiLayout(), pdVO.getQueryTemplateName(), pdVO.getQryType() @@ -581,14 +707,17 @@ BeanUtil.copy(pdVO,d); //涓嶈兘涓虹┖灞炴�ф鏌� - if(!this.baseInfoIsOk(pd,true)){ + /*if(!this.baseInfoIsOk(pd,true)){ return false; - } + }*/ + pd.plOId = pdVO.getId(); + pd.plTabPageOId = pdVO.getTabPageOId(); pd.name = pdVO.getName().trim(); pd.seq = Short.valueOf(pdVO.getSeq().trim()); pd.desc = pdVO.getDescription(); - pd.plType = Short.parseShort(pdVO.getTemplateType()); + pd.plType = (short) pdVO.getType(); + d.setId(pdVO.getId()); d.setName(pdVO.getName().trim()); d.setUiParser(pdVO.getUiParser().trim()); d.setExtAttr(pdVO.getExtAttr().trim()); @@ -597,15 +726,15 @@ this.newPLDefinationIsOk(pdVO, true); // 妫�鏌ュ悇涓粍浠跺唴閮ㄧ殑鏁版嵁鏄惁鏈夋晥 - int plType = pdVO.getType(); - switch (plType){ + String templateType = pdVO.getTemplateType(); + switch (templateType){ //Table(琛ㄦ牸) - case 1: + case "1": //From(琛ㄥ崟) - case 4: + case "4": TableComptCheckInput tci = new TableComptCheckInput( pdVO.getSearchTarger() - ,pdVO.getBtmType() + ,pdVO.getShowType() ,pdVO.getLinkType() ,pdVO.getTemplateId() ,pdVO.getQueryTemplateName() @@ -616,7 +745,7 @@ d = tci.getNewPLDefination(d); break; //Custom(鑷畾涔夋ā鏉�) - case 2: + case "2": //鍙鏌ユ帶鍒惰矾寰勪笉鑳戒负绌�,鏈夐棶棰樹細鐩存帴鎶ラ敊 CustomComptCheckInput ccci = new CustomComptCheckInput(pdVO.getControlPath()); if(!ccci.checkInputIsOk()){ @@ -625,10 +754,10 @@ d = ccci.getNewPLDefination(d); break; //TreeTable(鏍戣〃) - case 3: + case "3": TreeTableComptCheckInput ttcci = new TreeTableComptCheckInput( pdVO.getSearchTarger() - ,pdVO.getBtmType() + ,pdVO.getShowType() ,pdVO.getLinkType() ,pdVO.getTemplateId() ,pdVO.getQueryTemplateName() @@ -641,9 +770,9 @@ d = ttcci.getNewPLDefination(d); break; //Tree(鏍�) - case 5: + case "5": TreeComptCheckInput tcci = new TreeComptCheckInput( - pdVO.getBtmType(), + pdVO.getShowType(), pdVO.getLinkType(), pdVO.getQueryTemplateName(), pdVO.getShowExpressionRoot(), @@ -658,10 +787,10 @@ d = tcci.getNewPLDefination(d); break; //UILayout(UI瀹氫箟) - case 6: + case "6": UILayoutComptCheckInput ulci = new UILayoutComptCheckInput( pdVO.getSearchTarger(), - pdVO.getBtmType(), + pdVO.getShowType(), pdVO.getUiLayout(), pdVO.getQueryTemplateName(), pdVO.getQryType() @@ -687,7 +816,7 @@ @Override public boolean delPageDefination(String[] oids) throws PLException { VciBaseUtil.alertNotNull(oids,"鍒犻櫎鐨勯〉闈㈠畾涔変富閿�"); - boolean res = platformClientUtil.getUIService().deletePLUILayoutByOidsForCascade(oids); + boolean res = platformClientUtil.getUIService().deletePLPageDefinationByOidsForCascade(oids); return res; } @@ -697,13 +826,22 @@ * @return */ @Override - public List<PLTabButtonVO> getTabButton(String pageDefinationOid) { + public List<PLTabButtonVO> getTabButtons(String pageDefinationOid) { VciBaseUtil.alertNotNull(pageDefinationOid,"椤甸潰瀹氫箟涓婚敭"); List<PLTabButton> buttonList = new ArrayList<>(); try { PLTabButton[] plTabButtons = platformClientUtil.getUIService().getPLTabButtonsByTableOId(pageDefinationOid); buttonList = Arrays.asList(plTabButtons); - return this.tabButton2TabButtonVOS(buttonList); + List<PLTabButtonVO> plTabButtonVOList = this.tabButton2TabButtonVOS(buttonList); + PLTabButtonVO plTabButtonVO = new PLTabButtonVO(); + for(int i = 0; i < plTabButtonVOList.size(); i++){ + plTabButtonVO = plTabButtonVOList.get(i); + + if(plTabButtonVO.getParentOid().equals("")){ + plTabButtonVO.setChildren(plTabButtonVO2Children(plTabButtonVOList,plTabButtonVO.getOId())); + } + } + return plTabButtonVOList; } catch (Exception e) { e.printStackTrace(); throw new VciBaseException("鍔犺浇椤电鍖哄煙鎸夐挳閰嶇疆淇℃伅寮傚父锛�" + e.getMessage()); @@ -730,7 +868,6 @@ logger.error(errorLog); throw new VciBaseException(errorLog); } - }); return plTabButtonVOList; } @@ -766,10 +903,36 @@ //鍙傛暟淇℃伅鍥炲~ PLCommandParameter[] parameters = platformClientUtil.getUIService().getPLCommandParametersByCommandOId(tabButtonDO.plOId); if(Func.isNotEmpty(parameters)){ - LinkedHashMap<String, String> parameterMap = (LinkedHashMap<String, String>)Arrays.stream(parameters).collect(Collectors.toMap(parm -> parm.plKey, parm -> parm.plValue)); + LinkedHashMap<String, String> parameterMap = Arrays.stream(parameters) + .collect(Collectors.toMap( + parm -> parm.plKey, + parm -> parm.plValue, + (existing, replacement) -> existing, // 澶勭悊閲嶅閿殑鎯呭喌 + LinkedHashMap::new // 鎸囧畾浣跨敤 LinkedHashMap + )); plTabButtonVO.setButtonParams(parameterMap); } return plTabButtonVO; + } + + /** + * 鎸夐挳閰嶇疆瀛愯妭鐐规煡鎵� + * @param plOid + * @param plTabButtonVOList + * @return + */ + private List<PLTabButtonVO> plTabButtonVO2Children(List<PLTabButtonVO> plTabButtonVOList, String plOid){ + ArrayList<PLTabButtonVO> plTabButtonVOS = new ArrayList<>(); + for (PLTabButtonVO plTabButtonVO : plTabButtonVOList) { + if(StringUtils.isBlank(plTabButtonVO.getParentOid())){ + continue; + } + if(plTabButtonVO.getParentOid().equals(plOid)){ + plTabButtonVO.setChildren(plTabButtonVO2Children(plTabButtonVOList,plOid)); + plTabButtonVOS.add(plTabButtonVO); + } + } + return plTabButtonVOS; } /** @@ -876,7 +1039,7 @@ } LinkedHashMap<String, String> buttonParams = tabButtonVO.getButtonParams(); - if(!buttonParams.isEmpty()) { + if(Func.isNotEmpty(buttonParams)) { Iterator<Map.Entry<String, String>> iterator = buttonParams.entrySet().iterator(); while(iterator.hasNext()){ Map.Entry<String, String> next = iterator.next(); @@ -884,30 +1047,92 @@ iterator.remove(); } } - if(!buttonParams.isEmpty()){ - Iterator<Map.Entry<String, String>> kvItor = buttonParams.entrySet().iterator(); - while(kvItor.hasNext()){ - Map.Entry<String, String> next = kvItor.next(); - PLCommandParameter plCommandParameter = new PLCommandParameter(); - plCommandParameter.plOId = ObjectUtility.getNewObjectID36(); - plCommandParameter.plCommandOId = plTabButton.plOId; - plCommandParameter.plKey = next.getKey(); - plCommandParameter.plValue = next.getValue(); - plCommandParameter.plCreateUser = sessionInfo.getUserId(); - plCommandParameter.plModifyUser = sessionInfo.getUserId(); - try { - platformClientUtil.getUIService().savePLCommandParameter(plCommandParameter); - } catch (PLException e) { - e.printStackTrace(); - throw new VciBaseException("淇濆瓨鎸夐挳淇℃伅鏃跺彂鐢熷紓甯革細"+ e.getMessage()); - } + Iterator<Map.Entry<String, String>> kvItor = buttonParams.entrySet().iterator(); + while(kvItor.hasNext()){ + Map.Entry<String, String> next = kvItor.next(); + PLCommandParameter plCommandParameter = new PLCommandParameter(); + plCommandParameter.plOId = ObjectUtility.getNewObjectID36(); + plCommandParameter.plCommandOId = plTabButton.plOId; + plCommandParameter.plKey = next.getKey(); + plCommandParameter.plValue = next.getValue(); + plCommandParameter.plCreateUser = sessionInfo.getUserId(); + plCommandParameter.plModifyUser = sessionInfo.getUserId(); + try { + platformClientUtil.getUIService().savePLCommandParameter(plCommandParameter); + } catch (PLException e) { + e.printStackTrace(); + throw new VciBaseException("淇濆瓨鎸夐挳淇℃伅鏃跺彂鐢熷紓甯革細"+ e.getMessage()); } } } return true; } + /** + * 鍒犻櫎鍗曚釜鎸夐挳閰嶇疆 + * @param tabButtonVO + * @return + */ + @Override + public boolean deleteTapButton(PLTabButtonVO tabButtonVO) throws PLException { + VciBaseUtil.alertNotNull(tabButtonVO,"鍒犻櫎鐨勬寜閽厤缃璞�"); + boolean success = platformClientUtil.getUIService().deletePLTabButton(this.tabButtonVO2TabButton(new PLTabButton(),tabButtonVO)); + if(success == false){ + throw new VciBaseException("璇ユ湁瀛愮骇鎸夐挳锛屼笉鑳藉垹闄わ紒"); + } + return true; + } + /** + * 璋冩暣涓轰笅绾ф寜閽� + * @param tabButtonVO + * @return + */ + @Override + public BaseResult joinBtn(PLTabButtonVO tabButtonVO) throws PLException { + VciBaseUtil.alertNotNull(tabButtonVO,"闇�璋冩暣涓轰笅绾ф寜閽�",tabButtonVO.getTableOId(),"褰撳墠鎸夐挳閰嶇疆鎵�鍦ㄧ殑椤甸潰涓婚敭"); + //鍚屼竴椤甸潰涓嬬殑鎸夐挳 + List<PLTabButtonVO> plTabButtons = this.getTabButtons(tabButtonVO.getTableOId()); + if(Func.isEmpty(plTabButtons)){ + return BaseResult.fail("鏈幏鍙栧埌鎸夐挳閰嶇疆淇℃伅锛�"); + } + //鑾峰彇褰撳墠瑕佺Щ鍔ㄧ殑鎸夐挳鐨勪笅鏍� + int index = 0; + for (int i = 0; i < plTabButtons.size(); i++) { + if (plTabButtons.get(i).getOId().equals(tabButtonVO.getOId())) { + index = i; // 鎵惧埌鍚庤褰曚笅鏍� + break; // 鎵惧埌鍚庨��鍑哄惊鐜� + } + } + //褰撻�夋嫨鐨勬寜閽负鏍戠殑绗竴涓妭鐐圭殑鏃跺�欙紝浠栫殑鍏勮妭鐐规槸浠栬嚜宸憋紝瀵艰嚧璋冩暣涓轰笅绾ф寜閽椂鍑洪敊锛屾晠浣滄鍒ゆ柇銆� + if(index == 0){ + return BaseResult.fail("褰撳墠鑺傜偣涓嶅瓨鍦ㄥ厔鑺傜偣锛屾棤娉曡皟鏁翠负涓嬬骇鎸夐挳锛�"); + } + //璁剧疆鐖秈d涓轰笂涓�涓妭鐐圭殑 + tabButtonVO.setParentOid(plTabButtons.get(index-1).getOId()); + PLTabButton plTabButton = this.tabButtonVO2TabButton(new PLTabButton(), tabButtonVO); + boolean success = platformClientUtil.getUIService().updatePLTabButton(plTabButton); + if(success == false) { + return BaseResult.fail("淇敼澶辫触锛�"); + } + return BaseResult.fail("淇敼鎴愬姛锛�"); + } + + /** + * 璋冩暣涓轰笂绾ф寜閽� + * @param tabButtonVO + * @return + */ + @Override + public BaseResult exitBtn(PLTabButtonVO tabButtonVO) throws PLException { + tabButtonVO.setParentOid(""); + PLTabButton plTabButton = this.tabButtonVO2TabButton(new PLTabButton(), tabButtonVO); + boolean success = platformClientUtil.getUIService().updatePLTabButton(plTabButton); + if(success == false) { + BaseResult.fail("鎾ら攢澶辫触锛�"); + } + return BaseResult.success("鎾ら攢鎴愬姛锛�"); + } /** * 澶勭悊閰嶇疆鐨別vent浜嬩欢 @@ -959,7 +1184,6 @@ * @throws PLException */ private void newPLDefinationIsOk(PLDefinationVO pd, boolean isEdit) throws PLException{ - boolean res = false; boolean nameExist = false; boolean seqExist = false; PLPageDefination[] pds = platformClientUtil.getUIService().getPLPageDefinationsByPageContextOId(pd.getTabPageOId()); @@ -1168,6 +1392,7 @@ } + /** * 鑾峰彇鏉冮檺 * @param isUp 鏄惁鏄悜涓婅幏鍙栵紝濡傛灉鏄悜涓婅幏鍙栵紝浼犺繘鏉ョ殑蹇呯劧鏄ā鍧楄妭鐐癸紝涓斾笂绾фā鍧楀繀鐒舵槸娌℃湁閫変腑 @@ -1281,6 +1506,7 @@ } } + /** * 浼犲叆鐩存帴鎸傛帴鎿嶄綔鐨勬ā鍧楃殑鑺傜偣,璁$畻璇ヨ妭鐐圭殑鏉冮檺鍊� * @param node 妯″潡鑺傜偣 @@ -1313,6 +1539,7 @@ } }); } + private void setChildNode(List<Tree> parentTree, List<PLUILayout>contextList,Map<String,RoleRightVO> roleRightVOMap,boolean isShowCheckBox){ Optional.ofNullable(parentTree).orElseGet(()->new ArrayList<Tree>()).stream().forEach(pTree -> { Object funcObj= pTree.getData(); @@ -1603,13 +1830,14 @@ /** * 闈炵┖妫�鏌� - * @param tip - * @param txt + * @param tip 鎻愮ず淇℃伅 + * @param txt 鏍¢獙鐨勫唴瀹� + * @param isRequired 鏄惁蹇呭~ * @return */ - protected boolean checkRequiredIsOk(String tip, String txt){ + protected boolean checkRequiredIsOk(String tip, String txt,boolean isRequired/*鏄惁蹇呭~*/){ boolean res = false; - if(Func.isBlank(txt)){ + if(Func.isBlank(txt) && isRequired){ throw new VciBaseException(tip + " 涓嶈兘涓虹┖锛�"); } else { res = true; @@ -1623,11 +1851,11 @@ * @param btmName 涓氬姟绫诲瀷鍚� * @return */ - protected boolean checkBtmTypeTxtIsOk(String tipName, String btmName) throws PLException { + protected boolean checkBtmTypeTxtIsOk(String tipName, String btmName,boolean isRequired) throws PLException { boolean res = false; if(tipName == null) return true; if(btmName == null) return true; - if(!checkRequiredIsOk(tipName, btmName)){ + if(!checkRequiredIsOk(tipName, btmName, isRequired)){ res = false; } else if(!checkBtmNameIsExist(tipName, btmName)){ res = false; @@ -1679,11 +1907,11 @@ * @param btmLinkType * @return */ - protected boolean checkPortalVITxtIsOk(String tip, String txtVIName, String btmLinkType) throws PLException { + protected boolean checkPortalVITxtIsOk(String tip, String txtVIName, String btmLinkType, boolean isRequired) throws PLException { boolean res = false; if(tip == null) return true; if(txtVIName == null) return true; - if(!checkRequiredIsOk(tip, txtVIName)){ + if(!checkRequiredIsOk(tip, txtVIName,isRequired)){ res = false; } else if(!checkPortalVIIsExist(tip, txtVIName, btmLinkType)){ res = false; @@ -1722,13 +1950,13 @@ * @param btmLinkType * @return */ - protected boolean checkQTNameTxtIsOk(String tip, String txtQTName, String btmLinkType) throws PLException { + protected boolean checkQTNameTxtIsOk(String tip, String txtQTName, String btmLinkType, boolean isRequired) throws PLException { boolean res = false; if(tip == null) return true; if(txtQTName == null) return true; - if(!checkRequiredIsOk(tip, txtQTName)){ + if(!checkRequiredIsOk(tip, txtQTName, isRequired)){ res = false; - } else if(Func.isBlank(txtQTName) && !checkQTIsExist(tip, txtQTName, btmLinkType)){ + } else if(Func.isNotBlank(txtQTName) && !checkQTIsExist(tip, txtQTName, btmLinkType)){ res = false; } else { res = true; @@ -1743,11 +1971,11 @@ * @param btmLinkType * @return */ - protected boolean checkUILayoutTxtIsOk(String tip, String uiName, String btmLinkType) throws PLException { + protected boolean checkUILayoutTxtIsOk(String tip, String uiName, String btmLinkType, boolean isRequired) throws PLException { boolean res = false; if(tip == null) return true; if(uiName == null) return true; - if(!checkRequiredIsOk(tip, uiName)){ + if(!checkRequiredIsOk(tip, uiName,isRequired)){ res = false; } else if(!checkUILayoutIsExist(tip, uiName, btmLinkType)){ res = false; @@ -1801,11 +2029,11 @@ * @param linkTypeName * @return */ - protected boolean checkLinkTypeTxtIsOk(String tip, String linkTypeName) throws PLException { + protected boolean checkLinkTypeTxtIsOk(String tip, String linkTypeName, boolean isRequired) throws PLException { boolean res = false; if(tip == null) return true; if(linkTypeName == null) return true; - if(!checkRequiredIsOk(tip, linkTypeName)){ + if(!checkRequiredIsOk(tip, linkTypeName,isRequired)){ res = false; } else if(!checkLinkTypeIsExist(tip, linkTypeName)){ res = false; @@ -1949,11 +2177,11 @@ */ private boolean checkBtmTypeInputIsOk(String btmType,String txtVIName/*閫夋嫨妯℃澘*/,String txtQTName/*鏌ヨ妯℃澘*/) throws PLException { boolean res = false; - if(!super.checkBtmTypeTxtIsOk("涓氬姟绫诲瀷", btmType)){ + if(!super.checkBtmTypeTxtIsOk("涓氬姟绫诲瀷", btmType,true)){ res = false; - } else if(!super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, btmType)){ + } else if(!super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, btmType,true)){ res = false; - } else if(!super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, btmType)){ + } else if(!super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, btmType,false)){ res = false; } else { res = true; @@ -1970,11 +2198,11 @@ */ private boolean checkLinkTypeInputIsOk(String txtVIName/*閫夋嫨鐨勬ā鏉�*/,String txtQTName/*鏌ヨ妯℃澘*/,String btmType) throws PLException { boolean res = false; - if(!(this.checkBtmTypeTxtIsOk("鐩爣瀵硅薄", linkType))){ + if(!(this.checkBtmTypeTxtIsOk("鐩爣瀵硅薄", linkType,true))){ res = false; - } else if(!(this.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, linkType))){ + } else if(!(this.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, linkType,true))){ res = false; - } else if(!(this.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, linkType))){ + } else if(!(this.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, linkType,false))){ res = false; } else { res = true; @@ -2054,11 +2282,11 @@ private boolean checkBtmTypeInputIsOk() throws PLException { boolean res = false; - if(!(super.checkBtmTypeTxtIsOk("椤剁骇鑺傜偣鏄剧ず绫诲瀷", btmType))){ + if(!(super.checkBtmTypeTxtIsOk("椤剁骇鑺傜偣鏄剧ず绫诲瀷", btmType,true))){ res = false; - } else if(!(super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, btmType))){ + } else if(!(super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, btmType,true))){ res = false; - } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName , btmType))){ + } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName , btmType,false))){ res = false; } else { res = true; @@ -2068,11 +2296,11 @@ private boolean checkLinkTypeInputIsOk() throws PLException { boolean res = false; - if(!(super.checkBtmTypeTxtIsOk("椤剁骇鑺傜偣鏄剧ず绫诲瀷", linkType))){ + if(!(super.checkBtmTypeTxtIsOk("椤剁骇鑺傜偣鏄剧ず绫诲瀷", linkType,true))){ res = false; - } else if(!(super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, linkType))){ + } else if(!(super.checkPortalVITxtIsOk("閫夋嫨妯℃澘", txtVIName, linkType,true))){ res = false; - } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, linkType))){ + } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", txtQTName, linkType,false))){ res = false; } else { res = true; @@ -2150,34 +2378,34 @@ private boolean checkBtmTypeInputIsOk() throws PLException { boolean res = false; - if(!(super.checkBtmTypeTxtIsOk("涓氬姟绫诲瀷", btmType))){ + if(!(super.checkBtmTypeTxtIsOk("涓氬姟绫诲瀷", btmType,true))){ res = false; return res; } // 閾炬帴绫诲瀷涓嶄负绌烘椂锛岄渶瑕佸悓鏃舵鏌ラ摼鎺ョ被鍨嬪強閾炬帴绫诲瀷涓嬬殑鏌ヨ妯℃澘鏄惁鏈夋晥 if(Func.isBlank(linkType)){ - if(!(super.checkLinkTypeTxtIsOk("閾炬帴绫诲瀷", linkType))){ + if(!(super.checkLinkTypeTxtIsOk("閾炬帴绫诲瀷", linkType,false))){ res = false; return res; - } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, linkType))){ + } else if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, linkType,true))){ res = false; return res; } } else { // 閾炬帴绫诲瀷涓虹┖鏃讹紝鍙渶瑕佹鏌ヤ笟鍔$被鍨嬩笅鐨勬煡璇㈡ā鏉挎槸鍚︽湁鏁� - if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, btmType))){ + if(!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, btmType,true))){ res = false; return res; } } - if(!super.checkRequiredIsOk("鏍硅妭鐐规樉绀鸿〃杈惧紡", showExpressionRoot)){ + if(!super.checkRequiredIsOk("鏍硅妭鐐规樉绀鸿〃杈惧紡", showExpressionRoot,true)){ res = false; } - else if(!super.checkRequiredIsOk("鏍戣妭鐐规樉绀鸿〃杈惧紡", showExpression)){ + else if(!super.checkRequiredIsOk("鏍戣妭鐐规樉绀鸿〃杈惧紡", showExpression,true)){ res = false; } - else if(!super.checkRequiredIsOk("鍙傜収鏍戣缃�", refTreeSet)){ + else if(!super.checkRequiredIsOk("鍙傜収鏍戣缃�", refTreeSet,true)){ res = false; } else { @@ -2245,11 +2473,11 @@ private boolean checkUILayoutInputIsOk() throws PLException { boolean res = false; - if (!(super.checkBtmTypeTxtIsOk("瀵硅薄绫诲瀷", uiBtmType))) { + if (!(super.checkBtmTypeTxtIsOk("瀵硅薄绫诲瀷", uiBtmType,true))) { res = false; - } else if (!(super.checkUILayoutTxtIsOk("UI瀹氫箟", uiLayout, uiBtmType))) { + } else if (!(super.checkUILayoutTxtIsOk("UI瀹氫箟", uiLayout, uiBtmType,true))) { res = false; - } else if (!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, qryType))) { + } else if (!(super.checkQTNameTxtIsOk("鏌ヨ妯℃澘", queryTemplateName, qryType,false))) { res = false; } else { res = true; -- Gitblit v1.9.3