From c826afb6dbc2c1d4433b3c127c5f30f9f72fb2dc Mon Sep 17 00:00:00 2001
From: xiejun <xiejun@vci-tech.com>
Date: 星期一, 09 九月 2024 17:18:37 +0800
Subject: [PATCH] 属性加UI类型字段

---
 Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/pagemodel/OsAttributeVO.java             |   29 ++++
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlAttributeType.java        |   27 +++
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlType.java                 |   33 ++++
 Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/dto/OsAttributeDTO.java                  |   19 ++
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ItemTypeEnum.java                |   84 ++++++++++++
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/UIManagerServiceImpl.java   |  189 +++++++++++++++++++++++---
 Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsAttributeServiceImpl.java |    5 
 7 files changed, 362 insertions(+), 24 deletions(-)

diff --git a/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/dto/OsAttributeDTO.java b/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/dto/OsAttributeDTO.java
index 3731204..5232df6 100644
--- a/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/dto/OsAttributeDTO.java
+++ b/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/dto/OsAttributeDTO.java
@@ -38,6 +38,10 @@
      * 灞炴�х被鍨嬶紝浣跨敤鏋氫妇VciFieldTypeEnum
      */
     private String attributeDataType;
+    /**
+     * 灞炴�I鎺т欢鏄剧ず绫诲瀷
+     */
+    private  String attributeUIType;
 
     /**
      * 鏄惁鍙互涓虹┖
@@ -301,6 +305,14 @@
         this.scaleLength = scaleLength;
     }
 
+    public String getAttributeUIType() {
+        return attributeUIType;
+    }
+
+    public void setAttributeUIType(String attributeUIType) {
+        this.attributeUIType = attributeUIType;
+    }
+
     @Override
     public String toString() {
         return "OsAttributeDTO{" +
@@ -309,17 +321,24 @@
                 ", name='" + name + '\'' +
                 ", description='" + description + '\'' +
                 ", attributeDataType='" + attributeDataType + '\'' +
+                ", attributeUIType='" + attributeUIType + '\'' +
                 ", nullableFlag=" + nullableFlag +
                 ", defaultValue='" + defaultValue + '\'' +
                 ", enumId='" + enumId + '\'' +
                 ", enumName='" + enumName + '\'' +
                 ", btmTypeId='" + btmTypeId + '\'' +
                 ", btmTypeName='" + btmTypeName + '\'' +
+                ", linkTypeName='" + linkTypeName + '\'' +
+                ", version=" + version +
                 ", attrLength=" + attrLength +
                 ", precisionLength=" + precisionLength +
                 ", scaleLength=" + scaleLength +
                 ", range='" + range + '\'' +
                 ", ts=" + ts +
+                ", creator='" + creator + '\'' +
+                ", createTime=" + createTime +
+                ", lastModifier='" + lastModifier + '\'' +
+                ", lastModifyTime=" + lastModifyTime +
                 '}';
     }
 }
diff --git a/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/pagemodel/OsAttributeVO.java b/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/pagemodel/OsAttributeVO.java
index 1cad6e4..4de3c81 100644
--- a/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/pagemodel/OsAttributeVO.java
+++ b/Source/plt-web/plt-web-parent/plt-web-api/src/main/java/com/vci/pagemodel/OsAttributeVO.java
@@ -43,6 +43,14 @@
      * 灞炴�х被鍨嬫樉绀烘枃鏈�
      */
     private String attributeDataTypeText;
+    /**
+     * 灞炴�I鎺т欢鏄剧ず绫诲瀷
+     */
+    private  String attributeUIType;
+    /**
+     * 灞炴�I鎺т欢鏄剧ず绫诲瀷鏂囨湰
+     */
+    private  String attributeUITypeText;
 
     /**
      * 鏄惁鍙互涓虹┖
@@ -353,6 +361,22 @@
         this.scaleLength = scaleLength;
     }
 
+    public String getAttributeUIType() {
+        return attributeUIType;
+    }
+
+    public void setAttributeUIType(String attributeUIType) {
+        this.attributeUIType = attributeUIType;
+    }
+
+    public String getAttributeUITypeText() {
+        return attributeUITypeText;
+    }
+
+    public void setAttributeUITypeText(String attributeUITypeText) {
+        this.attributeUITypeText = attributeUITypeText;
+    }
+
     @Override
     public String toString() {
         return "OsAttributeVO{" +
@@ -362,16 +386,21 @@
                 ", description='" + description + '\'' +
                 ", attributeDataType='" + attributeDataType + '\'' +
                 ", attributeDataTypeText='" + attributeDataTypeText + '\'' +
+                ", attributeUIType='" + attributeUIType + '\'' +
+                ", attributeUITypeText='" + attributeUITypeText + '\'' +
                 ", nullableFlag=" + nullableFlag +
                 ", defaultValue='" + defaultValue + '\'' +
                 ", enumId='" + enumId + '\'' +
                 ", enumName='" + enumName + '\'' +
                 ", btmTypeId='" + btmTypeId + '\'' +
                 ", btmTypeName='" + btmTypeName + '\'' +
+                ", linkTypeName='" + linkTypeName + '\'' +
+                ", version=" + version +
                 ", attrLength=" + attrLength +
                 ", precisionLength=" + precisionLength +
                 ", scaleLength=" + scaleLength +
                 ", range='" + range + '\'' +
+                ", other='" + other + '\'' +
                 ", btmname='" + btmname + '\'' +
                 ", owner='" + owner + '\'' +
                 ", creator='" + creator + '\'' +
diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlAttributeType.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlAttributeType.java
new file mode 100644
index 0000000..7f86ad2
--- /dev/null
+++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlAttributeType.java
@@ -0,0 +1,27 @@
+package com.vci.web.enumpck;
+
+public enum ControlAttributeType {
+
+    VTString,
+    VTInteger,
+    VTLong,
+    VTDouble,
+    VTBoolean,
+    VTImage,
+    VTDate,
+    VTTime,
+    VTDateTime,
+    VTNote,
+    VTFilePath,
+    VTClob,
+    canzhao;
+    public static ControlType Parse(String value) {
+        for (ControlType ct : ControlType.values()) {
+            if (ct.name().equalsIgnoreCase(value)) {
+                return ct;
+            }
+        }
+
+        return null;
+    }
+}
diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlType.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlType.java
new file mode 100644
index 0000000..e011ffd
--- /dev/null
+++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ControlType.java
@@ -0,0 +1,33 @@
+package com.vci.web.enumpck;
+
+public enum ControlType {
+	Text,
+	TextBtn,
+	TextArea,
+	RichText,
+	Number,
+	Password,
+	Radio,
+	Checkbox,
+	Select,
+	WebEditor,
+	Date,
+	Time,
+	Datetime,
+	Hidden,
+	Customform,
+	File,
+	MultiFile,
+	Custom,
+	UserChoose;
+	
+	public static ControlType Parse(String value) {
+		for (ControlType ct : ControlType.values()) {
+		    if (ct.name().equalsIgnoreCase(value)) {
+		      return ct;
+		    }
+		  }
+		
+		  return null;
+	}
+}
diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ItemTypeEnum.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ItemTypeEnum.java
index c2ef060..8db2a92 100644
--- a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ItemTypeEnum.java
+++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/enumpck/ItemTypeEnum.java
@@ -2,6 +2,7 @@
 
 import com.vci.pagemodel.KeyValue;
 import com.vci.starter.web.enumpck.BaseEnum;
+import com.vci.starter.web.enumpck.VciFieldTypeEnum;
 
 import java.util.ArrayList;
 import java.util.List;
@@ -141,4 +142,87 @@
         }
         return enumDataList;
     }
+
+    /***
+     *鏍规嵁灞炴�х被鍨嬭幏鍙朥I灞炴�х被鍨�(鏂囨湰)
+     * @param key
+     * @return
+     */
+    public static String convertAttributeTypeTOUITypeTextByValue(String key,boolean isText){
+        String value=ItemTypeEnum.TEXT.getValue();
+        ItemTypeEnum itemTypeEnum=null;
+        if(ControlAttributeType.VTInteger.equals(key)||
+           ControlAttributeType.VTDouble.equals(key)
+        ){
+            value = ItemTypeEnum.NUMBER.getValue();
+        }
+        else if (ControlAttributeType.VTNote.equals(key)) {// textarea绫诲瀷
+            value = ItemTypeEnum.TEXTAREA.getValue();
+        }// 鏃ヨ捣绫诲瀷
+        else if (ControlAttributeType.VTDate.equals(key)) {//鏃ユ湡
+            value = ItemTypeEnum.DATE.getValue();
+        }else if(ControlAttributeType.VTDateTime.equals(key)){//鏃ユ湡鏃堕棿
+            value = ItemTypeEnum.DATETIME.getValue();
+        }else  if( ControlAttributeType.VTTime.equals(key)){//鏃堕棿
+            value = ItemTypeEnum.TIME.getValue();
+        }
+        else  if( ControlAttributeType.canzhao.equals(key)){//鍙傜収
+            value = ItemTypeEnum.TEXT.getValue();
+        }
+        else  if( ControlAttributeType.VTBoolean.equals(key)){//boolean
+            value = ItemTypeEnum.CHECKBOX.getValue();
+        }else  if( ControlAttributeType.VTFilePath.equals(key)){//鏂囦欢
+            value = ItemTypeEnum.FILE.getValue();
+        } else {
+            value = ItemTypeEnum.TEXT.getValue();
+        }
+        itemTypeEnum = forValue(value);
+        if(itemTypeEnum==null){
+            return "";
+        }else {
+            if (isText) {
+                value = itemTypeEnum.getText();
+            } else {
+                value = itemTypeEnum.getText();
+            }
+        }
+        return value;
+    }
+
+    /***
+     *鏍规嵁灞炴�х被鍨嬭幏鍙朥I灞炴�х被鍨�(鏂囨湰)
+     * @param key
+     * @return
+     */
+    public static String convertAttributeTypeTOUITypeValueByText(String key){
+        String value=ItemTypeEnum.TEXT.getValue();
+        if(ControlAttributeType.VTInteger.equals(key)||
+                ControlAttributeType.VTDouble.equals(key)
+        ){
+            value = ItemTypeEnum.NUMBER.getValue();
+        }
+        else if (ControlAttributeType.VTNote.equals(key)) {// textarea绫诲瀷
+            value = ItemTypeEnum.TEXTAREA.getValue();
+        }// 鏃ヨ捣绫诲瀷
+        else if (ControlAttributeType.VTDate.equals(key)) {//鏃ユ湡
+            value = ItemTypeEnum.DATE.getValue();
+        }else if(ControlAttributeType.VTDateTime.equals(key)){//鏃ユ湡鏃堕棿
+            value = ItemTypeEnum.DATETIME.getValue();
+        }else  if( ControlAttributeType.VTTime.equals(key)){//鏃堕棿
+            value = ItemTypeEnum.TIME.getValue();
+        }
+        else  if( ControlAttributeType.canzhao.equals(key)){//鍙傜収
+            value = ItemTypeEnum.TEXT.getValue();
+        }
+        else  if( ControlAttributeType.VTBoolean.equals(key)){//boolean
+            value = ItemTypeEnum.CHECKBOX.getValue();
+        }else  if( ControlAttributeType.VTFilePath.equals(key)){//鏂囦欢
+            value = ItemTypeEnum.FILE.getValue();
+        } else {
+            value = ItemTypeEnum.TEXT.getValue();
+        }
+        value= getTextByValue(value);
+        return value;
+    }
+
 }
diff --git a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsAttributeServiceImpl.java b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsAttributeServiceImpl.java
index ec96cc5..038360c 100644
--- a/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsAttributeServiceImpl.java
+++ b/Source/plt-web/plt-web-parent/plt-web/src/main/java/com/vci/web/service/impl/OsAttributeServiceImpl.java
@@ -28,6 +28,7 @@
 import com.vci.starter.web.pagemodel.*;
 import com.vci.starter.web.util.*;
 import com.vci.model.OsAttributeDO;
+import com.vci.web.enumpck.ItemTypeEnum;
 import com.vci.web.enumpck.PortalVITypeFlag;
 import com.vci.web.properties.UsedNames;
 import com.vci.web.service.OsAttributeServiceI;
@@ -347,6 +348,10 @@
 			attributeVO.setDescription(attribItem.description);
 			attributeVO.setAttributeDataType(attribItem.vtDataType);
 			attributeVO.setAttributeDataTypeText(VciFieldTypeEnum.getTextByValue(attribItem.vtDataType));
+			//鑾峰彇UI灞炴�х被鍨�
+			attributeVO.setAttributeUIType(ItemTypeEnum.convertAttributeTypeTOUITypeTextByValue(attribItem.vtDataType,false));
+			//鑾峰彇UI灞炴�х被鍨嬫枃鏈�
+			attributeVO.setAttributeUITypeText(ItemTypeEnum.convertAttributeTypeTOUITypeTextByValue(attribItem.vtDataType,true));
 			attributeVO.setDefaultValue(attribItem.defValue);
 			if(Func.isNotBlank(attribItem.rage)){
 				attributeVO.setRange(attribItem.rage.replace("&lt;","<"));
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 d843ddb..2a06917 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
@@ -33,6 +33,7 @@
 import lombok.NoArgsConstructor;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.web.multipart.MultipartFile;
 
@@ -62,7 +63,11 @@
      */
     @Resource
     private SmRoleQueryServiceI smRoleQueryServiceI;
-
+    /***
+     * 鏄惁鏄鐞嗗憳
+     */
+    @Autowired
+    RightControlUtil rightControlUtil;
     /**
      * 涓氬姟绫诲瀷
      */
@@ -827,6 +832,12 @@
         return treeList;
     }
 
+    /***
+     * UI鎺堟潈
+     * @param uiAuthorDTO
+     * @return
+     * @throws Exception
+     */
     @Override
     public boolean authorizedUI(UIAuthorDTO uiAuthorDTO) throws Exception {
         boolean res=false;
@@ -842,41 +853,41 @@
         treeQueryObject.setConditionMap(conditionMap);
         List<Tree> treeList=this.getUIAuthor(treeQueryObject);
         HashMap<String,Tree> allTreeMap=new HashMap<>();
+        Map<String,RoleRightVO> roleRightVOMap=new HashMap<>();
         if(!CollectionUtil.isEmpty(treeList)){
+            if(StringUtils.isNotBlank(uiAuthorDTO.getRoleId())){
+                String userName= WebThreadLocalUtil.getCurrentUserSessionInfoInThread().getUserId();
+                RoleRightInfo[] rightInfos= platformClientUtil.getFrameworkService().getRoleRightList(uiAuthorDTO.getRoleId(),userName);
+                List<RoleRightVO>  roleRightVOList=roleRightDOO2VOS(Arrays.asList(rightInfos));
+                roleRightVOMap=roleRightVOList.stream().collect(Collectors.toMap(RoleRightVO::getFuncId,roleRightVO ->roleRightVO));
+            }
             convertTreeDOO2Map(treeList,allTreeMap);
             List<RoleRightDTO> roleRightDTOList=new ArrayList<>();
             List<Tree>  selectTreeList= uiAuthorDTO.getSelectTreeList();
-            getRoleRightDTOS(uiAuthorDTO.getRoleId(),selectTreeList,allTreeMap,roleRightDTOList);
+            getSelectedRoleRightObjs(uiAuthorDTO.getRoleId(),selectTreeList,allTreeMap,roleRightDTOList);
         }
         return res;
     }
 
-    private void getRoleRightDTOS(String roleOid,List<Tree>  selectTreeList,HashMap<String,Tree> allTreeMap,  List<RoleRightDTO> roleRightDTOList){
+    /**
+     *
+     * @param roleOid
+     * @param selectTreeList
+     * @param allTreeMap
+     * @param roleRightDTOList
+     */
+    private void getSelectedRoleRightObjs(String roleOid,List<Tree>  selectTreeList,HashMap<String,Tree> allTreeMap,  List<RoleRightDTO> roleRightDTOList){
+        Date date=new Date();
+        Map<String,RoleRightDTO> roleRightDTOMap=new HashMap<>();
         selectTreeList.stream().forEach(tree -> {
             RoleRightDTO roleRightDTO=new RoleRightDTO();
             String id=ObjectUtility.getNewObjectID36();
             Object data=  tree.getData();
-
-            if (data instanceof BizType) {//涓氬姟绫诲瀷
-                BizType bizType=(BizType)data;
-                roleRightDTO.setId(id);//涓婚敭
-                roleRightDTO.setCreateUser(null);//鍒涘缓鑰�
-                roleRightDTO.setCreateTime(null);//鍒涘缓鏃堕棿
-                roleRightDTO.setModifyUser(null);//淇敼鑰�
-                roleRightDTO.setModifyTime(null);//淇敼鏃堕棿
-                roleRightDTO.setRoleId(roleOid);//瑙掕壊ID
-                roleRightDTO.setRightValue(1);// 鏉冮檺鍊�
-                roleRightDTO.setRightType((short) -1);//鏉冮檺绫诲瀷 鏉冮檺绫诲瀷锛岃秴绾х鐞嗗憳缁欑鐞嗗憳鎺堟潈涓�1锛岀鐞嗗憳缁欐櫘閫氱敤鎴锋巿鏉冧负2
-                roleRightDTO.setFuncId(null);
-                roleRightDTO.setLicensor(null);
-            }else  if (data instanceof PLUILayout){//UI
-
-            }else if (data instanceof PLTabPage) {//UI涓婁笅鏂�
-
-
-            }else if (data instanceof PLPageDefination) {//
-
-
+            if(data instanceof String){
+                getRightValue(roleOid,tree,allTreeMap,false,roleRightDTOMap);//鍚戜笅鑾峰彇鎵�鏈夋ā鍧楃殑鏉冮檺鍊�
+            }else if (!(data instanceof PLTabButton)) {//涓氬姟绫诲瀷
+                getRightValue(roleOid,tree,allTreeMap,true,roleRightDTOMap);//鍚戜笂澶勭悊
+                getRightValue(roleOid,tree,allTreeMap,false,roleRightDTOMap);//鍚戜笅澶勭悊锛堝寘鍚綋鍓嶈妭鐐癸級
             }else if (data instanceof PLTabButton) {//鎸夐挳
 
             }
@@ -885,6 +896,136 @@
 
 
     }
+    /**
+     * 鑾峰彇鏉冮檺
+     * @param isUp 鏄惁鏄悜涓婅幏鍙栵紝濡傛灉鏄悜涓婅幏鍙栵紝浼犺繘鏉ョ殑蹇呯劧鏄ā鍧楄妭鐐癸紝涓斾笂绾фā鍧楀繀鐒舵槸娌℃湁閫変腑
+     */
+    private void getRightValue(String roleId,Tree node,HashMap<String,Tree> allTreeMap,boolean isUp,Map<String,RoleRightDTO> rightMap){
+        SessionInfo sessionInfo = WebThreadLocalUtil.getCurrentUserSessionInfoInThread();
+        String currentUserName = sessionInfo.getUserId();
+        boolean isDeveloper= rightControlUtil.isDeveloper(currentUserName);
+        String parentOid=node.getParentId();
+        if(allTreeMap.containsKey(parentOid)){
+            String id=ObjectUtility.getNewObjectID36();
+            Tree parentNode =allTreeMap.get(parentOid);
+            Object parentData=  parentNode.getData();
+            if(isUp) {//鍚戜笂鑾峰彇锛屽瓨鍌ㄦ瘡涓笂绾фā鍧楃殑鏉冮檺鍊�
+                while (!"root".equals(parentNode.getData())){
+                    String funcId = "";
+                    if (parentData instanceof BizType) {
+                        BizType bizType = (BizType) parentData;
+                        funcId = bizType.name;
+                    } else if (parentData instanceof PLUILayout) {
+                        PLUILayout context = (PLUILayout)parentData;
+                        funcId = context.plOId;
+                    } else if (parentData instanceof PLTabPage) {
+                        PLTabPage tab = (PLTabPage) parentData;
+                        funcId = tab.plOId;
+                    } else if (parentData instanceof PLPageDefination){
+                        PLPageDefination pageDef = (PLPageDefination) parentData;
+                        funcId = pageDef.plOId;
+                    } else if (parentData instanceof PLTabButton) {
+                        PLTabButton but = (PLTabButton)parentData;
+                        funcId = but.plOId;
+                    }
+                    RoleRightDTO roleRightDTO = new RoleRightDTO();
+                    roleRightDTO.setId(id);//涓婚敭
+                    roleRightDTO.setFuncId(funcId);
+                    if(isDeveloper) {
+                        roleRightDTO.setRightType((short) 1);//鏉冮檺绫诲瀷 鏉冮檺绫诲瀷锛岃秴绾х鐞嗗憳缁欑鐞嗗憳鎺堟潈涓�1锛岀鐞嗗憳缁欐櫘閫氱敤鎴锋巿鏉冧负2
+                    }else{
+                        roleRightDTO.setRightType((short) 2);
+                    }
+                    roleRightDTO.setRightValue(1);// 鏉冮檺鍊硷紝娌℃湁鎿嶄綔鐨勬ā鍧楁潈闄愬�煎瓨鍌ㄤ负0
+                    roleRightDTO.setRoleId(roleId);//瑙掕壊ID
+                    roleRightDTO.setCreateUser(currentUserName);//鍒涘缓鑰�
+                    roleRightDTO.setCreateTime(new Date());//鍒涘缓鏃堕棿
+                    roleRightDTO.setModifyUser(currentUserName);//淇敼鑰�
+                    roleRightDTO.setModifyTime(new Date());//淇敼鏃堕棿
+                    roleRightDTO.setLicensor("");
+                    if(!rightMap.containsKey(funcId)){
+                        rightMap.put(funcId, roleRightDTO);
+                    }
+                }
+            }else{
+                String funcId = "";
+                if(parentData instanceof String){
+                    funcId = (String)parentData;
+                } else if (parentData instanceof BizType) {
+                    BizType bizType = (BizType)parentData;
+                    funcId = bizType.name;
+                } else if (parentData instanceof PLUILayout) {
+                    PLUILayout context = (PLUILayout)parentData;
+                    funcId = context.plOId;
+                } else if (parentData instanceof PLTabPage) {
+                    PLTabPage tab = (PLTabPage) parentData;
+                    funcId = tab.plOId;
+                } else if (parentData instanceof PLPageDefination){
+                    PLPageDefination pageDef = (PLPageDefination) parentData;
+                    funcId = pageDef.plOId;
+                } else if (parentData instanceof PLTabButton) {
+                    PLTabButton but = (PLTabButton)parentData;
+                    funcId = but.plOId;
+                }
+                if(!(parentData instanceof PLPageDefination)) {//瀛愯妭鐐逛笉鏄搷浣�
+                    if(!rightMap.containsKey(funcId)&&!funcId.equals("root")){
+                        RoleRightDTO roleRightDTO = new RoleRightDTO();
+                        roleRightDTO.setFuncId(funcId);
+                        if(isDeveloper) {
+                            roleRightDTO.setRightType((short) 1);//鏉冮檺绫诲瀷 鏉冮檺绫诲瀷锛岃秴绾х鐞嗗憳缁欑鐞嗗憳鎺堟潈涓�1锛岀鐞嗗憳缁欐櫘閫氱敤鎴锋巿鏉冧负2
+                        }else{
+                            roleRightDTO.setRightType((short) 2);
+                        }
+                        roleRightDTO.setRightValue(0);//娌℃湁鎿嶄綔鐨勬ā鍧楁潈闄愬�煎瓨鍌ㄤ负0
+                        roleRightDTO.setRoleId(roleId);
+                        roleRightDTO.setCreateUser(currentUserName);
+                        roleRightDTO.setCreateTime(new Date());
+                        roleRightDTO.setModifyUser(currentUserName);
+                        roleRightDTO.setModifyTime(new Date());
+                        roleRightDTO.setLicensor("");
+                        rightMap.put(funcId, roleRightDTO);
+                    }
+                    for(int i = 0;i < parentNode.getChildren().size();i++){
+                        //瀵规瘡涓瓙鍚戜笅閫掑綊閬嶅巻
+                        getRightValue(roleId,parentNode.getChildren().get(i),allTreeMap,false,rightMap);
+                    }
+                }else {
+                    if(!rightMap.containsKey(funcId)){
+                        RoleRightDTO roleRightDTO = new RoleRightDTO();
+                        roleRightDTO.setFuncId(funcId);
+                        roleRightDTO.setRightType((short)2); // 璁剧疆UI鏉冮檺
+                        roleRightDTO.setRightValue(countRightValue(parentNode,true));//娌℃湁鎿嶄綔鐨勬ā鍧楁潈闄愬�煎瓨鍌ㄤ负0
+                        roleRightDTO.setRoleId(roleId);
+
+                        roleRightDTO.setCreateUser(currentUserName);
+                        roleRightDTO.setCreateTime(new Date());
+                        roleRightDTO.setModifyUser(currentUserName);
+                        roleRightDTO.setModifyTime(new Date());
+                        roleRightDTO.setLicensor("");
+                        rightMap.put(funcId, roleRightDTO);
+                    }
+                }
+            }
+
+        }
+    }
+    /**
+     * 浼犲叆鐩存帴鎸傛帴鎿嶄綔鐨勬ā鍧楃殑鑺傜偣,璁$畻璇ヨ妭鐐圭殑鏉冮檺鍊�
+     * @param node 妯″潡鑺傜偣
+     * @param isAll 鏄惁瀛愮骇鍏ㄩ儴閫変腑
+     * @return
+     */
+    private long countRightValue(Tree node,boolean isAll){
+        long value = 0;
+        for(int i = 0;i < node.getChildren().size();i++){
+            Tree childNode = (Tree)node.getChildren().get(i);
+            if(isAll && node.getData() instanceof PLTabButton ){
+                PLTabButton obj = (PLTabButton)node.getData();
+                value += (long)Math.pow(2, obj.plSeq);//绱鍔犱笂鍚勪釜鎿嶄綔鐨勬潈闄愬��
+            }
+        }
+        return value;
+    }
 
     /**
      *

--
Gitblit v1.9.3